3

我有一个 Qt 4.8 应用程序,它的前端 UI 都是通过 QDeclarativeView 中的 QML 完成的。

在应用程序的(原始)Linux 版本上,它通过指定在 QML 中的文本项目中使用了几种字体

font.family: "ReykjavikOne OT AGauge"

或者

font.family: "ReykjavikOne OT CGauge"

并且这些按预期工作(CGauge 是一种胖而粗体的版本)。

但是,在 Mac 端口上,这两个似乎都回退到一些丑陋的默认回退无字体。但是使用

font.family: "ReykjavikOne OT"

确实得到了“AGauge”。

在 Linux 系统上,fc-list | grep ReykjavikOne得到我

/usr/share/fonts/opentype/ReykjavikOneCGaugeItalic.otf: ReykjavikOne OT,ReykjavikOne OT CGaugeItalic:style=CGaugeItalic
/usr/share/fonts/opentype/ReykjavikOneCGauge.otf: ReykjavikOne OT,ReykjavikOne OT CGauge:style=CGauge
/usr/share/fonts/opentype/ReykjavikOneAGauge.otf: ReykjavikOne OT,ReykjavikOne OT AGauge:style=AGauge
/usr/share/fonts/opentype/ReykjavikOneAGaugeItalic.otf: ReykjavikOne OT,ReykjavikOne OT AGaugeItalic:style=AGaugeItalic

在 Mac 上,FontBook 将 4 种样式显示为单个“ReykjavikOne OT”条目下的子项。CGauge 字体似乎完全可以在 Mac 上的其他应用程序中使用,所以我假设这是 Qt/QML 特有的问题。

似乎没有任何 QML 文本/字体机制(至少,我无法发现),我可以通过它选择样式名称为“CGauge”的字体样式。乱用粗体/字体粗细似乎让我得到了一个更大胆的 AGauge 或默认字体。

QML RichText 内容也是如此。<style></style>包含元素的文本font-family: 'ReykjavikOne OT CGauge'在 Linux 上工作正常,但在 Mac 上它恢复为备用字体,并且'ReykjavikOne OT'是最好的,获得 AGauge。(添加 afont-weight: bold;确实会得到一个粗体的 AGauge,但 CGauge 明显更胖)。

Mac 和 Linux (Debian/Wheezy) 系统都从相同的 .otf 文件安装字体。

我最大的希望是解决这个问题并让字体的 CGauge 样式按预期显示在 Mac 上?(注意,在字体和 Mac 方面我是新手)。

4

2 回答 2

6

恐怕核心问题是字体元数据。AGauge/CGauge 位不应该在字体名称中泄漏。虽然许多字体编辑器允许字体作者在面(样式)字段中放置几乎任何他们想要的字符串,但在实践中,如果您希望应用程序理解它们,则需要遵守严格的规则。

几年前,微软开始认真考虑在其应用程序中使用类似 css 的样式,并被所有具有创造性命名的字体所困扰。因此,他们编写了关于在应用程序中实际运行的严格指南,并得到了 Adob​​e 和其他主要字体播放器的支持(请注意,Microsoft 是 OpenType 规范的共同维护者,而 uniscribe 几乎是参考 OpenType 引擎)。您的字体不遵守这些准则

请阅读微软白皮书。它描述了 Microsoft 设法挽救的字体命名类型、使用的启发式方法以及启发式方法产生的规范名称。一个好的字体不会受到这些启发,因为它的命名已经使用规范形式并且不需要更正。一个坏字体最多只能在微软平台上默默地纠正它的命名。在 Linux 或 OSX 等其他平台上,将不会进行更正,因此狂野的命名会产生狂野的结果,包括您遇到的故障。

https://blogs.msdn.com/cfs-filesystemfile.ashx/__key/communityserver-components-postattachments/00-02-24-90-36/WPF-Font-Selection-Model.pdf http://blogs.adobe .com/typblography/typotechnica2007/Font%20names.pdf

例如,您的 fontconfig 输出显示 ReykjavikOneCGauge.otf 将 ReykjavikOne OT 或 ReykjavikOne OT CGauge(按优先顺序)声明为姓氏,并将 CGauge 声明为面名。根据 Microsoft 白皮书,CGauge 不是有效的人脸名称,因此该字体应该使用 ReykjavikOne OT CGauge 作为家族名称,并从适当的 WWS(重量宽度斜率)限定符构建人脸名称。不幸的是,它声明 ReykjavikOne OT(没有 CGauge)为主要名称,而 CGauge 为无用的面部名称。

请注意,较旧的软件不会读取那些新的 Opentype 命名字段,因此无论作者在那里放什么,只要您的字体堆栈足够古老,它就可以工作。

于 2013-07-08T17:32:08.283 回答
2

我设法通过在 Debian 系统上的 fontforge 中打开 ReykjavikOneCGauge.otf 文件来解决这个问题,将任何提及的字体名称/字体系列名称更改为 ReykjavikCGauge,其中这种字体是“正常”样式,重新生成一个新的 ReykjavikCGauge。 otf 并将其安装在 Debian 和 Mac 系统上。在 Mac 上,它现在显示为与原始字体完全不同的字体,并且使用 font-family: ReykjavikCGauge 现在可以按预期访问它。

于 2013-07-08T23:25:04.150 回答