翻譯|使用教程|編輯:龔雪|2024-07-11 14:55:20.870|閱讀 115 次
概述:本文將為大家介紹如何使用Qt Widget小部件如何實現一個滑動條示例,歡迎下載最新版組件體驗~
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
Qt 是目前最先進、最完整的跨平臺C++開發工具。它不僅完全實現了一次編寫,所有平臺無差別運行,更提供了幾乎所有開發過程中需要用到的工具。如今,Qt已被運用于超過70個行業、數千家企業,支持數百萬設備及應用。
滑動條示例展示了如何使用Qt中可用的不同類型的滑動條:, 和 。
Qt提供了三種類似滑動條的小部件:QSlider、QScrollBar和QDial,它們都繼承了QAbstractSlider的大部分功能,并且理論上可以在應用程序中相互替換,因為差異只涉及它們的外觀和樣式。這個例子展示了它們是什么樣子的,它們是如何工作的,以及如何通過它們的屬性來操縱它們的操作和外觀。
Qt技術交流群:166830288 歡迎一起進群討論
本示例還演示了如何使用信號和槽來同步兩個或多個小部件的操作,以及如何覆蓋resizeEvent()來實現響應式布局。
在上文中(點擊這里回顧>>),我們主要為大家介紹了Window類定義、Window類實現等,本文將繼續介紹SlidersGroup類的定義和實現。
class SlidersGroup : public QGroupBox { Q_OBJECT public: SlidersGroup(const QString &title, QWidget *parent = nullptr); signals: void valueChanged(int value); public slots: void setValue(int value); void setMinimum(int value); void setMaximum(int value); void invertAppearance(bool invert); void invertKeyBindings(bool invert); void setOrientation(Qt::Orientation orientation); private: QSlider *slider; QScrollBar *scrollBar; QDial *dial; QBoxLayout *slidersLayout; };
SlidersGroup類繼承自,它提供了一個框架和一個標題,并包含一個、一個 和一個。
我們提供了一個valueChanged()信號和一個公共setValue()槽,其功能與QAbstractSlider和QSpinBox中的相同。此外,我們還實現了其他幾個公共槽來設置最小值和最大值,并反轉滑塊小部件的外觀以及鍵綁定,并設置方向。
SlidersGroup::SlidersGroup(const QString &title, QWidget *parent) : QGroupBox(title, parent) { slider = new QSlider; slider->setFocusPolicy(Qt::StrongFocus); slider->setTickPosition(QSlider::TicksBothSides); slider->setTickInterval(10); slider->setSingleStep(1); scrollBar = new QScrollBar; scrollBar->setFocusPolicy(Qt::StrongFocus); dial = new QDial; dial->setFocusPolicy(Qt::StrongFocus);
首先我們創建具有適當屬性的類似滑塊的小部件,我們為每個小部件設置焦點策略。是一個枚舉類型,它定義了小部件在獲取鍵盤焦點方面可以具有的各種策略,策略意味著小部件通過tab和click來接受焦點。
connect(slider, &QSlider::valueChanged, scrollBar, &QScrollBar::setValue); connect(scrollBar, &QScrollBar::valueChanged, dial, &QDial::setValue); connect(dial, &QDial::valueChanged, slider, &QSlider::setValue); connect(dial, &QDial::valueChanged, this, &SlidersGroup::valueChanged);
然后我們將這些小部件彼此連接起來,這樣當其中一個小部件的當前值發生變化時,它們將保持同步。
將dial的valueChanged()信號連接到SlidersGroup的valueChanged()信號,來將更改的值通知應用程序中的其他小部件(即控件小部件)。
slidersLayout = new QBoxLayout(QBoxLayout::LeftToRight); slidersLayout->addWidget(slider); slidersLayout->addWidget(scrollBar); slidersLayout->addWidget(dial); setLayout(slidersLayout); }
最后為組框內的滑塊小部件創建布局,從滑塊的水平排列開始。
void SlidersGroup::setValue(int value) { slider->setValue(value); }
setValue()槽設置QSlider的值,我們不需要在QScrollBar和QDial小部件上顯式地調用setValue(),因為QSlider將在其值發生變化時發出valueChanged()信號,從而觸發多米諾骨牌效應。
void SlidersGroup::setMinimum(int value) { slider->setMinimum(value); scrollBar->setMinimum(value); dial->setMinimum(value); } void SlidersGroup::setMaximum(int value) { slider->setMaximum(value); scrollBar->setMaximum(value); dial->setMaximum(value); }
setMinimum()和setMaximum()槽被Window類用來設置QSlider、QScrollBar和QDial小部件的范圍。
void SlidersGroup::invertAppearance(bool invert) { slider->setInvertedAppearance(invert); scrollBar->setInvertedAppearance(invert); dial->setInvertedAppearance(invert); } void SlidersGroup::invertKeyBindings(bool invert) { slider->setInvertedControls(invert); scrollBar->setInvertedControls(invert); dial->setInvertedControls(invert); }
invertAppearance()和invertKeyBindings()插槽控制子部件的和屬性。
void SlidersGroup::setOrientation(Qt::Orientation orientation) { slidersLayout->setDirection(orientation == Qt::Horizontal ? QBoxLayout::TopToBottom : QBoxLayout::LeftToRight); scrollBar->setOrientation(orientation); slider->setOrientation(orientation); }
setOrientation()插槽控制布局的方向和滑塊的方向,在水平組中,滑塊具有水平方向,并且彼此堆疊在一起。在垂直組中,滑塊具有垂直方向,并且彼此相鄰布局。
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn