Illustrator CS4/CS5編 複数のアートボードに画像を連続配置(3)

アートボードネタは今回で最後です。最初のスクリプトは前回同様、選択したフォルダ内にあるJPEG画像を配置します。配置する際に、アートボードの中央に画像を移動させます。配置してセンタリングする、ということです。また、JPEG画像ではなくPNG画像にしたい場合には「var fileList = folderObj.getFiles("*.jpg");」を「var fileList = folderObj.getFiles("*.png");」のように拡張子を変更してください。


(function(){
var abNum = 100; // 100ページ
var pageW = 595.28; // A4サイズ横幅
var pageH = 841.89; // A4サイズ縦幅
var docObj = app.documents.add(
DocumentColorSpace.RGB,
pageW, // A4サイズ
pageH,
abNum,
DocumentArtboardLayout.GridByRow, // 左から右、上から下
0, // アートボード間の余白
10 // アートボードサイズの平方根。Math.SQRT(abNum)
);
var folderObj = Folder.selectDialog("配置するJPEG画像があるフォルダを選択してください");
var fileList = folderObj.getFiles("*.jpg");
var num = fileList.length;
if (num > 100) num = 100; // 100枚以上は配置しない
var X = 0;
var Y = pageH * 10;
for(var i=0; i<num; i++){
setImage(fileList[i], X, Y);
X = X + pageW;
if (X > pageW*9) { // 10*10なので10枚を超えたら下のアートボードへ
X = 0;
Y = Y - pageH;
}
}
// 指定した位置に画像を配置
function setImage(fileObj, x, y){
var myImage = app.activeDocument.placedItems.add();
myImage.file = fileObj;
myImage.left = x;
myImage.top = y;
if (myImage.width > pageW){ // ページの横幅よりはみ出している場合
var d = pageW / myImage.width;
myImage.width = myImage.width * d;
myImage.height = myImage.height * d;
}
if (myImage.height > pageH){ // ページの縦幅よりはみ出している場合
var d = pageH / myImage.height;
myImage.width = myImage.width * d;
myImage.height = myImage.height * d;
}
var tx = (pageW - myImage.width) / 2;
var ty = (pageH - myImage.height) / 2;
myImage.translate(tx, -ty);
myImage.embed();
}
})();
画像カタログとして利用したい場合にはファイル名も表示しないと役に立ちません。ファイル名も追加して配置する場合には以下のスクリプトを使ってください。ファイル名の位置は「txtObj.translate(X+20, Y - 40); // 文字の表示位置」の20と40の値を調整することで変更できます。
(function(){
var abNum = 100; // 100ページ
var pageW = 595.28; // A4サイズ横幅
var pageH = 841.89; // A4サイズ縦幅
var docObj = app.documents.add(
DocumentColorSpace.RGB,
pageW, // A4サイズ
pageH,
abNum,
DocumentArtboardLayout.GridByRow, // 左から右、上から下
0, // アートボード間の余白
10 // アートボードサイズの平方根。Math.SQRT(abNum)
);
var folderObj = Folder.selectDialog("配置するJPEG画像があるフォルダを選択してください");
var fileList = folderObj.getFiles("*.jpg");
var num = fileList.length;
if (num > 100) num = 100; // 100枚以上は配置しない
var X = 0;
var Y = pageH * 10;
for(var i=0; i<num; i++){
setImage(fileList[i], X, Y);
var txtObj = app.activeDocument.textFrames.add();
txtObj.contents = File.decode(fileList[i].name);
txtObj.translate(X+20, Y - 40); // 文字の表示位置
X = X + pageW;
if (X > pageW*9) { // 10*10なので10枚を超えたら下のアートボードへ
X = 0;
Y = Y - pageH;
}
}
// 指定した位置に画像を配置
function setImage(fileObj, x, y){
var myImage = app.activeDocument.placedItems.add();
myImage.file = fileObj;
myImage.left = x;
myImage.top = y;
if (myImage.width > pageW){ // ページの横幅よりはみ出している場合
var d = pageW / myImage.width;
myImage.width = myImage.width * d;
myImage.height = myImage.height * d;
}
if (myImage.height > pageH){ // ページの縦幅よりはみ出している場合
var d = pageH / myImage.height;
myImage.width = myImage.width * d;
myImage.height = myImage.height * d;
}
var tx = (pageW - myImage.width) / 2;
var ty = (pageH - myImage.height) / 2;
myImage.translate(tx, -ty);
myImage.embed();
}
})();
また、埋め込み画像ではなくリンクタイプの画像にしたい場合には「myImage.embed();」の行を削除してください。

[サンプルをダウンロード]