Adobe Illustrator CS3〜CC2014編 ページ内に選択した図形をページ内に納める

今回は、Illustratorで選択した図形をページ内に納めるスクリプトです。一応ページ内に選択した図形を入れるようになっていますが、GUI部分で入れ込む範囲を指定することで、その中に図形を入れ込むことができます。
なお、図形は縮小してページ内に入れ込む処理はしていません。
今回はプログラムが長いので、縮小して処理するパターンは次回に掲載します。

// ページ内に選択された図形等を入れる
(function(){
if (app.documents.length < 1){ return; }
var w = app.activeDocument.width; // 横幅
var h = app.activeDocument.height; // 縦幅
// 内包するオブジェクトを指定する
var targetObj = {
x1 : 0,
y1 : 0,
x2 : w,
y2 : h
}
// GUI部分
var winObj = new Window("dialog", "ページ内に納める", [0,0,320,200]);
var cropSize1 = winObj.add("statictext", [20, 10, 300, 25], "収める範囲を入れてください(単位pt)");
winObj.add("statictext", [30, 50, 60, 70], "左");
winObj.add("statictext", [170, 50, 180, 70], "上");
winObj.add("statictext", [30, 80, 60, 100], "右");
winObj.add("statictext", [170, 80, 180, 100], "下");
var x1e = winObj.add("edittext", [50, 50, 150, 70], targetObj.x1);
var y1e = winObj.add("edittext", [190, 50, 290, 70], targetObj.y1);
var x2e = winObj.add("edittext", [50, 80, 150, 100], targetObj.x2);
var y2e = winObj.add("edittext", [190, 80, 290, 100], targetObj.y2);
var btnExtend = winObj.add("button", [20, 130, 300, 155], "実行する");
var btnEnd = winObj.add("button", [20, 160, 300, 185], "終了する");
// ボタンにイベントを割り当てる
btnExtend.onClick = function(){
targetObj.x1 = parseFloat(x1e.text);
targetObj.y1 = parseFloat(y1e.text);
targetObj.x2 = parseFloat(x2e.text);
targetObj.y2 = parseFloat(y2e.text);
adjust();
redraw();
}
// ウィンドウを閉じる
btnEnd.onClick = function(){
winObj.close();
}
winObj.center();
winObj.show();
// 位置を調整する処理
function adjust(){
// 各種オブジェクトに対して処理を行う
for(var i=0; i<activeDocument.selection.length; i++){
toInner(activeDocument.selection[i], targetObj);
}
function toInner(selObj, targetObj){
// 図形の座標を読み出し
var rect = selObj.geometricBounds;
var srcX1 = rect[0];
var srcY1 = -rect[1];
var srcX2 = rect[2];
var srcY2 = -rect[3];
// ページX座標よりも小さい場合
if (srcX1 < targetObj.x1){
selObj.translate(targetObj.x1-srcX1, 0);
}
// ページX座標よりも大きい場合
if (srcX2 > targetObj.x2){
selObj.translate(targetObj.x2-srcX2, 0);
}
// ページY座標よりも小さい場合
if (srcY1 < targetObj.y1){
selObj.translate(0, -(targetObj.y1-srcY1));
}
// ページY座標よりも大きい場合
if (srcY2 > targetObj.y2){
selObj.translate(0, -(targetObj.y2-srcY2));
}
}
}
})();

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