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

JavaScript Discussion :

Signature manuscrite tablette


Sujet :

JavaScript

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Mars 2015
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Distribution

    Informations forums :
    Inscription : Mars 2015
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Signature manuscrite tablette
    Bonjour a tous. Je requiers votre aide sur un soucis que je rencontre au boulot.
    Je vais essayer d'être clair.
    Je développe un outils permettant de créer des rapport d'interventions lors de nos déplacements extérieurs.
    Je développe en html css, avec du js en cas de besoin.
    Notre société utilise comme logiciels de developpement pour nos appli métier OPENEDGE PROGRESS (pour ceux qui connaissent).
    Mon appli tourne correctement, mais je bute sur un point.
    Je souhaite à la fin du rapport demander une signature sur ipad.
    J'y arrive (d'un sens) avec le code fourni ici: https://github.com/szimek/signature_pad
    J'ai réussi à adapter le code pour mon utilisation (sous webspeed pour ceux qui connaissent)
    Mon fonctionnement est le suivant: signature coté client sur tablette, envoi des données, puis traitement côté serveur.
    Le premier soucis est qu'avec le logiciel que l'on utilise, on ne peux envoyer que des "petites" variables. Sur tablette le js permettant designer créer des variables de
    40 - 50000 caractères en base64, ce qui me renvoi des message d'erreur côté serveur. Donc première chose, j'ai découpé ma variable en plusieurs de max 10000 caractères.
    Ensuite, côté serveur, je ne peux pas enregistrer des champs trop volumineux dans ma base, donc je me suis dit que j'allai recréer une image en PNG de la signature.
    Pour ce, je mets toutes mes variables dans un fichier .txt pour recréer le code en base64.
    Ensuite, sur ubuntu, je fais la commande base64 -d toto2.txt > toto.png, pour générer mon png à partir du txt.
    Le soucis que je rencontre est le suivant : pour des signature ne dépassant pas 10000 caractères cela fonctionne, mais au dela l'image à cette allure:
    Pièce jointe 172400
    les 10000 premiers caractères (variable1) sont correctement interprêtés et l'image est nickel, mais ensuite le reste est retranscrit "brouillé".

    Pour info : base 64 me renvoi ceci : base64: invalid input
    Code js :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    window.onresize = resizeCanvas;
    resizeCanvas();
     
    signaturePad = new SignaturePad(canvas);
     
    clearButton.addEventListener("click", function (event) {
        signaturePad.clear();
    });
     
    saveButton.addEventListener("click", function (event) {
        if (signaturePad.isEmpty()) {
            alert("Veuillez signer dans la Zone Blanche");
        } else {
     
            /*La fonction windows open sert a afficher à l'ecran une variable*/
    		/*window.open(signaturePad.toDataURL());	*/
     
    		/*lenght sert à compter le nombre de caractère dans une chaine*/
    		lg = (signaturePad.toDataURL()).length;				
    		alert(lg);
     
    		$('#signature1').val(signaturePad.toDataURL().substr(0,10000));						
    	        $('#signature2').val(signaturePad.toDataURL().substr(10001,20000));
    		$('#signature3').val(signaturePad.toDataURL().substr(20001,30000));
    		$('#signature4').val(signaturePad.toDataURL().substr(30001,40000));
    		$('#signature5').val(signaturePad.toDataURL().substr(40001,50000));		
     
    		$('#lg').val(lg);	
     
    		/*$('#signature1').val(signaturePad.toDataURL());*/
    		$('#exec_prev').submit();						
        }	
    });
    J'espère avoir été clair!
    A bientôt.

  2. #2
    Membre chevronné

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Points : 1 768
    Points
    1 768
    Billets dans le blog
    1
    Par défaut
    Trop de "je peux pas par ce que" enregistrer une image a gros format par PHP ou apache l'autorise pas, ou est limité a cause de sa configuration ou autre donc il y a toujours d'autre moyen d'éviter ce problème comme envoyer le fichier par ftp, augmenter la taille de la limit de l'upload de fichier au niveau du server web ... passer par du NOSQL.
    Un Environnement REST API (Web mobile POST GET PUT DELETE HEAD ...) est destiné a combler le problème limitation et de ralentissement et adapté a envoyer via un format json toute la chaine que tu souhaite...
    Niveau base de donnée l'image est souvent enregistrer sous format type blob en base de donnée donc pas si limité si tu as omis de choisir le bon format d'image etc ...

    Et l'affichage en js de ton image ce fera simplement en récupérant ta chaine blob de ta db relationnelle ou pas pour :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    var data = "";
     
    console.log("devicePixelRatio: ", window.devicePixelRatio);
    console.log("data length: ", data.length);
     
    img = new Image();
    img.src = data;
      //document.getElementById('signature-pad').appendChild(img);
    document.body.appendChild(img);
    Petite piste pour prévoir dans ton implémentation un module nodejs (pour rester sur le js) mais tout a fait possible dans un autre languages côté serveur de récupérer les données via ton propre client ftp.
    https://www.npmjs.com/package/jsftp

  3. #3
    Membre averti
    Profil pro
    à la bougie alors
    Inscrit en
    Mai 2006
    Messages
    224
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : à la bougie alors

    Informations forums :
    Inscription : Mai 2006
    Messages : 224
    Points : 362
    Points
    362
    Par défaut
    edit:22/03/2015 19:46 mal lu

    substr prend la position du premier caractère et une longueur

    Soit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    ...substr(0,10000);
    ...substr(10000,10000);
    ...substr(20000,10000);
    etc.

Discussions similaires

  1. [iPad] librairie pour champ signature (manuscrite) IOS
    Par jason42 dans le forum Objective-C
    Réponses: 2
    Dernier message: 20/02/2013, 18h59
  2. [WD-2010] Comment inserer une signature manuscrite, word?
    Par Georges974 dans le forum Word
    Réponses: 1
    Dernier message: 14/11/2012, 06h06
  3. PDA signature manuscrite
    Par nawara3003 dans le forum Servlets/JSP
    Réponses: 0
    Dernier message: 28/02/2010, 17h04
  4. Digitaliser une signature manuscrite
    Par mbartolacci dans le forum Droit
    Réponses: 2
    Dernier message: 09/10/2008, 11h05
  5. Capter la signature manuscrite dans un formulaire
    Par ClaudeLELOUP dans le forum IHM
    Réponses: 4
    Dernier message: 14/12/2007, 22h24

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