QT:QTableView,QCheckBox、QMenu富文本上标

2023-11-03 19:40

本文主要是介绍QT:QTableView,QCheckBox、QMenu富文本上标,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

嗯,第一次,稍微有点紧张,写的不好希望大佬不要批评我,会伤心的
相信上标这个简单而不简单的问题一定难道了不少像我一样想用简单方式,尝试通过Word、WPS里面的字符进行实现的傻缺。
话不多说,我们进入正题。

QTableView和QTableWidget方法一样,所以我只讲QTableWidget

说道QTableWidget我们肯定需要一个QTableWidget来做这个东西先随便建一个QTableWidget

然后进入正题,对于QTableWidget\QTableView我们需要用到QItemDelegate代理来进行绘制,这样可以节省很多时间,但是由于QTableView和QTableWiget的表头是独立的QHeadView而且代理设置是不生效的可以查阅QT表中的说明可知As a result, calling a header's setItemDelegate() function will have no effect.因此我们QHeadView只能从他本身的绘制事件入手

然后贴上代码:

#ifndef TOPRICH_H
#define TOPRICH_H#include <QTableView>
#include <QHeaderView>
#include <QCheckBox>
#include <QItemDelegate>
#include <QTableWidgetItem>class RichEditDelegate: public QItemDelegate
{Q_OBJECT
public :RichEditDelegate(QObject*parent=nullptr):QItemDelegate(parent){}void paint(QPainter*painter, const QStyleOptionViewItem&option, const QModelIndex&index) const;
private :
};class HeaderView : public QHeaderView
{Q_OBJECT
public:HeaderView(Qt::Orientation orientation, QWidget *parent = Q_NULLPTR):QHeaderView(orientation, parent){}HeaderView(QHeaderView tb):QHeaderView(tb.orientation()){}void paintSection(QPainter *painter, const QRect &rect, int logicalIndex) const;};
#endif // TOPRICH_H
#include "TopRich.h"
#include <QDebug>
#include <QTextDocument>
#include <QtWidgets/QApplication>
#include <QStylePainter>
#include <QAbstractTextDocumentLayout>
#include <QStyleOptionViewItem>
#include <QPainter>void RichEditDelegate::paint(QPainter*painter, const QStyleOptionViewItem&option, const QModelIndex&index) const
{QStyleOptionViewItem viewOption(option);if (option.state.testFlag(QStyle::State_HasFocus))viewOption.state = viewOption.state ^ QStyle::State_HasFocus;QStyle *pStyle = viewOption.widget? viewOption.widget->style() : QApplication::style();QString strHTML = QString("");strHTML = index.model()->data(index, Qt::DisplayRole).toString();QRect textRect = pStyle->subElementRect(QStyle::SE_ItemViewItemText, &viewOption);QFont fontDefault;int fwidth = QFontMetrics(fontDefault).width(strHTML);if(fwidth>textRect.width()){//此处是为了进行换行QString str;for(QString::iterator iter = strHTML.begin(); iter!=strHTML.end(); ++iter){str += *iter;fwidth = QFontMetrics(fontDefault).width(str);if(fwidth>textRect.width()-8){if(str.indexOf("\n") == -1){if((*iter) != '-' && *(++iter) != 's'){str += '\n';--iter;}else{str += *iter;str += '\n';}}for(++iter;iter!=strHTML.end();++iter)str += *iter;break;}}strHTML = str;}strHTML.replace("/s", "<sup>-s</sup>");strHTML.replace("\n","<br>");QTextDocument doc;doc.setHtml(strHTML);QAbstractTextDocumentLayout::PaintContext paintContext;if((option.state & QStyle::State_Selected) == QStyle::State_Selected){drawBackground(painter, viewOption, index);}painter->save();// 坐标变换,将左上角设置为原点painter->translate(textRect.topLeft());// 设置HTML绘制区域painter->setClipRect(textRect.translated(-textRect.topLeft()));doc.documentLayout()->draw(painter, paintContext);painter->restore();}
//----------------------------------------------------------------------------------------------------------------------------
void HeaderView::paintSection(QPainter *painter, const QRect &rect, int logicalIndex) const
{QAbstractItemModel * mo = model();QVariant hData = mo->headerData(logicalIndex, Qt::Horizontal);QString hDataStr = hData.toString();if(hDataStr.contains("<sup>") || hDataStr.contains("/s")){//设置显示文本为空,使用默认样式QStyleOptionHeader viewOption;initStyleOption(&viewOption);QStyle * pStyle = style();viewOption.rect = rect;viewOption.text = "";pStyle->drawControl(QStyle::CE_Header, &viewOption, painter);//需要显示的HTMLQString strHTML = QString(hDataStr);QRect textRect = pStyle->subElementRect(QStyle::SE_HeaderLabel, &viewOption);QPoint textPoint= textRect.topLeft();textPoint.setX(textPoint.x());strHTML.replace("/s","<sup>-s</sup>");strHTML.replace("\n","<br>");//qDebug() << "HeaderView::paintSection -- fwidth:" << strHTML;QTextDocument doc;doc.setHtml(strHTML);QAbstractTextDocumentLayout::PaintContext paintContext;painter->save();//坐标变换,将左上角设置为原点painter->translate(textPoint);//设置HTML绘制区域painter->setClipRect(textRect.translated(-textPoint));doc.documentLayout()->draw(painter, paintContext);painter->restore();}else{painter->save();QHeaderView::paintSection(painter, rect, logicalIndex);painter->restore();}updatesEnabled();
}

最后简单的调用设置

ui->tableWidget->setItemDelegateForRow(0,new RichEditDelegate);    
ui->tableWidget->setHorizontalHeader(new HeaderView(ui->tableWidget->horizontalHeader()->orientation()));

见证奇迹的时候到了

整个解决方法中核心的地方就在于QT支持两种文本一个是PlainText一个是RichText,而RichText可以支持Html格式字符,所以我们在重载的时候就需要按照Html的格式进行修改,另一个就是需要了解Qt控件的绘图机制,QStyle的原理。了解以上之后,QMenu设置上标的方法就很简单了。附上代码:

void TopStyle::drawControl(ControlElement element, const QStyleOption *option, QPainter *painter, const QWidget *widget) const
{if(element == QStyle::CE_MenuItem){if(const QStyleOptionMenuItem * btn = qstyleoption_cast<const QStyleOptionMenuItem *>(option)){QStyleOptionMenuItem suopt = *btn;QString strHTML = suopt.text;suopt.text = "";QProxyStyle::drawControl(element, &suopt, painter, widget);strHTML.replace("/s", "<sup>-s</sup>");QTextDocument doc;doc.setHtml(strHTML);QAbstractTextDocumentLayout::PaintContext paintContext;painter->save();//坐标转换QPoint textPoint = suopt.rect.topLeft();textPoint.setX(textPoint.x()+30);painter->translate(textPoint);painter->setClipRect(suopt.rect.translated(-textPoint));doc.documentLayout()->draw(painter, paintContext);painter->restore();}}elsereturn QProxyStyle::drawControl(element, option, painter, widget);
}

重载QProxyStyle然后设置QMenu的style就行了。
感谢浏览,写的不好,希望不要计较,共同进步!

这篇关于QT:QTableView,QCheckBox、QMenu富文本上标的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/340447

相关文章

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

VS配置好Qt环境之后但无法打开ui界面的问题解决

《VS配置好Qt环境之后但无法打开ui界面的问题解决》本文主要介绍了VS配置好Qt环境之后但无法打开ui界面的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目UKeLvb录找到Qt安装目录中designer.UKeLvBexe的路径找到vs中的解决方案资源

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可

Qt之QMessageBox的具体使用

《Qt之QMessageBox的具体使用》本文介绍Qt中QMessageBox类的使用,用于弹出提示、警告、错误等模态对话框,具有一定的参考价值,感兴趣的可以了解一下... 目录1.引言2.简单介绍3.常见函数4.按钮类型(QMessage::StandardButton)5.分步骤实现弹窗6.总结1.引言

Qt中Qfile类的使用

《Qt中Qfile类的使用》很多应用程序都具备操作文件的能力,包括对文件进行写入和读取,创建和删除文件,本文主要介绍了Qt中Qfile类的使用,具有一定的参考价值,感兴趣的可以了解一下... 目录1.引言2.QFile文件操作3.演示示例3.1实验一3.2实验二【演示 QFile 读写二进制文件的过程】4.

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

PyQt6/PySide6中QTableView类的实现

《PyQt6/PySide6中QTableView类的实现》本文主要介绍了PyQt6/PySide6中QTableView类的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录1. 基本概念2. 创建 QTableView 实例3. QTableView 的常用属性和方法

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Qt中QGroupBox控件的实现

《Qt中QGroupBox控件的实现》QGroupBox是Qt框架中一个非常有用的控件,它主要用于组织和管理一组相关的控件,本文主要介绍了Qt中QGroupBox控件的实现,具有一定的参考价值,感兴趣... 目录引言一、基本属性二、常用方法2.1 构造函数 2.2 设置标题2.3 设置复选框模式2.4 是否