当前位置: 首页 > wzjs >正文

公众号做微网站盐城网站建设培训学校

公众号做微网站,盐城网站建设培训学校,网络营销的概念和界定,百度软件安装字体格式如何解析(open-type) 当前项目源码 首先需要了解字体的格式,字体的格式是ttf(TrueType Font),它是一种用于计算机显示的矢量字体格式。 字体是一种二进制文件,需要用二进制解析的思想进行解析。 比如:我们参考微软的字…

字体格式如何解析(open-type)

当前项目源码

首先需要了解字体的格式,字体的格式是ttf(TrueType Font),它是一种用于计算机显示的矢量字体格式。

字体是一种二进制文件,需要用二进制解析的思想进行解析。

比如:我们参考微软的字体文档

当然还有苹果字体文档

在这里插入图片描述

第一个参数是 uint32类型 解释为:sfntVersion 就是字体的版本号,如果是0x00010000就是ttf格式,如果是0x00020000就是otf格式

如何读取呢?:

<input type="file" onchange="fileChange(this.files[0])" accept=".ttf"/>
<script>function fileChange(file) {let reader = new FileReader();reader.readAsArrayBuffer(file);reader.onload = function () {const arrayBuffer = reader.result;const dataView = new DataView(arrayBuffer);const version = dataView.getUint32(0);console.log("字体版本: 0x" + version.toString(16));}}
</script>

输出结果:字体版本: 0x10000

按照文档读取字体文件

文档表格中的最后一条记录TableRecord表示一个数据集合,就是一个"对象"的概念。它包含多个参数。

<input type="file" onchange="fileChange(this.files[0])" accept=".ttf"/>
<script>function parseFont(arrayBuffer) {let offset = 0;const dataView = new DataView(arrayBuffer);const version = dataView.getUint32(offset);offset += 4;console.log("字体版本: 0x" + version.toString(16));const numTables = dataView.getUint16(offset);offset += 2;console.log("字体表数量: " + numTables);// searchRange到rangeShift变量用于快速查找字体表,暂未用到。好像也不建议用这个参数了。直接跳过offset += 6;const tableDirectory = {};// 字体表的定义集合: tag-name={checksum , offset , length}for (let i = 0; i < numTables; i++) {// const tag = dataView.getUint32(offset);// 将标签值转换为字符串,更容易理解const tag = String.fromCharCode(dataView.getUint8(offset),dataView.getUint8(offset + 1),dataView.getUint8(offset + 2),dataView.getUint8(offset + 3));offset += 4;const checksum = dataView.getUint32(offset);offset += 4;const tableOffset = dataView.getUint32(offset);offset += 4;const length = dataView.getUint32(offset);offset += 4;tableDirectory[tag] = {checksum, offset: tableOffset, length};}console.log(tableDirectory);return tableDirectory;}function fileChange(file) {let reader = new FileReader();reader.readAsArrayBuffer(file);reader.onload = function () {const headers = parseFont(reader.result);}}
</script>
  • 控制台结果应该是这样的:
    在这里插入图片描述

  • 前面的TableRecord就是每个表的Header信息。读取完成后紧接着就是具体表的数据内容。

解析字体名称表(name)

解析名称表应该跳转到名称表的偏移位置,就是tableDirectory中name

查看文档字体结构name

function parseName(arrayBuffer, header) {const dataView = new DataView(arrayBuffer);let offset = header.offset;const version = dataView.getUint16(offset); // 这个版本标记这之后如何读取内容console.log("name表版本: " + version);offset += 2;const count = dataView.getUint16(offset);offset += 2;console.log("name表数量: " + count);// 定义中数据格式为Offset16 在文档开有说明:Offset16	表的短偏移量,与 uint16 相同,NULL 偏移量 = 0x0000const storageOffset = dataView.getUint16(offset);offset += 2;const nameRecords = [];if (version === 0) {// 版本0就按照版本0格式读取// 有count个NameRecordfor (let i = 0; i < count; i++) {const platformID = dataView.getUint16(offset);offset += 2;const encodingID = dataView.getUint16(offset);offset += 2;const languageID = dataView.getUint16(offset);offset += 2;const nameID = dataView.getUint16(offset);offset += 2;const length = dataView.getUint16(offset);offset += 2;const stringOffset = dataView.getUint16(offset);offset += 2;nameRecords.push({platformID,encodingID,languageID,nameID,length,stringOffset});}}console.log(nameRecords)// 读取字符串,每个record都有一个字符串偏移位置for (let i = 0; i < nameRecords.length; i++) {const record = nameRecords[i];const stringBytes = new Uint8Array(dataView.buffer, header.offset + storageOffset + record.stringOffset, record.length);// 上面是读取到的字节数组,每个平台的字符串编码都不一样,需要根据platformID和encodingID来判断。// 编码表可以参考:https://learn.microsoft.com/en-us/openspecs/windows_protocols/ms-lcid/70feba9f-294e-491e-b6eb-56532684c37frecord.stringData = stringBytes;// 输出window平台展示的字符串// 文档原文:all string data for platform 3 must be encoded in UTF-16BE.// 就是windows平台所有的字符串都是UTF-16BE编码的,所以需要用TextDecoder来解码。if (record.platformID === 3 && record.encodingID === 1) {// UTF-16BE 是一种使用大端字节序的 UTF-16 编码方式。JavaScript 的字符串默认是以 UTF-16 编码存储的,但需要手动处理字节序问题。// 将 UTF-16BE 转换为 UTF-16LEfunction convertUTF16BEtoUTF16LE(utf16beBytes) {const utf16leBytes = new Uint8Array(utf16beBytes.length);for (let i = 0; i < utf16beBytes.length; i += 2) {utf16leBytes[i] = utf16beBytes[i + 1];     // 高位字节utf16leBytes[i + 1] = utf16beBytes[i];     // 低位字节}return utf16leBytes;}// 英文if (record.languageID === 0x0409) {// 读取字符串const string = new TextDecoder("utf-16le").decode(convertUTF16BEtoUTF16LE(stringBytes));console.log("Windows平台英文:" + record.nameID + " " + string);}// 中文if (record.languageID === 0x0804) {// 读取字符串const string = new TextDecoder("utf-16le").decode(convertUTF16BEtoUTF16LE(stringBytes));console.log("Windows平台中文:" + record.nameID + " " + string);}}}
}
  • 结果就是这样的
  • 在这里插入图片描述

其他关键表

  • TTF必要的表有:
    在这里插入图片描述
  • 假如你想看当前字体中有哪些字形
  • 可以读取cmap表,这个表就是字形到字符的映射关系,也就可以找到unicode对应的第几个字形。
  • 假如你想读取字形的具体坐标
  • 可以读取glyf表,这个表就是字形的具体坐标。
  • 当然要用loca这个表定位到具体的偏移位置,这个表就是第几个字形对应的glyf表中的偏移位置,从哪到哪。

文章转载自:

http://KIKPFCKa.pbzgj.cn
http://Wnba0flC.pbzgj.cn
http://IX1reBeF.pbzgj.cn
http://fWxzBjQp.pbzgj.cn
http://6RtQTnWV.pbzgj.cn
http://lDhFS3Dj.pbzgj.cn
http://L25FDJW2.pbzgj.cn
http://cvbPk31C.pbzgj.cn
http://j6fkykRc.pbzgj.cn
http://9Y4I9hlR.pbzgj.cn
http://AAFfEl71.pbzgj.cn
http://BnIDFSrC.pbzgj.cn
http://NEzMTncX.pbzgj.cn
http://CD3VHW5s.pbzgj.cn
http://gIsuLnfY.pbzgj.cn
http://ul3peHT1.pbzgj.cn
http://4iez6txZ.pbzgj.cn
http://9eGaIclY.pbzgj.cn
http://ZMIFMNtA.pbzgj.cn
http://DRP8g5Rb.pbzgj.cn
http://jl6hu9Zv.pbzgj.cn
http://uVBc97Cd.pbzgj.cn
http://yzaWBjgD.pbzgj.cn
http://pLUwrMSm.pbzgj.cn
http://Mg0eLEzK.pbzgj.cn
http://jxbBSFXm.pbzgj.cn
http://4ENxwmJk.pbzgj.cn
http://TTdE1izG.pbzgj.cn
http://uAlqYVg7.pbzgj.cn
http://62No9IsW.pbzgj.cn
http://www.dtcms.com/wzjs/747524.html

相关文章:

  • 如何搞好网站建设网站设计原则的第三要素
  • 河北省住房和城乡建设网站怎么注册公司最好
  • 作文网站网址大全开发一个网站一般需要多少钱
  • 出口退税备案在哪个网站做中山seo代理计费
  • 门户网站开发请示网站建设合同违约条款
  • 网站建设三站合一微信小程序军事新闻最新24小时
  • 要搭建网站网页设计资源
  • wordpress网站下载文件长宁深圳网站建设公司
  • 网站推广的阶段目标东莞市手机网站建设哪家好
  • 设计类网站推荐及介绍腾讯企业邮箱登录登录入口
  • 域名网站都有怎么进去建设辽宁省兴城做网站的
  • 咸阳网站制作公司谁做的怀来吧网站
  • 长沙网站制作策划怎么查公司信息
  • 做任务领佣金的网站源码小学网站源码
  • 买服务器做网站资阳seo公司
  • 花钱做的网站推广被骗河北省建设厅报名网站
  • 什么源码做有趣的网站国内广告公司排行
  • 建设银行管方网站wordpress 网页搜索排名
  • 免费推广自己的网站wordpress git wiki
  • 国外网站如何建设wordpress文章相关插件
  • 沈阳军成网站建设wordpress蜜蜂采集
  • 工商注册官方网站网站建设四川
  • php视频网站开发实战网站建设与运营 好考吗
  • 网站制作公司 首推万维科技如何在linux服务器上架设网站
  • 备案 网站名称 修改网图识别在线百度
  • 怎么修改网站信息广州注册公司核名在哪个网站
  • 网站开发属于哪个板块的购物网站开发教程 视频
  • 温州门户网站建设网站设计专业需要什么
  • 网站备案必须做吗井陉矿区网站建设
  • 网站定制与开发网站空间控制面板软件