FF_Include

Beispielscript für den Include-Mechanismus von FixFoto


Mit Hilfe der FF_INCLUDE Anweisung lassen sich Scripte auf mehrere Dateien aufteile. Auch lassen sich damit Funktionen, die
man in mehreren Scripten benötigt, auslagern.

Um einfacher mit einem externen Editor arbeiten zu können, teile ich meine Script oft in zwei Teile. Der eine wird in FF Im Scripteditor geöffnet.
Der zweite Teil wird mit dem externen Editor bearbeitet und von FF dann per FF_INCLUDE Befehl dazu geladen.

Aufpassen muss man nur bei der Weitergabe des Scriptes. Da es nicht mehr nur eine Datei ist, muss eine ZIP Datei erstellt werden,
die dann in FixFoto importiert/installiert werden kann.

Hier das Hauptscript, das in FF eingebunden wird und auch die Dialogdefinitionen enthält.

Fix35Kb.js
  1. //FFSubmenu=Canon
  2. //FFName=Fix35Kb_include
  3. //FFInclude=Fix35Kb_main.js
  4. //
  5. // Autor: Heinz Höfling
  6. //
  7.  
  8. function makemaindialog()
  9. {
  10. //** Start Dialog Canon KB35.. **
  11. FF_AddDialog("Canon KB35..",185,113);
  12. FF_AddControl("Canon KB35..","prog","PROGRESS",83,69,97,11);
  13. FF_AddControl("Canon KB35..","vorschau","IMAGE",1,1,79,79);
  14. FF_AddControl("Canon KB35..","aktfile","SLEDIT",2,89,178,10);
  15. FF_SetControlStyle("Canon KB35..","aktfile",2048);
  16. FF_AddControl("Canon KB35.."," Abbruch mit ESC-Taste ","STATIC",98,30,62,22);
  17. FF_SetControlStyle("Canon KB35.."," Abbruch mit ESC-Taste ",4096);
  18. FF_AddControl("Canon KB35..","Aktuelle Datei:","STATIC",4,81,41,7);
  19. FF_AddControl("Canon KB35..","© 2009 Heinz Höfling V:1.5 ","STATIC",0,101,70,7);
  20. FF_AddControl("Canon KB35..","(Hierzu eventuell vorher Fixfoto","STATIC",91,54,81,7);
  21. FF_AddControl("Canon KB35..","über die Taskleiste aktivieren)","STATIC",94,60,86,6);
  22. FF_AddControl("Canon KB35..","Start","BUTTON",125,101,53,10);
  23. FF_AddControl("Canon KB35..","In den selectierten Bildern wird die","STATIC",87,2,96,11);
  24. FF_AddControl("Canon KB35..","35mm Brennweite nachgetragen","STATIC",86,12,97,11);
  25. //** End Dialog Canon KB35.. **
  26. return "Canon KB35..";
  27. }
  28.  
  29. if( FF_GetImageCount() > 0 )
  30. Main();
  31. else FF_MessageBox("Keine Bilder selektiert.",1);

Und hier das Include-Script, das die eigentliche Arbeit erledigt.

Fix35Kb_main.js
  1. //----------------------------
  2. // Die eigendliche Bearbeitung ist hier
  3. //----------------------------
  4.  
  5. function BearbeiteEinBild(cImageName)
  6. {
  7. var result=false;
  8. if( FF_LoadExif(cImageName) && FF_HasExif() )
  9. {
  10. if ( (FF_GetExifTag("Model") == "Canon EOS 400D DIGITAL")
  11. && (FF_GetExifTag("FocalLengthIn35mmFilm") == "" )
  12. )
  13. {
  14. FF_SetExifTag("FocalLengthIn35mmFilm", Math.round((1.61 * FF_GetExifTagAdvanced("FocalLength") ),0) );
  15. FF_SaveExif(cImageName);
  16. result=true;
  17. }
  18. }
  19. return result;
  20. }
  21.  
  22. //======================================================================================
  23.  
  24. function Shorten(s, maxlen)
  25. {
  26. var r = new String(s);
  27. if( r.length> maxlen )
  28. r = r.substring(0,5) + "..." + r.substring( r.length-maxlen , r.length);
  29. return r;
  30. }
  31.  
  32. //======================================================================================
  33. // Main
  34. //======================================================================================
  35. function Main()
  36. {
  37. var dlg = makemaindialog();
  38. var nCurrent;
  39. var cImageName="";
  40. var NumImages = FF_GetImageCount();
  41. var doneImmages=0; // bis zum evtl. abbruch
  42. var aborted=false;
  43. var r;
  44.  
  45. FF_SetProgressText(0, NumImages,"");
  46. FF_SetControl(dlg,"aktfile","");
  47. try
  48. {
  49. FF_OpenDialog(dlg);
  50. for(r=""; ; )
  51. {
  52. r=FF_ShowDialog(dlg);
  53. if (r=="CANCEL") break;
  54. if (r=="Start") break;
  55. }
  56. if (r=="Start")
  57. {
  58. for ( nCurrent = 0 ; nCurrent < NumImages ; nCurrent++ )
  59. {
  60. var key=FF_CheckKey();
  61. if (key==27)
  62. {
  63. if (FF_MessageBox("Script abbrechen?",4)==6)
  64. {
  65. aborted=true;
  66. break;
  67. }
  68. }
  69. cImageName = FF_getImageName(nCurrent);
  70. FF_SetProgressText(nCurrent, NumImages,cImageName);
  71. FF_SetControl(dlg,"prog",(100/NumImages*(nCurrent+1)));
  72. var msg = "" + (nCurrent+1)+" von "+NumImages + " " + Shorten(cImageName,40);
  73. FF_SetControl(dlg,"aktfile",msg);
  74. FF_LoadThumb(cImageName);
  75. FF_SetControl(dlg,"vorschau",0);
  76. FF_RefreshDialog(dlg);
  77. // Aktion.....
  78. if( BearbeiteEinBild(cImageName) )
  79. doneImmages++;
  80. } // for
  81. FF_RefreshDialog(dlg);
  82. } // if
  83. } // try
  84. catch(e)
  85. {
  86. var msg="Script-Fehler:\r\n";
  87. msg = msg + e + "\r\n";
  88. msg = msg + "Fehler Nr.: 0x" + (e.number & 0x1FFFFFFF).toString(16).toUpperCase() +"\r\n";
  89. msg = msg + e.description+"\r\n\r\n";
  90. msg=msg+"Aktuelle Datei:\r\n"+cImageName;
  91. FF_Messagebox(msg,16);
  92. }
  93. finally
  94. {
  95. FF_CloseDialog(dlg);
  96. }
  97.  
  98. if( r=="Start")
  99. {
  100. if (aborted)
  101. msg="Abbruch"
  102. else msg="Fertig";
  103. FF_MessageBox("Selektierte Bilder: "+NumImages+"\r\n"+
  104. "davon bearbeitet : "+doneImmages+"\r\n"+msg,64);
  105. }
  106. }


Zur Funktion des Scriptes:
Das Script korrigiert in Bildern der Canon EOS400D die KB-äquivalente Brennweite, in dem es den Cropfaktor 1.61 einrechnet. Bei mir macht das zwar schon das Karten-Einlesescript aber für den Fall, das ich die Bilder doch mal per Explorer auf den Rechner kopiere, kann ich mit diesem Script den Wert nachtragen lassen.

FF_CallScript und FF_Include

Wenn man ein Script aus einem anderen mittels FF_CallScript aufruft, wird offensichtlich FF_Include nicht ausgeführt. D.h. die im Include definierten Funktionen und Werte sind dann im aufgerufenen Script nicht verfügbar. Workaround: Falls ein Script per FF_CallScript aufgerufen wird, den Include manuell machen. Um die beiden Fälle (Aufruf aus UI und FF_CallScript) unterscheiden zu können, kann man sich z.B. im letzteren Fall einen zusätzlichen Parameter mit übergeben:

  1. FF_SetParam("DO_INCLUDE");
  2. FF_CallScript("ScriptName");

Den Parameter kann man dann im Script überprüfen und bei Bedarf per eval() den Include manuell machen:

  1. if (FF_GetParam() == "DO_INCLUDE") {
  2. // FFInclude not executed - having been called from elsewhere...
  3. eval(new ActiveXObject("Scripting.FileSystemObject").OpenTextFile("Include_Script_Path_And_Name",1,false).ReadAll());
  4. }