8

是否可以显示 QSlider 的最小值、最大值和当前选定值?当然我可以用标签来显示这个,但我认为QSlider中一定有这种可能性

4

3 回答 3

10

你有两个选择..

1)正如评论中提到的 - 子类

2) 使用 QSlider 作为级添加任意数量的 QLabel ,在 QSlider 上安装 eventHandler() 以捕获调整大小事件以正确定位它们,并且显然处理滚动事件,因此您可以更新它们......所以标签将浮动QSlider 顶部

于 2013-08-22T15:26:04.797 回答
8

这是我快速实现一个花哨的滑块,它是 qslider 的子类,用于将滑块句柄下方的当前值显示到工具提示中。

标题

#ifndef FANCYSLIDER_H
#define FANCYSLIDER_H

#include <QSlider>

class FancySlider : public QSlider
{
    Q_OBJECT
public:
    explicit FancySlider(QWidget *parent = 0);
    explicit FancySlider(Qt::Orientation orientation, QWidget *parent = 0);

protected:
    virtual void sliderChange(SliderChange change);
};

#endif // FANCYSLIDER_H

Cpp

#include "FancySlider.h"

#include <QStyleOptionSlider>
#include <QToolTip>

FancySlider::FancySlider(QWidget * parent)
    : QSlider(parent)
{
}

FancySlider::FancySlider(Qt::Orientation orientation, QWidget * parent)
    : QSlider(orientation, parent)
{
}

void FancySlider::sliderChange(QAbstractSlider::SliderChange change)
{
    QSlider::sliderChange(change);

    if (change == QAbstractSlider::SliderValueChange )
    {
        QStyleOptionSlider opt;
        initStyleOption(&opt);

        QRect sr = style()->subControlRect(QStyle::CC_Slider, &opt, QStyle::SC_SliderHandle, this);
        QPoint bottomRightCorner = sr.bottomLeft();

        QToolTip::showText(mapToGlobal( QPoint( bottomRightCorner.x(), bottomRightCorner.y() ) ), QString::number(value()), this);
    }
}
于 2017-02-10T13:17:06.137 回答
2

这是我的实现,没有子类化。实例化一个带有右侧标签的滑块,显示滑块的当前值:

QWidget *tmpW1 = new QWidget(this);
QHBoxLayout *tmpH1 = new QHBoxLayout(this);
QLabel *tmpLabel = new QLabel("0");

QSlider *tmpSlider = new QSlider(Qt::Horizontal, this);
tmpSlider->setMinimum(0);
tmpSlider->setMaximum(10);
tmpSlider->setValue(5);

tmpH1->addWidget(tmpSlider);
tmpH1->addWidget(tmpLabel);
tmpW1->setLayout(tmpH1);

QObject::connect(tmpSlider, &QSlider::valueChanged, this, [=] () {
    tmpLabel->setText(QString::number(tmpSlider->value()));
});
于 2020-01-02T10:28:19.070 回答