首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >QWebView不呈现字体

QWebView不呈现字体
EN

Stack Overflow用户
提问于 2012-08-05 00:31:44
回答 3查看 3.1K关注 0票数 4

我正在编写一个从文件夹中显示静态HTML文件的应用程序。出于某种原因,PyQt4 4的QWebView类不允许任何字体呈现,即使是对远程网站:

QWebView

Chrome

我正在按如下方式加载文件:

代码语言:javascript
复制
self.web_view = QWebView()
self.settings = self.web_view.settings()
self.settings.setAttribute(QWebSettings.LocalContentCanAccessRemoteUrls, True)

self.web_view.load(QUrl('http://blender3d.github.com/Bevel/demo/'))

是否有更多的安全设置,我必须改变,以使这一工作?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2012-08-08 04:50:23

在折磨了QWebView几个小时之后,我终于注意到字体松鼠以惊人的方式呈现了一个外部字体。我把这些信高亮了很多遍,满脸敬畏地坐在那里,面带微笑。

不管怎样,这似乎是为了使这与QWebView一起工作。

代码语言:javascript
复制
@font-face {
  font-family: 'Terminal Dosis';
  font-style: normal;
  font-weight: 400;
  src: local('Dosis Regular'), local('Dosis-Regular'), url('../fonts/terminal-dosis-regular.woff') format('woff');
}

我不得不让它看起来像这样:

代码语言:javascript
复制
@font-face {
  font-family: 'Terminal Dosis Regular';
  src: url('../fonts/terminal-dosis-regular.ttf') format('truetype');
}

注意,QWebView不喜欢WOFF字体。我不得不通过字体松鼠把我的转换成字体松鼠

简言之:

  • 确保您的字体是TrueType字体。
  • 没有local()的东西。
  • font-stylefont-weight似乎被忽略了。您必须为每种字体的每种样式创建不同的字体系列(例如,Terminal Dosis Bold)。
票数 7
EN

Stack Overflow用户

发布于 2012-08-08 02:28:51

示例url的样式表使用css @font-face规则指定联机字体。

不幸的是,在QWebKit:Bug 36351中,这个问题目前似乎已经被打破了。

票数 0
EN

Stack Overflow用户

发布于 2012-08-08 02:54:36

坏了!本文中可能的解决办法:

declaration.xhtml

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11813055

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档