您可以使用树视图的setItemDelegate 方法为您的树视图项目设置自定义绘制过程。在 deligate 的绘制方法中,您可以从项目选项中删除 QStyle::State_HasFocus 样式并执行基本绘制例程。下面是一个例子,不好意思是c++。
...
NoFocusDelegate* delegate = new NoFocusDelegate();
ui->treeView->setItemDelegate(delegate);
...
class NoFocusDelegate : public QStyledItemDelegate
{
protected:
void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const;
};
void NoFocusDelegate::paint(QPainter* painter, const QStyleOptionViewItem & option, const QModelIndex &index) const
{
QStyleOptionViewItem itemOption(option);
if (itemOption.state & QStyle::State_HasFocus)
itemOption.state = itemOption.state ^ QStyle::State_HasFocus;
QStyledItemDelegate::paint(painter, itemOption, index);
}
update0: 使用自定义 QStyle 对象移除 QFocusFrame,使其不会被 TReeView 淹没。下面是应用于应用程序对象的自定义 QMotifStyle 样式后代(我猜在您的情况下我猜它应该是 QMacStyle 后代)的示例。每当检测到 qtreeview 小部件时,它都不会进行任何框架矩形绘制
class MyStyle1 : public QMotifStyle
{
public:
MyStyle1()
{
//???
}
void drawControl(ControlElement element, const QStyleOption* option, QPainter* painter, const QWidget* widget = 0 ) const
{
if (element==CE_FocusFrame)
{
const QFocusFrame* frame = qobject_cast<const QFocusFrame*>(widget);
if (frame && frame->widget())
{
QTreeView* treeView = qobject_cast<QTreeView*>(frame->widget());
if (treeView)
{
qDebug() << "no CE_FocusFrame for QFocusFrame over QTreeViews";
return;
}
}
}
QMotifStyle::drawControl(element, option, painter, widget);
}
};
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QCDEStyle style;
a.setStyle(new MyStyle1());
//a.setStyle(new QMotifStyle());
MainWindow w;
w.show();
return a.exec();
}
希望这会有所帮助,问候