[GastForen Programme Print/Bildbearbeitung Adobe InDesign Skriptwerkstatt BerechnungMitDialogUndRundung.jsx erweitern

  • Suche
  • Hilfe
  • Lesezeichen
  • Benutzerliste
Print/Bildbearbeitung - Photos, Layout, Design
Themen
Beiträge
Moderatoren
Letzter Beitrag

BerechnungMitDialogUndRundung.jsx erweitern

pitware2005
Beiträge gesamt: 39

9. Okt 2013, 08:20
Beitrag # 1 von 4
Bewertung:
(915 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo zusammen,

ich wollte das Berechnungsskript etwas erweitern. Leider will er nicht so wie ich möchte deshalb meine Frage an Euch ob mir jemand helfen bzw. einen Denkanstoß geben kann.

Hier sind meine Modifikationen:

Code
// Berechnungsfunktion      
function theCalculation(theData, theRound){
var theOldNumber = theData.split(",").join(".") // Komma wird ggf. durch Punkt ersetzt

if ((theOldNumber) * myFactor) > 10
var theNewString = myRound(parseFloat(theOldNumber) * myFactor, theRound) + ",00" ; // Berechnung der neuen Zahl
else if ((theOldNumber) * myFactor) < 10
var theNewString = myRound(parseFloat(theOldNumber) * 10, theRound) + ",00" ; // Berechnung der neuen Zahl

return theNewString;
}


Diese habe ich in den unteren Gesamtcode eingefügt, leider will er mir diese if/else Unterscheidung für die Variable "theNewString" nicht machen.

Code
var myDoc = app.documents[0];      
var myObj = (app.selection.length > 0 &&
(
(
app.selection[0].hasOwnProperty('baseline') &&
app.selection[0].constructor.name != 'InsertionPoint'
) ||
app.selection[0].constructor.name == 'TextFrame' ||
app.selection[0].constructor.name == 'Table' ||
app.selection[0].constructor.name == 'Cell'
)
)
? app.selection[0]
: app.activeDocument;
var theStyles = myDoc.characterStyles.everyItem().name; // Zeichenformate in Array
theStyles.shift(); // Abschneiden von Zeichenformat [Keine]

var theData = myDisplayDialog(); // Funktionsaufruf
var myFactor = theData.factor;
if (myFactor != undefined)
{
app.findGrepPreferences = app.changeGrepPreferences = null;
app.findGrepPreferences.appliedCharacterStyle = theData.style;
app.findGrepPreferences.findWhat = '\\d+[\\.,]?\\d*';
var myNumbers = myObj.findGrep();
app.findGrepPreferences = app.changeGrepPreferences = null;

for (oneNum = myNumbers.length-1; oneNum >= 0; oneNum--)
{
// Funktionsaufruf zu Berechnung und
// Zuweisung des neuen Inhats
if (isNaN(myNumbers[oneNum].contents.split(",").join(".") )){}
else
{
myNumbers[oneNum].contents = theCalculation(myNumbers[oneNum].contents, theData.round)
}
}
}

// Dialog
function myDisplayDialog()
{
var myFieldWidth = 80;

var myDialog = app.dialogs.add({name:"Berechnung"});
with(myDialog.dialogColumns.add())
{
with(dialogRows.add())
{
with(dialogColumns.add())
{
staticTexts.add({staticLabel:"Faktor:", minWidth:myFieldWidth});
}
with(dialogColumns.add())
{
var myFacTextEditbox = textEditboxes.add({editContents:"1,19", minWidth:140});
}
}
with(dialogRows.add())
{
with(dialogColumns.add())
{
staticTexts.add({staticLabel:"Rundung:", minWidth:myFieldWidth});
}
with(dialogColumns.add())
{
var myRoundTextEditbox = textEditboxes.add({editContents:"0,01", minWidth:140});
}
}
with(dialogRows.add())
{
with(dialogColumns.add())
{
staticTexts.add({staticLabel:"Zeichenformat:", minWidth:myFieldWidth});
}
with(dialogColumns.add())
{
var myStylesDropDown = dropdowns.add({stringList:theStyles, selectedIndex:0, minWidth:140});
}
}
}
var myResult = myDialog.show();
if(myResult == true)
{
var aFactor = myFacTextEditbox.editContents.split(",").join(".")*1;
var aStyle = theStyles[myStylesDropDown.selectedIndex];
var myRoundNum = Number(myRoundTextEditbox.editContents.split(",").join("."))
var aRound = (isNaN(myRoundNum) || myRoundNum == 0)
? 1
: 1/myRoundNum;
//Remove the dialog box from memory.
myDialog.destroy();
}
else
{
myDialog.destroy();
}
return {factor:aFactor, style:aStyle, round:aRound};
}

// Berechnungsfunktion
function theCalculation(theData, theRound){
var theOldNumber = theData.split(",").join(".") // Komma wird ggf. durch Punkt ersetzt
var theNewString = myRound(parseFloat(theOldNumber) * myFactor, theRound) ; // Berechnung der neuen Zahl
return theNewString;
}

function myRound(aNum, aDec)
{
var myResult = Math.round(aNum * aDec)/aDec;
if (aDec == 1)
return String(myResult);
if (myResult - Math.floor(myResult) == 0)
myResult += '.';
var myParts = String(myResult).split('.');
while (myParts[1].length < String(aDec).length-1)
{
myParts[1] += '0';
}
return myParts.join(',');


Ich danke Euch wie immer im voraus für Eure Unterstützung.

Lg
Peter
X

BerechnungMitDialogUndRundung.jsx erweitern

WernerPerplies
Beiträge gesamt: 2762

9. Okt 2013, 10:10
Beitrag # 2 von 4
Beitrag ID: #518246
Bewertung:
(890 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo Peter,

Du gehst mit Deinen Informationen recht sparsam um:

Zitat Leider will er nicht so

Was will nicht?, Bekommst Du eine Fehlermeldung, wenn ja, welche.

Bist Du das Skript im Einzelschrittverfahren durchgegangen?

Meine Empfehlung:

Teste zuerst nur die Funktion theCalculation(theData, theRound), z. B. so;

Code
main() 
function main()
{
alert(theCalculation(Wert für theData, Wert für theRound))
// Berechnungsfunktion
function theCalculation(theData, theRound){
var theOldNumber = theData.split(",").join(".") // Komma wird ggf. durch Punkt ersetzt

if ((theOldNumber) * myFactor) > 10
var theNewString = myRound(parseFloat(theOldNumber) * myFactor, theRound) + ",00" ; // Berechnung der neuen Zahl
else if ((theOldNumber) * myFactor) < 10
var theNewString = myRound(parseFloat(theOldNumber) * 10, theRound) + ",00" ; // Berechnung der neuen Zahl

return theNewString;
}
}


Schau Dir dann die Fehlermeldung an und korrigiere.
Wenn die Funktion dann noch nicht wie erwartet funktioniert, prüfe jeden Schritt einzeln: -> ESTK, Taste F11

Prüfe auch die Klammersetzung in der Bedingung.

Ich hoffe, das reicht als erster Denkanstoß.


als Antwort auf: [#518242]

BerechnungMitDialogUndRundung.jsx erweitern

pitware2005
Beiträge gesamt: 39

9. Okt 2013, 10:48
Beitrag # 3 von 4
Beitrag ID: #518247
Bewertung:
(880 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo Werner,

sorry hab den Anhang vergessen. Die Fehlermeldung ist nun im Anhang.

Nein ich bin es noch nicht in einzelnen Schritten durchgegangen weil ich eigentlich dachte es wäre ja keine große Änderung sondern einfach nur eine kleine if/else Erweiterung.

Das mit dem jeden Schritt einzeln werde ich sobald ich Zeit habe mal durchlaufen lassen. Aber vielleicht ist es ja mit der Fehlermeldung einfacher zu erkennen.

Lg
Peter


als Antwort auf: [#518246]
Anhang:
Fehler.jpg (81.4 KB)

BerechnungMitDialogUndRundung.jsx erweitern

WernerPerplies
Beiträge gesamt: 2762

9. Okt 2013, 11:13
Beitrag # 4 von 4
Beitrag ID: #518250
Bewertung:
(865 mal gelesen)
URL zum Beitrag
Beitrag als Lesezeichen
Hallo Peter,

die Anwort steht in meinem letzten Beitrag.
Noch einmal:
Teste Deine Funktion separat und prüfe die Klammersetzung.

Die Bedingung muss in Klammern stehen.


als Antwort auf: [#518247]
X

Aktuell

PDF / Print
enfocus_300

Veranstaltungskalender

Hier können Sie Ihre Anlässe eintragen, welche einen Zusammenhang mit den Angeboten von HilfDirSelbst.ch wie z.B. Adobe InDesign, Photoshop, Illustrator, PDF, Pitstop, Affinity, Marketing, SEO, Büro- und Rechtsthemen etc. haben. Die Einträge werden moderiert freigeschaltet. Dies wird werktags üblicherweise innert 24 Stunden erfolgen.

pdf-icon Hier eine kleine Anleitung hinsichtlich Bedeutung der auszufüllenden Formularfelder.

Veranstaltungen
14.05.2024

Online
Dienstag, 14. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Prozessoptimierung ist ein Teamsport! Keine Software und keine Maschine allein kann Ihnen helfen, die Effizienzpotenziale Ihres Betriebes maximal auszuschöpfen. Von der Auftragsannahme über die Vorstufe und den Druck bis hin zur Weiterverarbeitung – alles muss optimal ineinandergreifen. Apropos Weiterverarbeitung – in vielen Druckbetrieben fristet sie in Sachen Prozessoptimierung immer noch ein Schattendasein. Dabei liegen hier mittlerweile die größten Einsparpotenziale! In einem Webinar von Horizon und Impressed erfahren Sie, wie Sie diese Einsparungen realisieren können. Horizon, bekannt für innovative Lösungen in der Druckweiterverarbeitung, bietet mit iCE LiNK eine Workflowlösung für die Weiterverarbeitung. iCE LiNK überwacht, visualisiert und analysiert Produktionsabläufe und unterstützt bei der Wartung – damit immer alles reibungslos läuft. Den gleichen Anspruch hat der von Impressed entwickelte Impressed Workflow Server – er ist die smarte PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt. Im Webinar zeigen Ihnen die Experten von Horizon und Impressed, wie beide Lösungen im Team die Effizienz und Produktivität Ihres Betriebes steigern können. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Ja

Organisator: Impressed / Horizon

https://www.impressed.de/schulung.php?c=sDetail&sid=327

Einsparpotenziale in der Weiterverarbeitung
Veranstaltungen
16.05.2024

Online
Donnerstag, 16. Mai 2024, 10.00 - 10.30 Uhr

Webinar

Komplizierte, kleinteilige Aufträge; alles sehr speziell; seit Jahren bewährte Prozesse – da können wir nichts standardisieren und automatisieren! Das sagen viele Großformatdrucker – aber stimmt das wirklich, ist dem tatsächlich so? Günther Business Solutions und Impressed treten in einem Webinar den Gegenbeweis an. Experten beider Unternehmen zeigen, wie Großformatdrucker vom Einsatz zweier bewährter Lösungen profitieren können: • von advanter print+sign von Günther Business Solutions, dem ERP-System für den Großformatdruck, dass alle Phasen der Wertschöpfung im Large Format Printing abdeckt • von Impressed Workflow Server, der smarten PDF-Workflow-Lösung für Druckereien, die Datenmanagement, Preflight und Produktionssteuerung übernimmt Über die Kombination beider Lösungen können Großformatdrucker ihre Prozesse mit modernen Workflows Schritt für Schritt automatisieren – und so zügig deutliche Zeit- und Kosteneinsparungen realisieren. Das Webinar sollten Sie sich nicht entgehen lassen – damit Sie keine Effizienzpotenziale mehr liegen lassen. Melden Sie sich am besten gleich an, wir freuen uns auf Sie! PS: Melden Sie sich in jedem Fall an – sollten Sie zum Termin verhindert sein, erhalten Sie die Aufzeichnung.

kostenlos

Nein

Organisator: Impressed / Günther Business Solutions

https://www.impressed.de/schulung.php?c=sDetail&sid=326

Und es geht doch: Automatisierung im Großformatdruck!