【发布时间】:2014-07-19 06:30:51
【问题描述】:
当QTableView 编辑控件对当前项目可见时,编辑的样式表就会发生。当QTableView 中没有活动的编辑控件时,当前项使用QTableView { selection-background-color: } 设置样式如何仅为当前项设置不同的样式?
【问题讨论】:
标签: qt qt5 qtableview qtstylesheets
当QTableView 编辑控件对当前项目可见时,编辑的样式表就会发生。当QTableView 中没有活动的编辑控件时,当前项使用QTableView { selection-background-color: } 设置样式如何仅为当前项设置不同的样式?
【问题讨论】:
标签: qt qt5 qtableview qtstylesheets
1。正如 IGHOR 所说,您可以在模型中使用 data() 方法并在角色为 Qt::BackgroundColor 时提供颜色。但是这里有一个绊脚石,因为您不知道 index 是否是最新的。您应该在模型更改时在模型中设置一个当前索引,然后进行如下检查:
if (index == m_currentIndex and role==Qt::BackgroundRole) return Qt::black;
实际上,根据模型/视图模式告诉模型currentIndex并不是最好的主意,因为一个模型可以有两个视图。
2。 QAbstractItemView 的后代有方法 setItemDelegate。委托用于绘制单元格。
您只需要从 QStyledItemDelegate 继承,将指向视图的指针传递给委托并覆盖方法 initStyleOption。
然后做这样的事情:
void MyStyledItemDelegate::initStyleOption(QStyleOptionViewItem *option,
const QModelIndex &index) const
{
QStyledItemDelegate::initStyleOption(option, index);
QStyleOptionViewItemV4 *v4 = qstyleoption_cast<QStyleOptionViewItemV4 *>(option);
if (index == view()->currentIndex())
{
v4->backgroundBrush = QBrush(Qt::grey);
}
}
3。 如果你真的需要使用 css(例如你有主题)你可以这样做:
在你的css文件中添加这样的东西:
QTableView
{
qproperty-currentItemBackground: #cccccc;
}
修改上例中的 initStyleOption 以使用该属性:
v4->backgroundBrush = view()->property("currentItemBackground").toColor();
使用这种方法,您可以通过 css 为列、行、单个单元格或一组单元格设置特定样式。
【讨论】:
您需要创建一个新的委托,它根据数据模型(例如自定义角色)呈现自身。您需要将其样式基于为此目的而创建的特殊控件(可以通过样式表进行更改)。有时间我会贴一些代码。
可以使用可变参数模板,并且crtp(Coplien)对layer one的delegate有很好的效果
【讨论】:
Qt 样式表支持子控件和伪状态,您可以使用它来改进您的自定义。 (见http://qt-project.org/doc/qt-5/stylesheet-reference.html#list-of-pseudo-states)
在这种情况下,您可以使用::item 子控件和:focus 伪状态(“当前”伪状态不存在,但:focus 也是如此)。
这是一个您可以使用的示例:
QTableView::item:focus
{
selection-background-color: yellow;
}
另见http://qt-project.org/doc/qt-5/stylesheet-examples.html#customizing-qtreeview
【讨论】: