Qt QTableView – 使用IsUserCheckable时对齐复选框

Qt QTableView – 使用IsUserCheckable时对齐复选框,第1张

概述我正在使用Qt :: ItemIsUserCheckable的QTableView复选框标志来显示表格单元格中的复选框. 在读取了一些对齐的东西以试图将复选框置于单元格中心之后,我将Qt :: AlignCenter作为TextAlignmentRole从models data()函数返回. QVariant ExampleModel::data(const QModelIndex &index, 我正在使用Qt :: ItemIsUserCheckable的QtableVIEw复选框标志来显示表格单元格中的复选框.

在读取了一些对齐的东西以试图将复选框置于单元格中心之后,我将Qt :: AlignCenter作为TextAlignmentRole从models data()函数返回.

QVariant ExampleModel::data(const QModelindex &index,int role) const {  if(!index.isValID())     return QVariant();  if (role == Qt::TextAlignmentRole)        return Qt::AlignCenter | Qt::AlignVCenter;}

但是这并没有对齐我的复选框.

有谁知道如何对齐复选框是这种模式?

解决方法 在对委托选项进行进一步调查之后,我发现了一个不错的引用(遗憾的是不再可用),并使用QItemDelegate和IsUserCheckable提出了以下混合.

本质上,您需要扩展QItemDelegate并重新实现,使用drawCheck函数居中并使用editorEvent处理鼠标和键盘事件,同时使用适当的状态设置模型.

voID drawCheck(QPainter* painter,qstyleOptionVIEwItem const& option,QRect const& rect,Qt::CheckState state) const

bool editorEvent(QEvent *event,qabstractitemmodel *model,const qstyleOptionVIEwItem &option,const QModelindex &index)

另见这个类似的问题here ……

总结

以上是内存溢出为你收集整理的Qt QTableView – 使用IsUserCheckable时对齐复选框全部内容,希望文章能够帮你解决Qt QTableView – 使用IsUserCheckable时对齐复选框所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1134155.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-30
下一篇 2022-05-30

发表评论

登录后才能评论

评论列表(0条)

保存