【问题标题】:Customizing the checkboxes of the items of a QTreeView自定义 QTreeView 项目的复选框
【发布时间】:2012-03-22 17:12:43
【问题描述】:

我遇到以下情况:我需要创建一个自定义树控件,其复选框也是自定义的。我通过使用样式表轻松地对树控件进行了大部分自定义;我已经成功地为 QTreeView 的项目添加了复选框,但是我在自定义它们时遇到了很大的问题 - 我需要为选中状态显示一个自定义图像,另一个为未选中状态显示。

我得出的结论是在我的 QStyledItemDelegate 的子类中,在绘制事件中(即 CheckBoxItemDelegate::paint)。我需要的是显示项目的文本、图标和复选框。但问题是:
- 我无法获得项目的样式(我使用样式表设置) - 否则我的文本可能会以不正确的颜色绘制;
- 我不知道每个子项的矩形(复选框、图标、文本);
- 我不知道如何获取一个项目的图标(给定它的 QModelIndex)来绘制它。

附:我对 QTreeView 进行了子类化(显然),并且在使用 QFileSystemModel 时,我也对它进行了子类化,以便向其中添加复选框功能。

有人可以帮帮我吗? QStyledItemDelegate::paint 是更改树项目复选框视觉效果的正确位置吗?如果是,请给我一个小例子或其他东西,我该怎么做?

【问题讨论】:

    标签: qt checkbox customization


    【解决方案1】:

    这就是我在 QTreeView 中使用两个图像(睁眼/闭眼,以表示它们的可见性状态)而不是复选框来呈现可检查项目的方式:

    ui.myTreeView->setStyleSheet(
        "QTreeView::indicator:unchecked {image: url(:/icons/eye_grey.png);}"
        "QTreeView::indicator:checked {image: url(:/icons/eye.png);}"
      );
    

    当然,项目应该设置为可检查。希望这会有所帮助。

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2013-06-21
      • 2011-12-31
      • 2011-04-03
      • 2013-09-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多