ich möchte gerne folgendes Ergebnis erzielen: Mit einem Skript soll nachgeshen werden wo im Text ein Preis nach einem "statt" + Leerzeichen vorkommt. An dieser Stelle soll der Preis durchgestrichen werden, aber nicht mit einem Zeichenformat sondern mit einer graphicline von links unten (Grundlinie) bis rechts oben (Versalhöhe) über die ganze Breite des Preises = Fundstelle.
Die Fundstelle kann ich mit GREP so ermitteln: (?<=statt\s)\d+\.(\d+|-)
Aber wie kann ich die Linie an dieser Stelle diagonal zeichnen lasen?
Du denkst zu kompliziert. Dafür braucht es kein Skript!
Du machst dir eine Linie und vergibst ihr ein Objektformat. Dann fügst du sie an deiner Fundstellen über die Zwischenablage ein und richtest sie dann (oder schon vorher) als benutzerdefiniertes verankertes Objekt ein.
Danke Kai für deine Antwort. Aber ich denke leider nicht zu kompliziert. Der Text selbst darf nicht verändert werden. Also dürfen auch keine verankerten Objekte im Text vorkommen. (Der Text ist mit einer Datenbank verbunden und wird auch von daher aktualisiert) Ergo muss die "Durchstreichlinie" als eigenes Objekt über dem Text liegen.
Und daher wollte ich das per Skript erledigen.
Um eine Linie zeichnen zu können müsste ich jedoch die Koordinaten von meiner Fundstelle irgendwie auf die der Linie übertragen. Und genau hier fehlt mir der Ansatz.
Dann würde ich den Strich trotzdem verankert einfügen u. nachträglich alle verankerten Objekte lösen. Wenn sich später dein Layout verschiebt, kannst du alle Objekte mit Objektformat x löschen und machst die Schritte einfach noch einmal.
Also: Hast du die Mitteilung von Martin gelesen. So könnte man das machen. Es gibt im Forum auch einige Beispiele dazu. Ich bin allerdings von deinem Skripting-Wissenstand ausgegangen und fände diese teilautomatisierte Lösung für dich momentan einfacher …
Was spricht gegen das Einfügen u. nachträgliche Lösen eines Objekts?
Edit: Nein, hast du vermutlich nicht, denn Martin hat seinen guten Ansatz leider wieder gelöscht?!
Es wäre übrigens so, dass du per Skript generell unterschiedliche Neigungen in Abhängigkeit der Länge deiner Preise kriegen wirst. Das würde MIR nicht gefallen.
Gruß Kai Rübsamen
(Dieser Beitrag wurde von Kai Rübsamen am 18. Dez 2017, 14:37 geändert)
Dass ich unterschiedliche Neigungen erhalte ist erwünscht. Daher ist auch die Lösung per Objektformat nicht machbar. -> Hier müsste ich händisch nachjustieren. Das will ich aber vermeiden.
Ich werde mal das Forum durchsuchen, vielleicht werde ich ja fündig.
Hallo faxinger, ich hätte da noch einen Ansatz, der ohne eine Verankerung auskommt.
1. Wandle jede Fundstellen in eine Outline als Duplikat. Also Schleife durch die Fundstellen mit Zähler n . Innerhalb der Schleife dann:
Warum die [0] ? Weil createOutlines ein Array zurückgibt. Ich gehe hier mal von einer Länge 1 aus.
2. Zeichne im Spread der Outline (das ist der parent von outline) eine graphicLine mit den geometricBounds der Outline. Das gelingt am besten, wenn Du die Eigenschaft rulerOrigin der viewPreferences des Dokuments auf RulerOrigin.SPREAD_ORIGIN stellst.
An dieser Stelle kannst Du auch Werte für strokeWeight und strokeColor mitgeben. Vielleicht auch noch einen Wert für itemLayer, damit die graphicLine auf eine gesonderte Ebene gelangt.
3. Um von links unten nach rechts oben zu zeichnen, kannst Du den entirePath umdefinieren:
Dann kannst Du das Objekt aus 1. wieder löschen:
Da wir hier kein konkretes Beispiel sehen, ist es etwas schwierig zu entscheiden, ob mein Vorschlag taugt, um von "Grundlinie" zu "Versalhöhe" zu zeichnen. Je nach Typografie der Preise sind "Versalhöhe" und "Grundlinie" vielleicht weniger geeignet.
Bedenke auch, was passieren soll, wenn gefundener Text in Übersatz steht.
Mit horizontalOffset eines der insertionPoints eines gefundenen Texts würde ich übrigens nicht arbeiten. Das ist nicht exakt genug an der Form des Texts dran. Kann sich sogar im Text befinden, wenn mit Unterschneidung gearbeitet wurde. ***** Mit herzlichem Gruß, Uwe Laubender
In dem Fall hättest du für unterschiedlich lange Preis versch. Objektformate. Aber versuch das mal mit der Linie. Du wirst zwar etwas länger brauchen, aber auch etwas lernen ;-)
in Javascript muss auch der Backslash escaped werden:
--- Viele Grüße, Ralf --- iMac i7 (18,3) 4,2 GHz, 32 GB 10.15.7 Catalina | MacBook Pro 15" (8,2) 2,0 GHz, 16 GB, 10.13.6 High Sierra | Mac Mini (6,1) als Server 2,5 GHz, 8 GB, 10.13.6 High Sierra | CC 2021 (ID 16.3.2)
Dein Vorgehen ist gefährlich! Was machst du, wenn sich der Umbruch nachträglich verschiebt? Wie willst du die Linien wieder löschen? Ich würde zumindest noch ein Objektformat, Namen oder eigene Ebene vergeben.
Gruß Kai Rübsamen
(Dieser Beitrag wurde von Kai Rübsamen am 15. Jan 2018, 12:27 geändert)
danke für den Hinweis. Aber die Linien werden mit einem Skript gelöscht und dann neu gezeichnet.
Objektformate würden mir da nix helfen. Aber es kommen ohnehin nur solche Linien im Dokument vor und somit ist das Löschen per Skript der schnellste Weg.
In meiner zweiten Variante hatte ich einen Namen vergeben. Du könntest das Skript dahingehend ergänzen und zuerst alle Linien mit entsprechendem Namen besuchen, löschen u. dann neu zeichnen.
Hm… Noch einfacher wäre vielleicht für die Linien eine separate, eigene Ebene zu benutzen. Vor einem zweiten Skriptlauf wird einfach auf die Ebene geprüft und falls vorhanden gelöscht. ***** Mit herzlichem Gruß, Uwe Laubender
danke aber die Linien müssen auf der gleichen Ebene sein.
Aber wie gesagt da im Dokument sonst keine Linien vorkommen ist es auch kein Problem diese vorab per skript zu löschen und dann neu zeichnen zu lassen.
Das Skript funktioniert nur auf einer Seite bzw. Doppelseite.
Wie kann ich aber alle Fundstellen im Dokument mit Linien versehen?
Ich muss ja dann noch alle Seiten durchlaufen, aber mir ist nicht klar wie ich die jeweiligen x und y koordinaten des betroffenen Textrahmens auf der jeweiligen Seite mitberücksichtige.
Aktuell zeichnet ID alle Linien nur auf dem 1. Spread.
Sprich alle Fundstellen werden auf der 1. Seite gezeichnet.
Da hab ich jetzt einen Knoten im Hirn...
(Dieser Beitrag wurde von faxinger am 10. Sep 2020, 16:19 geändert)
Hallo faxinger, Du könntest die neu gezeichnete Linie am ersten insertionPoint der Fundstelle verankern und den Anker anschließend lösen. ***** Mit herzlichem Gruß, Uwe Laubender
Das Problem dabei ist wie gesagt, dass nur die erste Seite bzw. der erste Druckbogen mit den Streichlinien umgesetzt wird. Die weiteren Linien (GREP-Fundstellen) werden alle auf der 1. Seite gezeichnet.
Na, dann ermittelst Du über den ersten insertionPoint des gefundenen Textes den zugehörigen Textrahmen und dessen parentPage und baust die Linie dort.
Das dürfte in Deinem Code das hier sein:
Du solltest aber vorab noch den aktuellen Wert von parentPage prüfen. Kann ja sein, dass sich eine Fundstelle auf dem Pasteboard befindet. Dann gibt parentPage den Wert null zurück. Im Erfolgsfall aber das Seitenobjekt. ***** Mit herzlichem Gruß, Uwe Laubender