IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Développement Mobile .NET Discussion :

[Ionic 4 / Angular 9] Probléme de lecture d'un fichier juste écris


Sujet :

Développement Mobile .NET

  1. #1
    Membre actif Avatar de dragonfly
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    464
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 464
    Points : 240
    Points
    240
    Par défaut [Ionic 4 / Angular 9] Probléme de lecture d'un fichier juste écris
    Bonjour à tous,

    j'ai un petit souci avec Ionic4, le but de mon programme est d'ouvrir une image, de modifier l'EXIF et de sauvegarder l'image.

    A priori, tout fonctionne bien sauf que quand je rouvre l'image juste enregistré, les données sont différentes de l'image sauvegardé et l'image est 'corrompu', voici mon code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
        this.file.writeExistingFile(rep, fic, insert).then(
                    (data) => {
                      this.file.readAsBinaryString(rep, fic).then(
                        (data2) => {
                          console.log('data2', data2);
                       });
                    }
                  );
    Les données insérèes ressemblent à ca (variable insert de la fonction writeExistingFile):

    Nom : file1.png
Affichages : 104
Taille : 91,5 Ko

    Et quand je rouvre le fichier, j'ai des données de ce type :

    Nom : file2.png
Affichages : 105
Taille : 110,2 Ko

    J'ai essayé de le lire en binaire mais j'ai le même probléme, y'a t'il un truc que j'ai loupé? (genre de l'encodage ou un truc du genre)

    Ce probléme se produit lors d'un test sur tablette Android (HUAWEI)

    Please HELP.
    Merci

  2. #2
    Membre actif Avatar de dragonfly
    Profil pro
    Inscrit en
    Janvier 2006
    Messages
    464
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations forums :
    Inscription : Janvier 2006
    Messages : 464
    Points : 240
    Points
    240
    Par défaut
    Aprés de nombreuses recherches, il faut faire quelques manip avant d'écrire le fichier (passer par du ArrayBuffer en ayant supprimé le type...)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    const base64ToArrayBuffer = base64 => {
      const binaryString = window.atob(base64);
      const len = binaryString.length;
      const bytes = new Uint8Array(len);
      for (let i = 0; i < len; i++) {
        bytes[i] = binaryString.charCodeAt(i);
      }
     
     const dataBlob = base64ToArrayBuffer(base64.split(',')[1]);
     
      return file.writeFile(rep, fic, dataBlob, { replace: true, append: false }).then(() => {
        return true;
      });
    Et maintenant ca marche

Discussions similaires

  1. [VBnet] Problème de lecture d'un fichier texte.
    Par dibeloni dans le forum Windows Forms
    Réponses: 3
    Dernier message: 31/03/2006, 19h12
  2. [VB6] Problème de lecture d'un fichier excel
    Par Requin15 dans le forum VB 6 et antérieur
    Réponses: 5
    Dernier message: 23/03/2006, 17h10
  3. Problème de lecture d'un fichier
    Par rvweb dans le forum C++
    Réponses: 3
    Dernier message: 30/12/2005, 21h03
  4. Réponses: 2
    Dernier message: 28/12/2005, 15h00
  5. Problème de lecture dans un fichier xml
    Par Pyra dans le forum Langage
    Réponses: 2
    Dernier message: 18/12/2005, 00h13

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo