QSlider禁止点击 和精准点击跳转

1. 禁止点击

QSlider默认点击行为是点击一下,进行page step的进度跳转。所以可以使用这个方式实现禁止点击跳转。

方式一:

cpp 复制代码
 setPageStep(0);

方式二:

重写mousePressEvent函数

cpp 复制代码
void ProgressSlider::mousePressEvent(QMouseEvent *event) {
        // 获取点击触发前的值
        const int value = this->value();
        // 调用父类的鼠标点击处理事件
        QSlider::mousePressEvent(event);
        setValue(value);
}

这样子就禁止点击了,但是还是支持鼠标拖动。

2. 精准点击跳转

精准点击跳转需要重写 QSlider::mousePressEvent 事件函数,但是鼠标拖动的时候,按下瞬间也会有这个事件。

cpp 复制代码
void ProgressSlider::mousePressEvent(QMouseEvent *event) {

    /*
    //获取当前点击位置,得到的这个鼠标坐标是相对于当前QSlider的坐标
    int currentX = event->pos().x();
    //获取当前点击的位置占整个Slider的百分比
    double per = currentX * 1.0 / this->width();
    //利用算得的百分比得到具体数字
    // int value = per * (this->maximum() - this->minimum()) +
    this->minimum();*/

    // 注意应先调用父类的鼠标点击处理事件,这样可以不影响拖动的情况
    // 滑动条移动事件等事件也用到了mousePressEvent,加这句话是为了不对其产生影响,是的Slider能正常相应其他鼠标事件
    QSlider::mousePressEvent(event);

    if (!this->isSliderDown()) {
        int value = QStyle::sliderValueFromPosition(minimum(), maximum(),
                                                    event->pos().x(), width());
        // 设定滑动条位置
        this->setValue(value);
        qDebug() << "mousePressEvent emit sliderChanged" << value;
        emit sliderChanged(value);
    }
}

所以就是在鼠标没按下------单个点击的时候------根据坐标跳转。

QStyle::sliderValueFromPosition根据当前鼠标位置与slider的宽度按比例计算当前值。作用同前面注释代码一致。

鼠标拖动完毕的事件应该在sliderReleased信号槽中去处理。

相关推荐
雪的季节7 小时前
企业级 Qt 全功能项目
开发语言·数据库·qt
努力努力再努力wz16 小时前
【Qt入门系列】:QLabel控件详解:从文本显示到图片展示,再到内容布局与伙伴机制
android·开发语言·数据结构·数据库·c++·qt·mysql
郝学胜-神的一滴17 小时前
Qt 高级开发 016:半内存管理机制
开发语言·c++·qt·程序人生·用户界面
香菇滑稽之谈18 小时前
VSCode配置QT环境
ide·vscode·qt
雪的季节18 小时前
Qt pro 多项目、子目录、多层级配置(超级详细 + 实战模板)
qt
郝学胜-神的一滴18 小时前
Qt 高级开发 020:水平布局手写代码实战
开发语言·c++·qt·系统架构·软件构建·用户界面
机器视觉知识推荐、就业指导1 天前
Qt6 + QCustomPlot 实时曲线 Demo ,适合串口与上位机项目
qt
YY&DS1 天前
Qt 嵌入 CEF 在 Linux 下必须设置 `QT_XCB_GL_INTEGRATION=xcb_egl才能加载网页
linux·开发语言·qt
秋田君2 天前
Qt 5.12.8 下载与安装教程(附网盘资源)
开发语言·qt
郝学胜-神的一滴2 天前
Qt 高级开发 019:从零定制登录窗口按钮、Logo 样式与交互悬浮效果
开发语言·c++·qt·程序人生·交互·用户界面