向QTextEdit/QTextBrowser添加彩色文字与图片

转自:http://blog.sina.com.cn/s/blog_9da24f3b0101jz1w.html

QTextEdit/QTextBrowser支持Html4。当insertPlainText不能满足你的需求的时候,可以试试用Html来添加显示的内容。这几介绍大家常用的彩色文字,和添加图片。
    一、添加彩色文字。
    1.由于html的特性,会导致一些特殊字符不能显示,例如用于标记的‘<’‘>’、空格,换行等。所以第一步需要对待添加的QString进行转化,转化成html支持的文本方式。使用如下函数:
    void stringToHtmlFilter(QString &str)
   {
   //注意这几行代码的顺序不能乱,否则会造成多次替换
   str.replace("&","&amp;");     
   str.replace(">","&gt;");
   str.replace("<","&lt;");
   str.replace("\"","&quot;");
   str.replace("\'","&#39;");
   str.replace(" ","&nbsp;");
   str.replace("\n","<br>");
   str.replace("\r","<br>");
    }
    2.根据html标记语言,将QString转化。
    void stringToHtml(QString &str,QColor crl)
    {
     QByteArray array;
     array.append(crl.red());
     array.append(crl.green());
     array.append(crl.blue());
     QString strC(array.toHex());
     str = QString("<span style=\" color:#%1;\">%2</span>").arg(strC).arg(str));
     }
     3.尽情使用转换成功后的QString吧。
     例如在你的TextBrowser中添加如下彩色文字。
     QString str(" < Hello Qt!>\n");
     QColor  clrR(255,0,0);
     stringToHtmlFilter(str);
     stringToHtml(str,clrR);
     m_TextBrowser->insertHtml(str);
    二、添加图片
    1.由于图片没有特殊字符的问题,所以实现起来很容易。先使用如下函数将图片路径转换为html
    void imgPathToHtml(QString &path)
    {
         path = QString("<img src=\"%1\"/>").arg(path);
    }
    2.在你的TextBrowser中添加html
    //这里的path既可以是qrc路径,也可以是本地路径
    QString imgPath = QString("D:/img/hello.png");
    imgPathToHtml(imgPath);
    m_TextBrowser->insertHtml(imgPath);
 
    PS:有了以上准备,我的iCute多功能串口调试助手就可以升级了,修复之前使用彩色文字后,特殊字符无法显示的问题。
       修复自动发送,与发送后清空矛盾的问题。
       添加发送接收计数功能。
       新版本即将推出,敬请期待。
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
QTextEdit添加图片,可以使用QTextCursor类来设置光标位置并插入图片。下面是一个示例代码: ```python from PyQt5.QtWidgets import QTextEdit from PyQt5.QtGui import QTextCursor, QTextImageFormat, QImage class MyTextEdit(QTextEdit): def __init__(self, parent=None): super().__init__(parent) def insertImage(self, imagePath, width=100, height=100): cursor = self.textCursor() image = QImage(imagePath) imageFormat = QTextImageFormat() imageFormat.setWidth(width) imageFormat.setHeight(height) imageFormat.setName(imagePath) cursor.insertImage(imageFormat) ``` 在上面的代码中,我们定义了一个MyTextEdit类,它继承自QTextEdit。我们添加了一个名为insertImage的方法,该方法接受一个图像路径和图像大小,并将图像插入到当前光标位置。在方法中,我们使用QTextCursor类获取当前光标位置,并使用QTextImageFormat类设置插入的图像的大小和名称。最后,我们调用insertImage方法将图像插入到光标位置。 你可以使用以下代码来测试MyTextEdit类: ```python from PyQt5.QtWidgets import QApplication, QMainWindow import sys if __name__ == '__main__': app = QApplication(sys.argv) mainWindow = QMainWindow() textEdit = MyTextEdit() mainWindow.setCentralWidget(textEdit) mainWindow.show() textEdit.insertImage('image.png', 200, 200) sys.exit(app.exec_()) ``` 在上面的代码中,我们创建了一个主窗口,并将MyTextEdit实例设置为中央窗口部件。我们还在MyTextEdit实例中插入了一个200x200像素的图像。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值