Toutes mes réponses sur les forums
-
AuteurRéponses
-
MerlinMaître des clés
Quand on clique sur le bouton Export la console renvoie une erreur dans la dernière (et 2e) boucle “for” du script contenu dans ce bouton :
TypeError: f is null
22:Field:Mouse Up
C’est ce qui doit empêcher la fonction GestionCalques(), qui vient ensuite, de s’exécuter. Parce-qu’une erreur bloque le script, ce qui suit ne s’exécute pas.
Dans ce script tu devrais remplacer :
for (var i = 0; i < 25; i++) {
var fname = this.getNthFieldName(i);
var f = this.getField(fname);
f.readonly = true;
};Par :
for (var i=0; i<this.numFields; i++) {
var oFld = this.getField(this.getNthFieldName(i));
oFld.readonly = true;
}
MerlinMaître des clésPas forcément, les pièces jointes ont des droits que n’ont pas les documents en ligne.
À tester !
MerlinMaître des clésBonjour JC
La réponse est non, j’ai tout essayé, même en débloquant toutes les protections (https://helpx.adobe.com/fr/acrobat/using/allow-or-block-links-internet.html) ça ne fonctionne pas. Acrobat renvoie toujours les mêmes messages.
NotAllowedError: Les paramètres de protection interdisent l’accès à cette propriété ou à cette méthode.
et l’alerte ci-joint.
Attachments:
You must be logged in to view attached files.MerlinMaître des clésTout est bien, sauf le calque de boutons.
Quand on masque tous les calques du document on voit tous les champs de formulaires qui ne sont pas attachés à un calque, dont les boutons (voir ci-joint).
Donc il faut soit refaire le document dans InDesign en plaçant soigneusement les champs boutons sur le calque approprié (Acrobat ne sait pas gérer ça), soit gérer la visibilité des champs boutons en plus de celle du calque.
Attachments:
You must be logged in to view attached files.MerlinMaître des clésAussi, est ce que vous avez un tips pour tester des documents avec Reader ? Car comme j’ai Creative Cloud et Acrobat Pro, Adobe ne me laisse pas installer Reader…
Oui, comme je suis dans le même cas Adobe m’a forcé à installer Foxit Reader qui est son principal concurrent et j’ai découvert un excellent logiciel.
Et comme un bonheur ne vient jamais seul, Foxit Reader force à être plus soigneux dans l’utilisation des scripts car il ne supporte pas les fonctions JavaScript obsolètes. Les documents y gagnent donc beaucoup en pérennité.
😎
MerlinMaître des clésPour impression numérique classique dans une imprimerie, généralement ils recommandent d’utiliser un profil CMJN pour éviter des couleurs trop flash quand on doit convertir le profil RVB en CMJN.
C’est surtout pour éviter les réclamations des clients déçus qui ont envoyé des documents avec des couleurs RVB bien flashy, mais je suppose que ce n’est pas le cas de ce document. 😉
Tout est bien, sauf le calque de boutons.
Là il faudrait que tu partages (tout ou partie de) ce document pour qu’on puisse juger sur pièce.
MerlinMaître des clésPour quel type d’impression, Offset ou imprimante ?
En tout cas ça fait longtemps que les documents à imprimer sont conçus et exportés en RVB, ça permet d’exploiter au mieux le rendu colorimétrique de chaque procédé d’impression.
MerlinMaître des clésAstuce :
Si les champs de formulaire sont créés dans InDesign sur les calques correspondants il s’affichent et se masquent en même temps que le calque auquel ils sont attachés, sauf…
Sauf si on a eu le malheur de les déplacer ou de les couper/copier/coller dans Acrobat Pro, ce qui les “détache” de leur calque. Mais on peut modifier leurs propriétés sans problème avec Acrobat Pro, ils restent attachés à leur calque tant qu’on ne les déplace pas.
MerlinMaître des clésBonjour
Depuis InDesign il faut exporter en PDF interactif, pas en PDF impression.
Le “dossier” de calques n’a aucune importance, ça ne change pas leur comportement ni les scripts à utiliser. On peut cependant le supprimer en utilisant cet utilitaire gratuit : https://www.uvsar.com/projects/acrobat/indesignfixups/
Pour masquer le calque Grilles et repères (en Français) il faut éditer le script de cet utilitaire et y remplacer “Guides and Grids” par “Grilles et repères“. Mais ça n’a pas d’importance non plus, ce calque n’est pas gênant.
Ton script ne fonctionne pas sur Reader car cette ligne :
docOCGs.initState = true;
provoque une erreur et donc l’arrêt de l’exécution du script, parce-que Acrobat Reader ne peut pas modifier l’état initial des calques (initState). Il ne permet que de les afficher/masquer (state) temporairement.Ce qui signifie qu’ils reviennent systématiquement à leur état initial à chaque réouverture du document. Pour remédier à cet inconvénient il faut utiliser le script proposé dans ce sujet : https://www.abracadabrapdf.net/forums/topic/enregistrer-la-visibilite-des-calques-ogc-apres-le-remplissage-du-formulaire/
MerlinMaître des clés👍
MerlinMaître des clésQuand il y a plusieurs champs ayant le même nom il faut s’adresser au “widget” et non pas au champ, qui dans ce cas représente plusieurs widgets.
Dans la liste des champs du panneau des outils de formulaire les widgets apparaissent avec leur nom de champ, suivi d’un dièse et suivi d’un numéro d’ordre. Ce numéro d’ordre est attribué lors de la création du widget et n’est pas modifiable.
Dans la capture ci-joint on ne voit pas le widget numéro zéro car il est masqué puisque la page modèle sur laquelle il se trouve est masquée. Si on affiche la page modèle les deux widgets sont visibles dans la liste.
La particularité des widgets c’est qu’on ne peut pas s’adresser à eux directement, il faut impérativement passer par une variable. Sachant aussi que dans les scripts il faut remplacer le dièse par un point.
Ce qui pour tes boutons nous donne les scripts suivants :
var f = this.getField("CH1.1");
f.setFocus();
et
var f = this.getField("CH2.1");
f.setFocus();
Attachments:
You must be logged in to view attached files.MerlinMaître des clés“J’en conclu que les destinations sont perdues dès que l’on masque ou affiche une page modèle”
Oui, c’est bien ça.
“mais y a t-il donc un moyen de contourner ou de trouver une autre solution à ce problème ?”
Il faut utiliser les numéros de page, ou sinon pour un pointage plus précis on peut envoyer le focus vers un champ, éventuellement masqué.
this.getField("NOMDUCHAMPCIBLE").setFocus();
MerlinMaître des clésBonjour
Mac ou Windows ?
24 août 2023 à 13:01 en réponse à : Enregistrer la visibilité des Calques OGC apres le remplissage du formulaire #73148MerlinMaître des clésPS : le script ci-dessus utilise un champ texte (masqué) nommé “CalqCode“, à placer n’importe où dans le document.
24 août 2023 à 12:59 en réponse à : Enregistrer la visibilité des Calques OGC apres le remplissage du formulaire #73147MerlinMaître des clésBonjour
Avec Reader on ne peut pas aplatir ni modifier l’état de base (affiché/masqué) des calques.
Il n’y a que deux solutions :
- la signature numérique, qui fige le document.
- utiliser JavaScript pour enregistrer l’état des calques à la fermeture et le rétablir à la réouverture du document.
Exemple de script, la fonction GestionCalques() doit être utilisée lors de chaque modification de l’état des calques, ou bien en Action “Quand le document sera enregistré” (Document will save), et la fonction Ouverture() doit être exécutée à chaque ouverture du document :
function GestionCalques() {
ocg = this.getOCGs(this.pageNum);
indexCalque = 0;
code = "";
while (indexCalque < this.ocg.length)
{
if (ocg[indexCalque].state)
{
code=code + "1";
}
else
{
code=code + "0";
}
indexCalque = indexCalque + 1;
}
this.getField("CalqCode").value = code;
}
function Ouverture() {
ocg = this.getOCGs(this.pageNum);
code = this.getField("CalqCode").valueAsString;
indexCalque = 0;
while (indexCalque<this.ocg.length)
{
statut = code.substring(indexCalque,(indexCalque+1));
console.println("Rang " + indexCalque + " statut :" + statut)
if (statut==1)
{
ocg[indexCalque].state=true;
}
else
{
ocg[indexCalque].state=false;
}
indexCalque = indexCalque+1;
}
}
MerlinMaître des clésBonjour
Il faut exporter les données du ficher Réponses au format CSV, reconnu par tous les tableurs, et faire le traitement des données dans un tableur.
“Autre question en rapport, dans le fichier réponses, je peux déplacer les colonnes qui m’intéresse, mais même en enregistrant, à la nouvelle ouverture du fichier réponses, l’ordre des colonnes n’a pas été concervée?”
Bienvenue chez Adobe !
Spécialiste des interfaces et de l’expérience utilisateur, sauf dans Acrobat.
😉
MerlinMaître des clésBonjour
Le problème ne vient pas d’InDesign.
Le problème se sont les lecteurs de fichiers PDF, dont Acrobat, qui sont en dessous de tout.
Ce problème a été signalé de nombreuses fois à Adobe depuis l’arrêt de Flash Player mais rien n’y fait. Quand on utilise Acrobat Pro pour placer une vidéo on a les mêmes problèmes et la documentation est trop succincte.
Quand aux autres éditeurs…
Le plus sur c’est d’utiliser Acrobat Pro pour placer la vidéo en pièce jointe dans le PDF et pour créer un lien pour la lancer.
Ainsi elle s’affiche dans le lecteur vidéo par défaut, pas dans le lecteur de PDF.
MerlinMaître des clés“Cela ne fonctionne pas”
Qu’est-ce qui ne fonctionne pas et pourquoi ?
Il n’y a que des magiciens sur ce forum, mais aucun devin.
MerlinMaître des clésBonjour
Remplace la 2e ligne du script par :
var distance = Number(this.getField("distance").value) + Number(this.getField("total").value);
Par ailleurs c’est toujours une mauvaise idée de donner le même nom à un champ et à une variable, c’est source d’erreurs.
MerlinMaître des clésBonjour
Est-ce qu’il faut que la liste reprenne les valeurs contenues dans les champs 1, 2, 3 et 4 (si elles sont variables) ou bien peut-on reproduire ces valeurs directement dans la liste ?
Pouvez vous partager (tout ou partie de) ce formulaire ?
MerlinMaître des clésDu coup chat GT peut aller se rhabiller !
😁
MerlinMaître des clésPeux tu poster ce script ?
MerlinMaître des clés😎
MerlinMaître des clésBonjour
Quand on ouvre ce document la Console affiche ceci :
TypeError: event.target.value.toFixed is not a function
3:Field:Format
Pour moi le menu fonctionne normalement, mais il fonctionnerait encore mieux si l’option “Valider la valeur sélectionnée immédiatement” était cochée (onglet Options).
Mais ce menu déroulant fait des calculs faux, pour un montant de 100 € on a : un 1er acompte de 60 €, un 2e acompte de 40 € et un 3e acompte de 10 €.
Soit un total de 110 €, au moins tu as le sens des affaires ! 😀
Concernant la virgule il faut utiliser un format “nombre” normal, la valeur de ce champ n’étant pas calculée le script de format ne sert à rien d’autre qu’à provoquer les erreurs qui s’affichent dans la console JS.
Et il faudrait faire la même chose pour tous les champ situés au-dessus qui utilisent le point comme séparateur.
Sinon “acompte” ne prend qu’un seul C.
“Quantité” ne prend pas de E final.
Et concernant les abréviations des adjectifs numéraux voir : https://www.academie-francaise.fr/abreviations-des-adjectifs-numeraux
😉
Attachments:
You must be logged in to view attached files.MerlinMaître des clés😎
MerlinMaître des clés1 Oui, il suffit de supprimer la condition dans le script qui remplit le champ date automatiquement, ainsi la nouvelle date écrasera l’ancienne à chaque ouverture du document.
this.getField("validite").value=util.printd("dd/mm/yyyy", new Date(new Date().getTime()+(365*24*3600*1000)));
2 Il faut utiliser ce script en évènement “Document a été imprimé” :
this.getField("numero").value += 1;
MerlinMaître des clés“on ne trouve pas forcément beaucoup de tutoriels sur internet concernant le javascript pour les formulaires interactif PDF.”
Il y a beaucoup de tutos disponibles mais il faut lire l’Anglais ou savoir bien utiliser Googol Traduction.
Commence ici : https://www.abracadabrapdf.net/ressources-et-tutos/js-et-formulaires-ressources/ressources-pdf-javascript/
MerlinMaître des clés“si vous avez le bon script merci.”
Tu à l’air têtu, mais moi aussi : c’est donc la 2e fois que je te dis que tu trouveras les réponses que tu cherches dans mon fichier joint.
😎
MerlinMaître des clésDésolé, je suis trop nul en math et je n’ai pas le temps de chercher.
Mais si quelqu’un peut m’indiquer la formule de base pour calculer une telle moyenne je me ferai un plaisir de la convertir en JavaScript.
MerlinMaître des clésLe fichier que j’ai joint est fonctionnel, examine bien les scripts de validation et les scripts de calculs. Tu y trouveras toutes les réponses.
Qu’il y ait 2 champs à additionner pour le total ou qu’il en ait 50 le principe reste le même.
Tu devrais aussi lire cet article car quand on utilise tes fichiers la Console JavaScript affiche des informations très instructives sur les erreurs rencontrées :
MerlinMaître des clésJe ne suis pas certain d’avoir compris la question (un peu touffue…) mais en tout cas j’ai une réponse. 😉
Fichier fonctionnel ci-joint.
Attachments:
You must be logged in to view attached files.MerlinMaître des clésQuand j’ouvre ton fichier n°2 la console m’affiche cette erreur au moins 10 fois :
TypeError: this.geField is not a function
2:Field:CalculateDonc il faut commencer par remplacer geField par getField.
Je n’aurai pas le temps aujourd’hui mais j’examinerai ça de plus près ce soir ou demain.
MerlinMaître des clésBonjour
Où doivent apparaitre ces lettres ?
Dans le libellé du bouton cliqué ou dans autre champ ?
MerlinMaître des clésDu coup c’est encore plus simple.
temps = distance / vitesse
Donc dans le champ qui doit afficher le temps il faut placer ce calcul en notation simplifiée :
distance / vitesse
Si on part du principe que les champs se nomment “distance” et “vitesse”.
Attention, le résultat est donné en heures décimales, il faudra ensuite éventuellement convertir en H:MM
Voir : https://open.crea-learning.com/mod_turbolead/mod/crealearning/reader.php?n=OTA4MyYyOTEzMw%3D%3D
MerlinMaître des clésBonjour
Sur le principe la réponse est oui, mais dans ton exemple il manque un opérateur : la vitesse.
D’ailleurs il n’y a pas besoin de JavaScript, un calcul en notation simplifiée suffit :
((Texte1 * Texte2) / Texte3) / Texte4
Attachments:
You must be logged in to view attached files.MerlinMaître des clésBonjour
Place ce script en action Souris relâchée dans le champ texte :
if (!/^\s*$/.test(event.target.value)) {app.launchURL(event.target.value);}
MerlinMaître des clésBonjour
Il faut cocher l’option qui va bien dans les Options de la liste déroulante et utiliser ce script dans le champ texte :
event.target.value = this.getField("NOMDUCHAMP").value;
Attachments:
You must be logged in to view attached files.MerlinMaître des clés👍
MerlinMaître des clésUn tel script peut aussi être exécuté par une Action (Assistant Action).
MerlinMaître des clésthis.saveAs("/c/myDocs/myDoc.pdf", "com.callas.preflight.pdfa");
Erratum : comme cette fonction utilise le Contrôle en amont je suppose qu’elle ne fonctionne pas avec Acrobat Standard
Tout est là, attention il y a des restrictions :
https://opensource.adobe.com/dc-acrobat-sdk-docs/library/jsapiref/doc.html#saveas
MerlinMaître des clésBonjour
La réponse est oui mais Acrobat Reader (logiciel gratuit) ne peut pas enregistrer en PDF normé (PDF/A ou autre), ça requiert Acrobat Pro
ou Acrobat Standard.Même principe et même limitation chez Foxit, le principal concurrent.
MerlinMaître des clésPS : s’il s’agit de la valeur par défaut du menu déroulant on peut aussi utiliser :
this.getField("Dropdown2").value = this.getField("Dropdown2").defaultValue;
MerlinMaître des clésBonjour
getItemAt ça sert à connaitre la valeur d’un menu, pas à lui assigner une valeur.
Pour assigner une valeur à un menu déroulant il faut utiliser :
this.getField("Dropdown").value = "Blablabla";
Où “Blablabla” est la valeur d’exportation s’il y en a une, sinon c’est la valeur de l’item de menu qu’il faut utiliser.
MerlinMaître des clés👍
Pas mieux.
MerlinMaître des clésBonjour
Il faut pour chaque rangée mettre toutes les valeurs dans un tableau (array), et ensuite utiliser par exemple sort() pour classer les éléments.
Je n’ai pas plus de temps ce soir.
Je reviendrai pour les détails. 😉
MerlinMaître des clésBonjour
Oui c’est bien ce qu’il faut faire. La preuve c’est que ça fonctionne !
Mais normalement l’espace après l’apostrophe est signalée par le correcteur orthographique, c’est pour ça que ce cas n’est pas prévu par le script.
MerlinMaître des clésBonjour
Tout dépend de ce que recouvre “données web” mais dans le temps on pouvait importer/exporter des données depuis un PDF vers un serveur en ligne.
Avec beaucoup de restrictions bien entendu, sécurité oblige.
MerlinMaître des clésDans ce cas le mieux est de transférer les données entre les deux formulaires comme indiqué ci-dessus, et ensuite utiliser un script qui affecte la valeur “RAS” aux champs vides.
MerlinMaître des clésBonjour
Je ne connais pas PDF XChange mais je suppose que comme avec Acrobat on peut exporter/importer les données d’un formulaire.
Soit directement de PDF à PDF, soit indirectement en exportant les données au format FDF (ou XFDF).
MerlinMaître des clésBonjour
Je commencerais par : Préférences : Général : où je décocherais l’option “Afficher les messages d’Adobe…” (la 3e coche en partant du bas).
Sans oublier de croiser les doigts…
MerlinMaître des clés👍
MerlinMaître des clés👍
MerlinMaître des clésBonjour
Réponse en image, la boite de dialogue qui suit permet de sélectionner un ou plusieurs formulaires à exporter.
Bien entendu, s’il y a plusieurs formulaires à exporter dans un même fichier CSV il faut qu’au départ ils soient identiques, avec les mêmes noms de champs.
Attachments:
You must be logged in to view attached files.MerlinMaître des clés“Réinitialiser” signifie “revenir à la valeur par défaut” (reset to default value).
Ça ne concerne que la valeur du champ et donc aucun autre de ses attributs.
MerlinMaître des clésA priori c’est faisable (en récupérant le numéro suffixe ?) mais il faudrait que tu en dises plus car je ne comprend pas bien le but, sinon en supposant qu’il y aura plusieurs champs.
MerlinMaître des clés“Oui je ne suis pas fan des accents ..”
Contrairement à d’autres langues comme l’Espagnol (je ne connais pas le Portugais) en Français les accents ne servent pas qu’à la prononciation, ils ont pleine valeur orthographique et peuvent complètement changer le sens des mots.
MerlinMaître des clés“en bas au champ formulaire pourcentage, le champ ne prend pas en charge les chiffres à virgule”
C’est parce-que le champ Pourcentage utilise un format “JavaScript” qui ne fonctionne pas, c’est la première chose que dit la Console quand on ouvre le document :
TypeError: event.target.value.toFixed is not a function
1:Field:FormatIl faudrait que ce champ utilise un format Nombre “normal”.
MerlinMaître des clés“A-t-il déjà fonctionné correctement avec des version précédentes ?”
Oui.
Ça faisait bien ramer l’ordinateur (iBook G4) mais ça fonctionnait.
MerlinMaître des clésBonjour
À la place de plusieurs boutons de couleur, j’aurais plutôt utilisé une case à cocher avec un style de case “rond” et je lui aurait fait changer de couleur en même temps que la gommette.
MerlinMaître des clésC’est la pièce jointe envoyée ci-dessus : https://www.abracadabrapdf.net/wp-content/uploads/2023/04/horloge-Sowedoo.pdf
MerlinMaître des clésBonjour
Chaque item de la liste déroulante doit être associé à une “valeur d’exportation”.
Le script est placé en “script de calcul” dans le champ “Texte1”.
Exemple ci-joint.
Attachments:
You must be logged in to view attached files.MerlinMaître des clésMerci pour le partage.
Ci-joint le document corrigé de toutes ses fautes de français (je n’ai pas touché aux scripts).
😎
Attachments:
You must be logged in to view attached files.MerlinMaître des clésJ’ai retrouvé l’usine à gaz, c’est Michael et Alex qui avaient fait ça.
Mais aujourd’hui ça ne semble plus très bien fonctionner, il y a 6 aiguilles !
Attachments:
You must be logged in to view attached files.MerlinMaître des clésMerlinMaître des clés“nettoyage des case remplie sauf le numéro de facture”
En fait c’est très simple.
Réinitialiser un champ ne signifie pas “supprimer la valeur qu’il contient”, ça signifie “revenir à la valeur par défaut”.
Donc au lieu d’attribuer au champ “numéro” une simple valeur il faut lui attribuer une nouvelle valeur par défaut. Ainsi on peut réinitialiser tous les champs sans craindre qu’il perde sa valeur :
this.getField("numero").defaultValue += 1;
app.execMenuItem("SaveAs");
MerlinMaître des clésDans la logique d’utilisation d’une matrice celle-ci doit être enregistrée-sous un autre nom dès son ouverture pour être utilisée directement en tant que nouveau document. Ce qui évite aussi d’avoir à se poser la question de comment réinitialiser tous les champs sauf un.
Remplir la matrice, travailler dessus, et ensuite enregistrer-sous est source d’erreurs humaines et de corruption de fichier.
Il n’est pas possible d’utiliser la commande “Enregistrer” depuis un script de document, sécurité oblige. Voir : https://www.abracadabrapdf.net/ressources-et-tutos/js-et-formulaires-ressources/les-differents-niveaux-dutilisation-des-scripts-javascript/
Donc après avoir enregistré le nouveau document sous un autre nom, tu as juste à enregistrer la matrice pour qu’elle conserve son nouveau numéro.
MerlinMaître des clés19 ans après je n’ai pas retrouvé ce fichier mais pas de regrets : c’était soit une usine à gaz qui fonctionnait en détournant les outils de commentaires et donc pas très efficace, soit c’était en fait un fichier SWF incorporé dans le PDF mais ça ne fonctionne plus depuis l’arrêt de Flash Player.
Attachments:
You must be logged in to view attached files.MerlinMaître des clésJ’ai ajouté ces deux lignes de script en script de document :
this.getField("numero").value += 1;
app.execMenuItem("SaveAs");
Attachments:
You must be logged in to view attached files.MerlinMaître des clésJe crois qu’il serait plus logique/pratique d’utiliser une matrice.
À l’ouverture de la matrice le numéro s’incrémente, la matrice s’enregistre pour conserver le nouveau numéro et déclenche un enregistrer-sous pour générer la nouvelle facture.
Et bien entendu, juste avant l’enregistrer-sous de la nouvelle facture on supprime le script qui incrémente son numéro à l’ouverture.
Qu’en penses tu ?
MerlinMaître des clés👍
MerlinMaître des clés“Oui j´aimerais aussi incrémenté un numéro de facture a chaque fois que j´établie une nouvelle facture”
Même réponse que ci-dessus : Quel évènement devrait déclencher le nouveau numéro ?
MerlinMaître des clés“désolé mais je n’ai pas mis en place cette solution n’ayant pas trouvé d’aide ….”
On attend toujours le document.
MerlinMaître des clésDans ce cas on remplace la case à cocher par un champ de texte au format nombre (chiffre) et on modifie un peu le calcul final en utilisant la notation simplifiée.
Ci-joint.
Attachments:
You must be logged in to view attached files.MerlinMaître des clésBonjour.
Pour être exclusives (un seul choix possible) les cases à cocher d’un groupe doivent avoir le même nom et une valeur d’exportation différente.
Donc il faut ajouter un groupe de 3 cases à cocher et un groupe de 1 seule, le total étant fait par un simple calcul dans un champ texte.
Ci-joint.
Attachments:
You must be logged in to view attached files.MerlinMaître des clés👍
MerlinMaître des clésJe ne connais pas non plus de fonction JavaScript qui permettrait de cliquer OK dans la fenêtre d’alerte.
Si les champs avec Format ont toujours le même nom (Date, CodePostal, etc.) tu peux utiliser l’exportation/importation de données fictives entre plusieurs formulaires. C’est ce que je fais le plus souvent.
Ensuite tu peux demander au script de ne remplir que les champs vides.
MerlinMaître des clésBonjour
Avec JavaScript on ne peut pas détecter si un champ à un format ni lequel. Tout ce qu’on faire c’est ajouter un format en écrasant le précédent.
Pour ignorer les erreurs il faut utiliser “continue” mais le truc c’est qu’il faut dire quel type d’erreur on veut ignorer et pour le coup je ne sais pas.
Que dit la Console quand il y a ces erreurs ?
En attendant, si tu veux tout savoir sur “continue” :
https://www.w3schools.com/js/js_break.aspMerlinMaître des clésOups, dans mon script il manque effectivement la définition de “f”.
1000 excuses.
MerlinMaître des clésBonjour Jean-Claude
Essaie ça dans la console :
for (var i=0; i < f.numItems; i++) console.println(f.getItemAt(i,true) + ": " + f.getItemAt(i,false));
MerlinMaître des clésBonjour
C’est un petit bug d’Acrobat, si ça vous intéresse la solution se trouve sur le site d’Adobe :
https://community.adobe.com/t5/acrobat-discussions/acrobat-keeps-asking-to-sign-in/td-p/11525698
(Il y a un bouton “Traduire” sous chaque message)
MerlinMaître des clés👍
MerlinMaître des clés“Après une autre question, avec du jS peut-être on peut forcer la lecture auto ou en boucle etc…”
A priori oui mais je n’ai pas vérifié, tout est là :
MerlinMaître des clésMerlinMaître des clésBonjour
Tout est là : https://helpx.adobe.com/fr/acrobat/using/rich-media.html
Sinon il est également possible de placer la vidéo en pièce jointe dans le PDF pour qu’elle soit lue par le lecteur multimédia par défaut (au lieu d’Acrobat). Mais dans ce cas il ne peut pas y avoir de lancement automatique.
MerlinMaître des clés“En reprenant ce poste je voulais dans la case TexteSomme que le nombre en lettres soit remplie de étoile avant et après. comment faire ?”
Ajoute ceci en script de Format dans le champ concerné :
event.value = "************ " + event.value + " ************";
MerlinMaître des clésJe crois que tu as raison mais je n’ai pas tort : tu parles de ton script qui intègre l’enregistrement du nouveau fichier, alors que je parle d’une Action qui utilise la fonction Enregistrer d’Acrobat juste avant cette ligne de script.
Du coup ça fait une différence car le document actif n’est pas le même.
MerlinMaître des clés“« this » représente le fichier dont on veut extraire la première page donc this.closeDoc(true); ne fermera pas le fichier temporaire.”
Dans mon idée “this” représente le document qui vient d’être enregistré, qui est actif et donc au premier-plan à l’instant T.
Mais je n’ai pas testé.
😉
MerlinMaître des clésPS : dans l’Assistant Action il n’est pas possible de préciser si on veut que le nouveau fichier soit fermé après son enregistrement.
Je suppose que c’est automatique, mais si ce n’est pas le cas il faudra ajouter (après l’étape Enregistrement) une nouvelle étape “Exécuter un JavaScript” en utilisant ce script :
this.closeDoc(true);
J’aurais pu enregistrer une Action et te la transmettre mais comme tu utilises une version d’Acrobat Pro antérieure à la mienne ça ne fonctionnera pas.
MerlinMaître des clésOTAN pour moi (comme dirait V. Zelensky), j’ai oublié de préciser la dernière étape d’enregistrement (ci-joint).
L’option “Optimisation PDF” est facultative, avec le paramètre “Standard” ça donne de bons résultats.
Avantage : les fichiers générés sont de poids plus réduit.
Inconvénient : le temps de traitement de chaque fichier est allongé. Sur plusieurs centaines de fichiers ça peut être très pénalisant.
Connaissant les limites d’Acrobat je te conseille en tout cas de traiter les fichiers par lots de 500 fichiers maximum. Avec plus de fichiers d’un seul coup ça m’étonnerait qu’il arrive au bout, en général il mouline des heures et finit par planter.
Attachments:
You must be logged in to view attached files.MerlinMaître des clésIl est possible que la documentation d’Adobe ait changé d’adresses, voici les nouvelles :
https://opensource.adobe.com/dc-acrobat-sdk-docs/library/jsapiref/doc.html
https://opensource.adobe.com/dc-acrobat-sdk-docs/library/jsapiref/JS_API_AcroJS.html
MerlinMaître des clés” où peut-on trouver de la documentation…”
Tout est là : https://www.abracadabrapdf.net/ressources-et-tutos/js-et-formulaires-ressources/ressources-pdf-javascript/
MerlinMaître des clésUn dessin (ci-joint) vaut mieux qu’un long discours, une fois enregistrée et nommée la nouvelle Action est disponible dans la Liste d’Actions en haut du panneau de l’Assistant Actions.
Attachments:
You must be logged in to view attached files.MerlinMaître des clés“Il y a une petite coquille dans le code”
1000 excuses, je ne l’avais pas testé.
🙃
MerlinMaître des clésIl faut utiliser ce script dans la Console pour connaître le nom exact des imprimantes :
var nImp = app.printerNames.length
for ( var i = 0; i < nImp; i++)
console.println("(" + (i+1) + ") " + app.printerNames);
MerlinMaître des clésCe script fonctionne, il faut remplacer “Adobe PDF” par le nom exact de l’imprimante :
for (var z=0; z<this.numPages; z++) {
var pp = this.getPrintParams();
pp.interactive = pp.constants.interactionLevel.automatic;
pp.pageHandling = pp.constants.handling.fit;
pp.printerName = "Adobe PDF";
pp.printRange = [[z,z]];
this.print(pp);
}
MerlinMaître des clésAttention à ne pas confondre la couleur de surbrillance (bleu pale par défaut) et la couleur de champs (attributs de fond et de contour).
La couleur de surbrillance se règle dans : Préférences : Formulaires
MerlinMaître des clésBonjour
Il faudrait utiliser ce script (non testé) dans une Action :
// EXTRACTION DE PAGES ET CRÉATION D'UN NOUVEAU DOCUMENT AVEC LES PAGES EXTRAITES
// ENREGISTREMENT DU CHEMIN D'ACCÈS DU DOCUMENT ACTIF
var cheminDacces = this.path;
var cheminDacces = cheminDacces.substring(0,cheminDacces.length-4);
console.println(cheminDacces);
var docSource = this;
// Création d'un nouveau document à partir de la page extraite
var docCible = this.extractPages({nStart: 0, nEnd: 0}); // extraire page 1
// ATTENTION : cPath NE FONCTIONNE QUE DEPUIS UN SCRIPT D'APPLICATION, UNE ACTION OU LA CONSOLE
// ENREGISTREMENT DU NOUVEAU DOCUMENT en JPEG
docCible.saveAs({cPath: cheminDacces + "_extrait.jpg", cConvID: com.adobe.acrobat.jpeg, bPromptToOverwrite: true});
-
AuteurRéponses