<del id="d4fwx"><form id="d4fwx"></form></del>
      <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

            <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
          • 如何使用Opentype.js生成字體子集

            這篇文章主要講解了如何使用Opentype.js生成字體子集,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。

            創(chuàng)新互聯(lián)專(zhuān)注為客戶(hù)提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站制作、成都做網(wǎng)站、河西網(wǎng)絡(luò)推廣、微信平臺(tái)小程序開(kāi)發(fā)、河西網(wǎng)絡(luò)營(yíng)銷(xiāo)、河西企業(yè)策劃、河西品牌公關(guān)、搜索引擎seo、人物專(zhuān)訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠(chéng)為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);創(chuàng)新互聯(lián)為所有大學(xué)生創(chuàng)業(yè)者提供河西建站搭建服務(wù),24小時(shí)服務(wù)熱線(xiàn):18982081108,官方網(wǎng)址:www.jbt999.com

            字體子集是將字體文件中部分多余的字符刪除,來(lái)減小文件大小,從而在 Web 端使用或嵌入到其他應(yīng)用或系統(tǒng)中,在網(wǎng)上可以找到不少這方面的工具。

            Opentype.js是一套可以支持瀏覽器環(huán)境和 Node.js 環(huán)境的開(kāi)源 OpenType 字體讀寫(xiě)庫(kù),利用這個(gè)庫(kù)可以很輕松實(shí)現(xiàn)瀏覽器環(huán)境和 Node.js 環(huán)境的字體子集功能。

            在瀏覽器環(huán)境創(chuàng)建字體子集工具

            首先創(chuàng)建一個(gè)簡(jiǎn)單的 HTML界面,包括一個(gè)選取字體文件按鈕,一個(gè)輸入框用于輸入保留的字符,和一個(gè)保存下載按鈕。

            HTML

            <!DOCTYPE html>
            <html>
            <head>
            <meta charset="utf-8">
            <title>Font Subset</title>
            </head>
            <body>
             <div>
              <p><label for="text">Choose a font file:</label></p>
              <input type="file" id="file">
             </div>
             <div>
              <p><label for="text">Text:</label></p>
              <textarea id="text"></textarea>
             </div>
             <div>
              <input type="button" id="save" value="save">
             </div>
            </body>
            </html>

            在 HTML 的</body>前引入 opentype.js,并加入 Javascript。

            <script src="https://cdn.jsdelivr.net/npm/opentype.js@latest/dist/opentype.min.js"></script>
            <script>
             var save = document.getElementById("save");
             save.onclick = function() {
              var file = document.getElementById("file");
              var text = document.getElementById("text");
              if (file.files.length === 0) {
               alert("Choose a font file.")
               return;
              }
              if (text.value === "") {
               alert("Type some text.")
               return;
              }
            
              var glyphsArray = text.value.split("");
              var glyphs = glyphsArray.filter(function(item) {
                return item !== " ";
               }).filter(function(item, index) {
                return glyphsArray.indexOf(item) === index;
               }).join("");
            
              var reader = new FileReader();
              reader.onload = function(error) {
               try {
                var font = opentype.parse(reader.result);
                var postScriptName = font.getEnglishName("postScriptName");
                var [familyName, styleName] = postScriptName.split("-");
                
                var notdefGlyph = font.glyphs.get(0);
                notdefGlyph.name = ".notdef";
                var subGlyphs = [notdefGlyph].concat(font.stringToGlyphs(glyphs));
            
                var subsetFont = new opentype.Font({
                 familyName: familyName,
                 styleName: styleName,
                 unitsPerEm: font.unitsPerEm,
                 ascender: font.ascender,
                 descender: font.descender,
                 designer: font.getEnglishName("designer"),
                 designerURL: font.getEnglishName("designerURL"),
                 manufacturer: font.getEnglishName("manufacturer"),
                 manufacturerURL: font.getEnglishName("manufacturerURL"),
                 license: font.getEnglishName("license"),
                 licenseURL: font.getEnglishName("licenseURL"),
                 version: font.getEnglishName("version"),
                 description: font.getEnglishName("description"),
                 copyright: "This is a subset font of " + postScriptName + ". " + font.getEnglishName("copyright"),
                 trademark: font.getEnglishName("trademark"),
                 glyphs: subGlyphs
                });
                subsetFont.download();
               } catch (error) {
                alert(error.message);
                throw(error);
               }
              };
              reader.onerror = function(error) {
               alert(error.message);
               throw(error);
              };
              reader.readAsArrayBuffer(file.files[0]);
             };
            </script>

            在 Node.js 環(huán)境創(chuàng)建字體子集工具

            創(chuàng)建項(xiàng)目文件

            在 Node.js 版的項(xiàng)目中,可以考慮通過(guò)配置文件來(lái)實(shí)現(xiàn)批量處理多個(gè)字體文件功能。

            mkdir font_subset
            cd font_subset
            npm init

            項(xiàng)目結(jié)構(gòu)如下,把所有原始的字體保存在 src 目錄下,子集化之后的字體保存在 dist 目錄下,main.js 為主腳本。

            font_subset
            ├── config.json
            ├── dist
            ├── main.js
            ├── node_modules
            ├── package-lock.json
            ├── package.json
            └── src
             └── NotoSerifSC-Bold.otf

            字體配置

            修改 “config.json” 文件。fonts數(shù)組類(lèi)型,可配置多個(gè)字體文件;texts字符串類(lèi)型,輸入需要保留的字符,字符可以重復(fù),可包含空格,不可換行,英文雙引號(hào)使用\"表示。

            {
             "fonts": ["./src/NotoSerifSC-Bold.otf"],
             "texts": " 0123456789:"
            }

            生成字體

            main.js 內(nèi)容如下。

            const config = require('./config.json');
            const fonts = config.fonts;
            const texts = config.texts;
            
            const path = require('path');
            const opentype = require('opentype.js');
            
            const glyphs = [...new Set(texts.split(''))].join('');
            
            fonts.forEach(item => {
             const font = opentype.loadSync(item);
             const postScriptName = font.getEnglishName('postScriptName');
             const dist = path.join(
              'dist',
              postScriptName.replace(/-/g, '_').toLowerCase() + '_subset.otf'
             );
             const [familyName, styleName] = postScriptName.split('-');
             
             const notdefGlyph = font.glyphs.get(0);
             notdefGlyph.name = '.notdef';
             const subGlyphs = [notdefGlyph].concat(font.stringToGlyphs(glyphs));
             
             const subsetFont = new opentype.Font({
              familyName: familyName,
              styleName: styleName,
              unitsPerEm: font.unitsPerEm,
              ascender: font.ascender,
              descender: font.descender,
              designer: font.getEnglishName('designer'),
              designerURL: font.getEnglishName('designerURL'),
              manufacturer: font.getEnglishName('manufacturer'),
              manufacturerURL: font.getEnglishName('manufacturerURL'),
              license: font.getEnglishName('license'),
              licenseURL: font.getEnglishName('licenseURL'),
              version: font.getEnglishName('version'),
              description: font.getEnglishName('description'),
              copyright: 'This is a subset font of ' + postScriptName + '. ' + font.getEnglishName('copyright'),
              trademark: font.getEnglishName('trademark'),
              glyphs: subGlyphs
             });
            
             subsetFont.download(dist);
            });

            打開(kāi)終端項(xiàng)目所在目錄,輸入以下命令,字體保存到 “dist” 文件夾下。

            node main.js

            看完上述內(nèi)容,是不是對(duì)如何使用Opentype.js生成字體子集有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

            名稱(chēng)欄目:如何使用Opentype.js生成字體子集
            網(wǎng)頁(yè)URL:http://www.jbt999.com/article2/gsedoc.html

            成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作網(wǎng)站策劃、軟件開(kāi)發(fā)、小程序開(kāi)發(fā)、品牌網(wǎng)站制作、品牌網(wǎng)站設(shè)計(jì)

            廣告

            聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:[email protected]。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

            成都網(wǎng)頁(yè)設(shè)計(jì)公司

              <del id="d4fwx"><form id="d4fwx"></form></del>
              <del id="d4fwx"><form id="d4fwx"></form></del><del id="d4fwx"><form id="d4fwx"></form></del>

                    <code id="d4fwx"><abbr id="d4fwx"></abbr></code>
                  • 日本一区视频免费 | 午夜视频久久久 | 影视先锋男人资源网 | 爱爱网址视频 | 亚洲操逼片 |