基于QML的QSpinBox与QSlider控件同步

本文介绍了如何在Qt环境中创建一个QtWidgetsApplication工程,并使用QML设计界面,将QSpinBox、QSlider和QVBoxLayout控件进行布局。接着,设置了窗口标题和控件的默认值,并通过信号槽机制实现了QSpinBox与QSlider之间值的同步更新,确保用户在任一控件中更改值时,其他控件会相应地更新显示。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.创建Qt Widgets Application工程

 2.编辑.ui文件打开QML设计界面

3.向设计界面拖放QSpinBox,QSlider,QVBoxLayout控件如下

 

4.修改窗口标题

 this->setWindowTitle("基于QML的QSpinBox与QSlider控件同步");

 5.修改控件默认值

 ui->spinBox->setRange(0,100);
    ui->horizontalSlider->setRange(0,100);
    ui->verticalSlider->setRange(0,100);

6.关联控件信号

 //关联控件之间信号
    connect(ui->spinBox,SIGNAL(valueChanged(int)),ui->horizontalSlider,SLOT(setValue(int)));
    connect(ui->spinBox,SIGNAL(valueChanged(int)),ui->verticalSlider,SLOT(setValue(int)));
    connect(ui->horizontalSlider,SIGNAL(valueChanged(int)),ui->spinBox,SLOT(setValue(int)));
    connect(ui->verticalSlider,SIGNAL(valueChanged(int)),ui->spinBox,SLOT(setValue(int)));

演示效果

 完整源码

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);//任何通过代码修改UI界面值必须在调用setupUi之后,不然不会生效
    this->setWindowTitle("基于QML的QSpinBox与QSlider控件同步");
    ui->spinBox->setRange(0,100);
    ui->horizontalSlider->setRange(0,100);
    ui->verticalSlider->setRange(0,100);

    //关联控件之间信号
    connect(ui->spinBox,SIGNAL(valueChanged(int)),ui->horizontalSlider,SLOT(setValue(int)));
    connect(ui->spinBox,SIGNAL(valueChanged(int)),ui->verticalSlider,SLOT(setValue(int)));
    connect(ui->horizontalSlider,SIGNAL(valueChanged(int)),ui->spinBox,SLOT(setValue(int)));
    connect(ui->verticalSlider,SIGNAL(valueChanged(int)),ui->spinBox,SLOT(setValue(int)));

    //设置默认值
    ui->spinBox->setValue(20);

}

MainWindow::~MainWindow()
{
    delete ui;
}

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

自由软件开发者

有你的鼓励,我会更加努力。

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

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

打赏作者

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

抵扣说明:

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

余额充值