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

fastreport导出PDF后style bold粗体斜体等字体风格不显示的原因

用fastreport做导出PDF(带嵌入字体)的功能,发现导出的PDF里粗体效果不显示(style 设置 bold),其他比如文字颜色、底色等显示正常。然后如果不嵌入字体,那么粗体也是正常的,不过不嵌入字体的PDF在手机上会乱码。

看了两天的fastreport代码,fastreport的源码没有注释(也可能外发的代码删掉注释了),看的比较头大。

慢慢看出了一点头绪

在frxexporthelpers 但愿的的1846行 getfontfile函数内用getFontData这个API装入字体文件数据,我用的是宋体字,装入的是simSun.ttc字体

常用矢量字体文件分两种,ttc是集合字体,里面可以包含多个实际字体。
ttf后缀的是实际的字体。然后字体还有家族聚合,就是一个字体家族内可以有常规、加粗、斜体、粗体并斜体等风格。像微软雅黑还有细体风格。


继续跟代码, 在 frxtruetypeCollection 单元的第120行,函数Self.TrueTypeTables.Initialize 根据
刚才装入的字体判断开头标志,开头是0100 是单字体,开头是ttcf的是集合字体,如果是单字体,那么直接转化为tureType类型并加入字体列表。如果是ttc的,那么先拆分,再加入列表。

再在 frxtruetypeCollection 的第169行,函数loadfont

 根据是否有bold来从集合选择一个字体,如果没有匹配到,那么选择列表里的第一个字体文件。

看代码,fastreport也对字体风格进行了处理。但跟踪代码,发现不论有没bold等风格,嵌入的字体文件都是同一个。于是通过查找资料,发现宋体字体就只有一个,宋体的加粗是通过软件插值计算实现的,不像微软雅黑那样是有单独的粗体字体。

如果不能通过加载字体简单解决,那么要更改fastreport源码的工作量有点大了,于是先用了个取巧的方法,在报表准备阶段把字体为宋体且勾选了嵌入字体的导出内容,加粗的地方全部替换为黑体,看起来效果也差不多。

另外还有一个避免字体风格style丢失的方法,就是用微软雅黑代替宋体字,在勾选嵌入字体导出PDF时字体风格正常。
 


http://www.kler.cn/news/341515.html

相关文章:

  • LeetCode 54 Spiral Matrix 解题思路和python代码
  • mybatisPlus对于pgSQL中UUID和UUID[]类型的交互
  • 构建高效数据处理桥梁:探索基于数据库驱动的自定义TypeHandler解决方案
  • 基于esp8266的nodemcu实现网页配置wifi功能
  • SpringBoot框架在服装生产管理中的创新应用
  • ANSYS Workbench随机连通孔结构建模
  • 【Cursor教程】探索Cursor颠覆编程体验的创新工具!教程+示例+快捷键
  • Github 2024-10-03Go开源项目日报Top10
  • LeetCode讲解篇之34. 在排序数组中查找元素的第一个和最后一个位置
  • zigbee学习
  • C++-容器适配器- stack、queue、priority_queue和仿函数
  • 重生之我们在ES顶端相遇第 20 章 - Mapping 参数设置大全(进阶)
  • 交叉编译(移植)
  • 深入解析MySQL事务管理:ACID特性与基本操作
  • 文件夹作为普通文件而非子模块管理
  • Unity实现自定义图集(三)
  • 【操作系统】引导(Boot)电脑的奇妙开机过程
  • LeetCode hot100---栈专题(C++语言)
  • Stable Diffusion绘画 | 如何做到不同动作表情,人物角色保持一致性(上篇)
  • sqli-labs靶场第三关less-3