InDesign:ExtendScript 列出字体和扩展字体信息

问题描述 投票:0回答:1

我需要列出一组 inDesign 文档中使用的字体的详细信息。我需要的信息基本上可以通过菜单项 Type › Find Fonts… 访问(如here所述),但是遍历每个文档中的每种字体并写下信息是不可行的。

我可以在

Font
下的
document.fonts
对象中找到很多信息,我的问题是如何访问或生成下面面板中的扩展属性:

  • 给定字体的字符数
  • 字体出现的页面


(来源:indesignsecrets.com

编辑:

document.fonts
数组似乎也不包含丢失的字体。

adobe-indesign extendscript
1个回答
2
投票

嗯,这是字符计数的强力策略。它会迭代文档中的每个 character textStyleRange 并检查其应用的字体。 编辑:更新为使用textStyleRanges。比遍历每个角色要快得多。

var document = app.open(new File(Folder.desktop.fsName + "/test/test.indd"));
try {
    var fontMultiset = countCharsInFonts(document);

    // For each font, display its character count.
    var fonts = document.fonts.everyItem().getElements();
    for (var i = 0; i < fonts.length; i++) {
        var fontName = fonts[i].fullName;
        $.writeln(fontName + ": " + fontMultiset[fontName]);
    }
}
finally {
    document.close();
}

function countCharsInFonts(document) {
    // Create the font multiset.
    var fontMultiset = {
        add: function add(fontName, number) {
            if (this.hasOwnProperty(fontName)) {
                this[fontName] += number;
            }
            else {
                this[fontName] = number;
            }
        },
    };

    // For every textStyleRange in the document, add its applied font to the multiset.
    var stories = document.stories.everyItem().getElements();
    for (var i = 0; i < stories.length; i++) {
        var story = stories[i];
        var textStyleRanges = story.textStyleRanges.everyItem().getElements();
        for (var j = 0; j < textStyleRanges.length; j++) {
            fontMultiset.add(textStyleRanges[j].appliedFont.fullName, textStyleRanges[j].length);
        }
    }

    // For any fonts that aren't applied in the document, set the character count to 0.
    var fonts = document.fonts.everyItem().getElements();
    for (var i = 0; i < fonts.length; i++) {
        var fontName = fonts[i].fullName;
        if (!fontMultiset.hasOwnProperty(fontName)) {
            fontMultiset[fontName] = 0;
        }
    }

    return fontMultiset;
}
© www.soinside.com 2019 - 2024. All rights reserved.