2

多くのサブフォルダーを含むフォルダーがあり、それぞれに多数の TIF ファイルと PSD ファイルが含まれています。これらの中には透明なものもあれば、そうでないものもあります。これらのファイルのサイズは大きく異なります。

すべてのファイルを JPG に変換するか、透過性が含まれている場合は PNG に変換する必要があります。ファイルは 200kb 以下である必要があり、スケールアップしない限り、ファイルの大きさは気にしません。

フォーラムの誰か (私は非常に感謝しています) がかなりの量のコードを書いてくれました。私の友人はそれを私が求めていたものにぴったり合うように修正しました。

それは問題なく動作しましたが、唯一の問題は、多くの画像が 1x1 ピクセルで単色のブロックであるということでした。

何らかの理由でこれが同じ画像で一貫して発生していることがわかりましたが、これらの画像で正確に何が起こっているのかを突き止めることができませんでした.

現在、ミスター フォーラム blokey ( http://www.photoshopgurus.com/forum/members/paul-mr.html ) がスクリプトを修正し、PSD で問題なく動作するようになりました。

透明度のある TIF で動作していますが、不透明度が 100% の TIF の一部は機能しません。青以外にこれらのファイルと一致するものはあまり見つかりませんが、これは大きな偶然の一致である可能性があり、おそらくそうです(私が扱ってきた画像には多くの青があります)。

以下は、コードが最初に書かれたスレッドへのリンクです。Paul MR は、カラーサンプラー ビットが少し疑わしいと考えているようです。おそらくそれが問題の原因です (青さ?)。

http://www.photoshopgurus.com/forum/photoshop-actions-automation/34745-batching-tiffs-jpg-png-w-automatic-resize-based-filesize.html

これを自分で試して解決するためにもう少しできたらいいのにと思いますが、このことについてはほとんど理解していません。ちょっとしたスクリプトが役立つ状況があるときだけ知っています。

以下は、現在のスクリプトです。

#target PhotoshopString.prototype.endsWith  = function(str) {
 return (this.match(str  + "$")  == str)
} String.prototype.startsWith  = function(str) {
    return this.indexOf(str)  == 0;
};
var desiredFileSize  = 200000;
app.bringToFront();
app.displayDialogs  = DialogModes.NO;
main();
//app.displayDialogs = DialogModes.YES;
function main() {
    var topLevelFolder  = Folder.selectDialog("Please select top level folder.");
    if (topLevelFolder  == null)return;
    var FileList  = [];
    getFileList(topLevelFolder);
    var startRulerUnits  = app.preferences.rulerUnits;
    app.preferences.rulerUnits  = Units.PIXELS;
    for (var f in FileList)  {
        app.open(FileList[f]);
        activeDocument.changeMode(ChangeMode.RGB);
        try  {
            activeDocument.mergeVisibleLayers();
        } catch(e)  {} var Name  = decodeURI(app.activeDocument.name).replace(/.[^.] + $ /, '');
        if (hasTransparency(FileList[f]))  {
            var saveFile  = File(FileList[f].path  + "/"  + Name  + ".png");
            SavePNG(saveFile);
            app.activeDocument.close(SaveOptions.DONOTSAVECHANGES);
        } else  {
            var saveFile  = File(FileList[f].path  + "/"  + Name  + ".jpg");
            SaveForWeb(saveFile, 80);
            app.activeDocument.close(SaveOptions.DONOTSAVECHANGES);
        } app.preferences.rulerUnits  = startRulerUnits;
    } function getFileList(folder)  {
        var fileList  = folder.getFiles();
        for (var i = 0; i < fileList.length; i++)  {
            var file  = fileList[i];
            if (file instanceof Folder)  {
                getFileList(file);
            } else  {
                if ((file.name.endsWith("tiff")  || file.name.endsWith("tif")  || file.name.endsWith("psd"))  &&  ! file.name.startsWith("._"))FileList.push(file);
            }
        }
    } alert(FileList.length  + " files have been modified.");
} function hasTransparency(file) {
    if (file.name.endsWith("tiff")  || file.name.endsWith("tif"))  {
        var sample  = app.activeDocument.colorSamplers.add([new UnitValue(1.5, 'px'), new UnitValue(1.5, 'px')]);
        try  {
            sample.color.rgb.hexValue;
            sample.remove();
            return false;
        } catch(e)  {
            sample.remove();
            return true;
        }
    } var doc  = activeDocument;
    if (doc.activeLayer.isBackgroundLayer)return false;
    var desc  = new ActionDescriptor();
    var ref  = new ActionReference();
    ref.putProperty(charIDToTypeID("Chnl"), charIDToTypeID("fsel"));
    desc.putReference(charIDToTypeID("null"), ref);
    var ref1  = new ActionReference();
    ref1.putEnumerated(charIDToTypeID("Chnl"), charIDToTypeID("Chnl"), charIDToTypeID("Trsp"));
    desc.putReference(charIDToTypeID("T "), ref1);
    executeAction(charIDToTypeID("setd"), desc, DialogModes.NO);
    var w  = doc.width.as('px');
    var h  = doc.height.as('px');
    var transChannel  = doc.channels.add();
    doc.selection.store(transChannel);
    if (transChannel.histogram[255]  != (h  * w))  {
        transChannel.remove();
        return true;
    } else  {
        transChannel.remove();
        return false;
    }
};
function SavePNG(saveFile) {
    pngSaveOptions  = new PNGSaveOptions();
    activeDocument.saveAs(saveFile, pngSaveOptions, true, Extension.LOWERCASE);
    var actualFilesize  = saveFile.length;
    var ratio  = desiredFileSize / actualFilesize;
    if (ratio  < 1)  {
        var imageScale  = Math.sqrt(ratio);
        activeDocument.resizeImage(activeDocument.width  * imageScale, activeDocument.height  * imageScale, activeDocument.resolution, ResampleMethod.BICUBICSMOOTHER);
        activeDocument.saveAs(saveFile, pngSaveOptions, true, Extension.LOWERCASE);
    }
}
function SaveForWeb(saveFile, jpegQuality) {
    var sfwOptions  = new ExportOptionsSaveForWeb();
    sfwOptions.format  = SaveDocumentType.JPEG;
    sfwOptions.includeProfile  = false;
    sfwOptions.interlaced  = 0;
    sfwOptions.optimized  = true;
    sfwOptions.quality  = jpegQuality;
    activeDocument.exportDocument(saveFile, ExportType.SAVEFORWEB, sfwOptions);
    var actualFilesize  = saveFile.length;
    var ratio  = desiredFileSize / actualFilesize;
    if (ratio  < 1)  {
        var imageScale  = Math.sqrt(ratio);
        activeDocument.resizeImage(activeDocument.width  * imageScale, activeDocument.height  * imageScale, activeDocument.resolution, ResampleMethod.BICUBICSMOOTHER);
        activeDocument.exportDocument(saveFile, ExportType.SAVEFORWEB, sfwOptions);
    }
}
4

0 に答える 0