Adobe 0046100128056 Scripting Guide - Page 73

Replacing text, Inserting special characters, Understanding Text Objects

Page 73 highlights

CHAPTER 6: Text and Type Entering and Importing Text 73 var myDocument = app.activeDocument; //Set the measurement units to points. myDocument.viewPreferences.horizontalMeasurementUnits = MeasurementUnits.points; myDocument.viewPreferences.verticalMeasurementUnits = MeasurementUnits.points; //Create a text frame on the current page. var myTextFrame = app.activeWindow.activePage.textFrames.add(); //Set the bounds of the text frame. myTextFrame.geometricBounds = [72, 72, 96, 288]; //Fill the text frame with placeholder text. myTextFrame.contents = TextFrameContents.placeholderText; //Now add text beyond the end of the text frame. myTextFrame.insertionPoints.item(-1).contents = "\rThis is some overset text"; alert("The last paragraph in this alert should be \"This is some overset text\". Is it?\r" + myTextFrame.contents); alert("The last paragraph in this alert should be \"This is some overset text\". Is it?\r" + myTextFrame.parentStory.contents); For more on understanding the relationships between text objects in an InDesign document, see "Understanding Text Objects" on page 81. Replacing text The following script replaces a word with a phrase by changing the contents of the appropriate object (for the complete script, see ReplaceWord): var myDocument = app.activeDocument; //Set the measurement units to points. myDocument.viewPreferences.horizontalMeasurementUnits = MeasurementUnits.points; myDocument.viewPreferences.verticalMeasurementUnits = MeasurementUnits.points; //Create a text frame on the current page. var myTextFrame = app.activeWindow.activePage.textFrames.add({geometricBounds:[72, 72, 288, 288], contents:"This is some example text."}); //Replace the third word "some" with the phrase //"a little bit of". myTextFrame.parentStory.words.item(2).contents = "a little bit of"; The following script replaces the text in a paragraph (for the complete script, see ReplaceText): //Replace the text in the second paragraph without replacing //the return character at the end of the paragraph. To do this, //we'll use the ItemByRange method. var myStartCharacter = myTextFrame.parentStory.paragraphs.item(1).characters.item(0); var myEndCharacter = myTextFrame.parentStory.paragraphs.item(1).characters.item(-2); myTextFrame.texts.itemByRange(myStartCharacter, myEndCharacter).contents = "This text replaces the text in paragraph 2." In the preceding script above, we excluded the return character because deleting the return might change the paragraph style applied to the paragraph. To do this, we used ItemByRange method, and we supplied two characters-the starting and ending characters of the paragraph-as parameters. Inserting special characters Because the ExtendScript Toolkit supports Unicode, you can simply enter Unicode characters in text strings that you send to InDesign. Alternately, you can use the JavaScript method of explicitly entering Unicode characters by their glyph ID number: \unnnn (where nnnn is the Unicode code for the character). The following script shows several ways to enter special characters. (We omitted the myGetBounds

  • 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
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209

C
HAPTER
6: Text and Type
Entering and Importing Text
73
var myDocument = app.activeDocument;
//Set the measurement units to points.
myDocument.viewPreferences.horizontalMeasurementUnits = MeasurementUnits.points;
myDocument.viewPreferences.verticalMeasurementUnits = MeasurementUnits.points;
//Create a text frame on the current page.
var myTextFrame = app.activeWindow.activePage.textFrames.add();
//Set the bounds of the text frame.
myTextFrame.geometricBounds = [72, 72, 96, 288];
//Fill the text frame with placeholder text.
myTextFrame.contents = TextFrameContents.placeholderText;
//Now add text beyond the end of the text frame.
myTextFrame.insertionPoints.item(-1).contents = "\rThis is some overset text";
alert("The last paragraph in this alert should be \"This is some overset text\". Is
it?\r" + myTextFrame.contents);
alert("The last paragraph in this alert should be \"This is some overset text\". Is
it?\r" + myTextFrame.parentStory.contents);
For more on understanding the relationships between text objects in an InDesign document, see
“Understanding Text Objects” on page 81
.
Replacing text
The following script replaces a word with a phrase by changing the contents of the appropriate object (for
the complete script, see ReplaceWord):
var myDocument = app.activeDocument;
//Set the measurement units to points.
myDocument.viewPreferences.horizontalMeasurementUnits = MeasurementUnits.points;
myDocument.viewPreferences.verticalMeasurementUnits = MeasurementUnits.points;
//Create a text frame on the current page.
var myTextFrame = app.activeWindow.activePage.textFrames.add({geometricBounds:[72, 72,
288, 288], contents:"This is some example text."});
//Replace the third word "some" with the phrase
//"a little bit of".
myTextFrame.parentStory.words.item(2).contents = "a little bit of";
The following script replaces the text in a paragraph (for the complete script, see ReplaceText):
//Replace the text in the second paragraph without replacing
//the return character at the end of the paragraph. To do this,
//we'll use the ItemByRange method.
var myStartCharacter = myTextFrame.parentStory.paragraphs.item(1).characters.item(0);
var myEndCharacter = myTextFrame.parentStory.paragraphs.item(1).characters.item(-2);
myTextFrame.texts.itemByRange(myStartCharacter, myEndCharacter).contents = "This text
replaces the text in paragraph 2."
In the preceding script above, we excluded the return character because deleting the return might change
the paragraph style applied to the paragraph. To do this, we used
ItemByRange
method, and we supplied
two characters—the starting and ending characters of the paragraph—as parameters.
Inserting special characters
Because the ExtendScript Toolkit supports Unicode, you can simply enter Unicode characters in text
strings that you send to InDesign. Alternately, you can use the JavaScript method of explicitly entering
Unicode characters by their glyph ID number:
\u
nnnn
(where
nnnn
is the Unicode code for the character).
The following script shows several ways to enter special characters. (We omitted the
myGetBounds