Basil.js и ExtendScript в Indesign / Как я могу оформить textFrames?
После того, как элементы svg помещены / прорисованы в Indesign, я хочу изменить стиль некоторых или всех элементов. В моем примере я оформляю текстовые рамки, пока они рисуются. Мой пример работает.
Но как я могу изменить стиль после размещения текстовых фреймов?
Я хочу использовать угол наклона (применяется к TextFrame) и RotateAngle (посмотрите в моем примере -> forLoop)
Я попробовал следующее: r.textFrames.shearAngle=20;
а также doc.textFrames.add({shearAngle:20});
... но оба не работают.
#includepath "~/Documents/;%USERPROFILE%Documents";
#include "basiljs/bundle/basil.js";
// this script shows how to load data into
// basil for further usage.
// The document you are working with needs to be saved at least once.
// The data needs to be in a folder next to that document
// The folder needs to be named "data"
// take a look into the output of the JS console of the ESTK
function draw() {
var doc = b.doc();
b.clear(doc); // clear the doc
b.units(b.MM); // use MM
var yTextFrame = 195;
// get the scripts name// get its containing folder// get the name of the script without the extension // add the .indd to the extension
var fname = File($.fileName).parent.fsName + '/' + ($.fileName.split('/')[$.fileName.split('/').length - 1]).split('.')[0] + '.indd';
// and save it
doc.save(fname, false, 'basil', true); //save the file next to the script
// code goes here -----------
var filecontent = b.loadString("data.json"); // load the text file
b.println(filecontent.constructor.name); // take a look at what kind of content we have
var json = b.JSON.decode(filecontent); // transform it to JSON
b.println(json.constructor.name); // take a look again what json is
b.println(json.description); // print something from the file
// loop all the entries
for (var i = 0; i < 5; i++) {
b.println(json.laundry_care_instructions[i].instruction); // take a look at the entry
b.println(json.laundry_care_instructions[i].instruction.length); // how many characters does the entry have
var r =b.text(json.laundry_care_instructions[i].instruction, 10 + 7 * i, yTextFrame, b.width - 20, 7).properties={rotationAngle:90, shearAngle:20};// create a text box with the entry // // The skewing angle applied to the TextFrame
}
// end of your code ---------
}
b.go();
1 ответ
Вы почти получили это. В вашем коде переменная r
это уже объект textFrame.
Так и должно быть:
r.shearAngle = 20;
Увидимся завтра в классе;-)
Edit1:
Как сказано в комментариях. Код
var r = b.text("txt",x,y,width, height).properties = {something:10};
возвращает properties
объект. Не текстовый фрейм. Удалить .properties
часть и Бенедиктс и мой путь должны работать.
Edit2:
Бенедиктс кстати не работает. Я получаю следующую ошибку.
Error: Object does not support the property or method 'shearAngle'
@Benedikt: shearAngle не является текстовым свойством. Это для pageItems, таких как TextFrame, Rectangle, Oval и так далее. Есть ли способ в Basil.js установить свойства, подобные этим? А как у него с вложенными свойствами? Я задам новый вопрос для этого.