QTreeView使用总结18:点击空白处取消选中,简单方法

1,简介

前文介绍了通过继承重写mousePressEvent 来实现点击空白处取消选中的方法,有个弊端就是需要继承,为这个简单功能让工程多了2个类文件,感觉不太爽。

后来采用了一种更简单的方法,不需要继承即可实现。

主要就是通过父窗口(如MainWindow)的eventFilter,进行点击过滤处理。

2,代码

在MainWindow构造函数 添加如下代码:

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    ui->treeView->viewport()->installEventFilter(this);
}

在MainWindow.h 添加 eventFilter:

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

protected:
    bool eventFilter(QObject *obj, QEvent *event);

private:
    Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H
bool MainWindow::eventFilter(QObject *obj, QEvent *event)
{
    if (obj == ui->treeView->viewport())
    {
        //点击树的空白,取消选中
        if (event->type() == QEvent::MouseButtonPress)
        {
            if (event->buttons() & Qt::LeftButton)
            {
                QModelIndex index = ui->treeView->indexAt(event->pos());
                if (!index.isValid())
                {
                    ui->treeView->setCurrentIndex(QModelIndex());
                }
            }
        }
    }
    return QObject::eventFilter(obj, event);
}

该函数可响应treeView的左键单击消息,如果点击的内容没有元素,我们就通过

ui->treeView->setCurrentIndex(QModelIndex());

来达到取消选中的效果。

  • 3
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论
好的,以下是一种实现方法: ```cpp // 获取当前选中行的索引 QModelIndexList selectedRows = treeView->selectionModel()->selectedRows(); if (!selectedRows.isEmpty()) { // 获取第一行的索引 QModelIndex firstIndex = selectedRows.first(); int firstRow = firstIndex.row(); // 获取最后一行的索引 QModelIndex lastIndex = selectedRows.last(); int lastRow = qMin(firstRow + 8, lastIndex.row()); // 遍历选中的行 for (int row = firstRow; row <= lastRow; ++row) { QModelIndex index = model->index(row, 0); // 设置选中行及下面8行的背景色 QBrush brush(QColor(0, 0, 255)); treeView->setStyleSheet(QString("QTreeView::item:selected { background-color: blue; }")); treeView->setIndexWidget(index, new QLabel(model->fileName(index))); for (int i = 1; i <= 8; ++i) { QModelIndex childIndex = model->index(row + i, 0, index.parent()); if (childIndex.isValid()) { treeView->setStyleSheet(QString("QTreeView::item:selected { background-color: blue; }")); treeView->setIndexWidget(childIndex, new QLabel(model->fileName(childIndex))); } } } } ``` 这段代码会获取当前选中行的索引列表,然后遍历选中的行并设置它们及下面8行的背景色。在这个例子中,我们使用了QFileSystemModel来管理数据,并使用QBrush和CSS样式设置背景色。同时在每个单元格中添加了一个QLabel小部件,以便在每个单元格中显示数据。请注意,如果要在一个较大的QTreeView中实现这个功能,这种方法可能会影响性能。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

逆枫゛

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值