Qt去除控件虚线框的两种方法

在显示Qt Widget的控件时,经常遇到控件周围有虚线框的情况,很是影响软件的美观。下面有两种方法解决这个问题。

1、设置控件的样式进行设置

QWidget:focus {
    outline: none;
}

这种方法有时候使得控件失去样式,我们可以设置对应的控件样式为 outline:none;

2、让QApplication设置一个继承自QProxyStyle的类。

继承 QProxyStyle,QStyle::PE_FrameFocusRect 时不绘制虚线框,main() 函数里调用 QApplication::setStyle() 使用新的样式:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// 文件名: NoFocusRectStyle.h

#ifndef NOFOCUSRECTSTYLE_H
#define NOFOCUSRECTSTYLE_H

#include <QProxyStyle>

class NoFocusRectStyle : public QProxyStyle {
public:
    NoFocusRectStyle(QStyle *baseStyle) : QProxyStyle(baseStyle) {}

    void drawPrimitive(PrimitiveElement element,
                       const QStyleOption *option,
                       QPainter *painter,
                       const QWidget *widget = 0) const {
        if (element == QStyle::PE_FrameFocusRect) {
            return;
        }

        QProxyStyle::drawPrimitive(element, option, painter, widget);
    }
};

#endif // NOFOCUSRECTSTYLE_H

当 element == QStyle::PE_FrameFocusRect 时,直接返回,不绘制虚线框。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// 文件名: main.cpp

#include "Widget.h"
#include "NoFocusRectStyle.h"
#include <QApplication>

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);
    NoFocusRectStyle *style = new NoFocusRectStyle(app.style());
    app.setStyle(style); // Ownership of the style object is transferred to QApplication

    Widget w;
    w.show();

    return app.exec();
}

在 main() 函数中调用 app.setStyle(style) 使用我们上面自定义的 NoFocusRectStyle 就可以把虚线框去掉了。

转载地址:http://qtdebug.com/qt-no-focus-rect/

`QTableView` 是 Qt 库中的一个用于显示表格数据的组件。默认情况下,当用户选择某个单元格时,会有一条虚线显示选中区域。若想移除这一效果,可以通过修改 `QTableView` 的样式表 (style sheet) 来达到目的。 以下是通过设置样式表来移除选中项虚线的步骤: ### 步骤 1: 获取 QTableView 实例 首先,你需要有一个 `QTableView` 实例。假设这个实例已经存在于你的界面中,并命名为 `tableView`。 ```cpp QTableView *tableView = // ... 初始化你的 QTableView 代码 ``` ### 步骤 2: 设置样式表 接着,你可以通过以下代码设置样式表来移除虚线: ```cpp QString styleSheet = "QTableView::item:selected { border: none; }"; tableView->setStyleSheet(styleSheet); ``` 在这个样式表中,我们使用了 CSS 类型的选择符 `QTableView::item:selected`。这里的 `::` 表示这是一个内部选择符,它指定的是特定元素的子元素。在此处,`::item` 指定了 `QTableView` 中的每个项目 (`QTableWidget::item`) 被选择时的行为。然后我们设置了边属性 `border` 为空字符串 `""`,以此来移除被选择项的边。 ### 步骤 3: 确保样式有效应用 为了确保你的样式改变能立即生效并应用到所有后续的操作上,你可以在应用或者重绘视图的时候直接设置样式表。如果需要在运行时动态更新,可以考虑在信号槽连接中完成此操作,例如 `tableView->selectionChanged()` 信号。 ### 相关问题: 1. **如何自定义 QTableView 的行高和列宽?** - 可以通过设置 `horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch)` 和 `verticalHeader()->setDefaultSectionSize(高度值)` 来调整宽度和行高。 2. **QTableView 如何添加垂直滚动条?** - 默认情况下,`QTableView` 就有垂直滚动条。若未自动出现,可以检查控件布局是否限制其可见性,或者代码中是否存在错误导致其未正常加载。 3. **如何禁用 QTableView 的编辑功能?** - 通过设置 `tableView->setEditTriggers(QAbstractItemView::NoEditTriggers);` 来关闭编辑触发机制即可。 通过上述方法,你可以有效地控制 `QTableView` 的外观,包括移除选中项的虚线
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值