简体   繁体   English

Python Qt5 - QTextBrowser 上的字体真棒图标

[英]Python Qt5 - Font awesome icons on QTextBrowser

The question is simple: How can i use fontawesome icons in QTextBrowser?问题很简单:如何在 QTextBrowser 中使用 fontawesome 图标?

What i have done:我做了什么:

# -*- coding: utf-8 -*-

# Form implementation generated from reading ui file 'untitled.ui'
#
# Created by: PyQt5 UI code generator 5.15.0
#
# WARNING: Any manual changes made to this file will be lost when pyuic5 is
# run again.  Do not edit this file unless you know what you are doing.


from PyQt5 import QtCore, QtGui, QtWidgets


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(346, 194)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.verticalLayout = QtWidgets.QVBoxLayout(self.centralwidget)
        self.verticalLayout.setContentsMargins(0, 0, 0, 0)
        self.verticalLayout.setSpacing(0)
        self.verticalLayout.setObjectName("verticalLayout")
        self.textBrowser = QtWidgets.QTextBrowser(self.centralwidget)
        self.textBrowser.setObjectName("textBrowser")
        self.verticalLayout.addWidget(self.textBrowser)
        MainWindow.setCentralWidget(self.centralwidget)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)

    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.textBrowser.setHtml(_translate("MainWindow", "<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0//EN\" \"http://www.w3.org/TR/REC-html40/strict.dtd\">\n"
"<html><head><meta name=\"qrichtext\" content=\"1\" /><style type=\"text/css\">\n"
"p, li { white-space: pre-wrap; }\n"
"</style><script src='https://kit.fontawesome.com/b55315bcbf.js' crossorigin='anonymous'></head><body style=\" font-family:\'MS Shell Dlg 2\'; font-size:8.25pt; font-weight:400; font-style:normal;\">\n"
"<p style=\" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;\"><span style=\" font-size:14pt; font-weight:600;\">Test text</span><i class=\"fas fa-smile\"></i></p></body></html>"))


if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

As the documentation about QTextEdit (which is inherited by QTextBrowser) reports:作为文档有关的QTextEdit(其由QTextBrowser继承)报道:

QTextEdit is an advanced WYSIWYG viewer/editor supporting rich text formatting using HTML-style tags [...]. QTextEdit 是一个先进的 WYSIWYG 查看器/编辑器,支持使用 HTML 样式标签的富文本格式 [...]。 Rich text can be described using a subset of HTML 4 markup.可以使用 HTML 4 标记的子集来描述富文本。
The rich text support in Qt is designed to provide a fast, portable and efficient way to add reasonable online help facilities to applications, and to provide a basis for rich text editors. Qt 中的富文本支持旨在提供一种快速、可移植和高效的方式,为应用程序添加合理的在线帮助工具,并为富文本编辑器提供基础。 If you find the HTML support insufficient for your needs you may consider the use of Qt WebKit, which provides a full-featured web browser widget.如果您发现 HTML 支持不足以满足您的需求,您可以考虑使用 Qt WebKit,它提供了一个全功能的 Web 浏览器小部件。

Considering the above, this obviously means that there's no <script> support, that's exactly because QTextBrowser inherits from QTextEdit, which is a widget to write text documents, and should certainly not support dynamic contents like external scripts.综上所述,这显然意味着没有<script>支持,正是因为QTextBrowser继承自QTextEdit,它是一个编写文本文档的小部件,当然不应该支持像外部脚本那样的动态内容。

These are the only possible solutions, each one with its pros and cons:这些是唯一可能的解决方案,每一个都有其优点和缺点:

  1. install the font on the system: it's system-wide (or at least user-wide), you can just load the font with the correct tag;在系统上安装字体:它是系统范围的(或至少是用户范围的),您可以使用正确的标签加载字体; unfortunately it requires administrator permissions and there's no crossplatform way to install a font from Qt;不幸的是,它需要管理员权限,并且没有跨平台的方式从 Qt 安装字体;
  2. bundle the font in the application and load it with QFontDatabase.addApplicationFont() : usually the best solution, it behaves as the font was installed on the system, but without any installation requirements;在应用程序中捆绑字体并使用QFontDatabase.addApplicationFont()加载它:通常是最好的解决方案,它的行为就像字体安装在系统上一样,但没有任何安装要求; the font has to be packaged with the application, which might be an issue for some licenses;字体必须与应用程序打包在一起,这可能是某些许可证的问题;
  3. use Qt WebKit widgets ( QWebEngineView , etc);使用 Qt WebKit 小部件( QWebEngineView等); it supports all the features of a modern browser, but if you only need to display some text with a custom font, using it is a huge overshoot;它支持现代浏览器的所有功能,但如果你只需要显示一些带有自定义字体的文本,使用它是一个巨大的过冲;

You might use the .setHtml(your_HTML_string) from the QtWidgets.QTextBrowser widget from PyQt5您可以使用来自PyQt5QtWidgets.QTextBrowser小部件中的.setHtml(your_HTML_string)

Your html data should use this format for the image:您的 html 数据应该对图像使用以下格式:

img src="data:image/png;base64,[your_encoded_base64_string_image]"

You could use the https://pypi.org/project/QtAwesome/ icons and just get the image and encoded.您可以使用https://pypi.org/project/QtAwesome/图标并获取图像并进行编码。 For this purpose you could use the base64 python library to encode the image from QtAwesome library like:为此,您可以使用base64 python 库对来自QtAwesome库的图像进行编码,例如:

**Python pseudo code: ** **Python 伪代码:**

import base64
pm = base64.b64encode(img_file)
your_encoded_base64_string_image = pm.decode("utf-8")

**your_HTML_string example: ** **your_HTML_string 示例:**

<html>

<head><meta name="qrichtext" content="1" />
<style type="text/css">
p, li { white-space: pre-wrap; }
</style>
</head>

<body style=" font-family:'Arial Unicode MS'; font-size:10pt; font-weight:600; font-style:normal;">

<p style=" margin-top:0px; margin-bottom:0px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px;"><img src=" " width="17" height="17" style="vertical-align: top;" /> Tue Nov 30 08:57:36 2021: Importar Archivo Red, Exitoso! 
<br><img src=" " style='vertical-align:top' width="17" height="17"> Tue Nov 30 08:58:12 2021: Coordenadas de proyecto estan fuera de raster disponible, verificar!
</p>

</body>
</html>

Marcelo.马塞洛。

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM