7. Qt添加滑动条

前言:

添加一个这样的滑条,双方关联自动修改,也提供代码创建方式

技能:

QSpinBox

QSlider

方式一 Qt 的图形化编程(用ui文件,非常简单)

1.Spin Box

首先找到显示数字的这个部分。是input widget->spin box ,如果想用double型的就用下面的double spin box,拖出来一个

2.Slider

同样在input widget->里面最下面有slider,分为水平和垂直两种,看自己需要选择吧,也脱出来个

3.关联

拖出来排好布局

然后关联步骤也简单,只需要记得要两方面互相关联就好了

①VS2022使用Qt designer

直接在右下角的编辑器添加这两个就可以了,或者按照下面的一步一步加是一样的

++另一种添加方式:++不想用编辑器可以按照下面的,效果一样的

进入编辑信号/槽模式

从spin box拖到 slider 一个箭头,选择valuechange(int)到setvalue(int)

再反过来关联一下就好了

这就实现双向关联 ,记得最后保存

② Qt creator

可以和Qt designer 一样操作就好

至于右键转到槽用代码,我觉得不如上面的方便,这里不提供啦

方式二 编程实现

先直接放全代码

这是在Qt creator里面直接代码写出来的,也可以用上面的在ui文件中做出来

cpp 复制代码
#include "widget.h"

#include <QApplication>
#include<QHBoxLayout>
#include<QSpinBox>
#include<QSlider>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    QWidget* window = new QWidget;
    window->setWindowTitle("Tittle");
//创建窗口,设置tittle
    
    QSpinBox* spinBox = new QSpinBox;
    QSlider* slider = new QSlider(Qt::Horizontal);
    spinBox->setRange(0, 100);
    slider->setRange(0, 100);  
//new 出来想要的widget并设置范围,记得头文件包含
    
    QObject::connect(spinBox,SIGNAL(valueChanged(int)),slider,SLOT(setValue(int)));
    QObject::connect(slider,SIGNAL(valueChanged(int)),spinBox,SLOT(setValue(int)));
 //双向关联
    
    spinBox->setValue(22);
// 设置默认值
    
    QHBoxLayout* layout = new QHBoxLayout;
    layout->addWidget(spinBox);
    layout->addWidget(slider);
    window->setLayout(layout);
    window->show();
// 控件在窗口展示   
   
    return a.exec();
}

参考:

【Qt学习系列】7.Qt布局管理器

相关推荐
2501_941237539 小时前
基于C++的游戏引擎开发
开发语言·c++·算法
_OP_CHEN9 小时前
算法基础篇:(十)贪心算法拓展之哈夫曼编码:从 “合并最优” 到数据压缩的传奇
c++·算法·贪心算法·蓝桥杯·哈夫曼编码·算法竞赛·acm/icpc
枫叶丹49 小时前
【Qt开发】Qt窗口(二) -> QToolBar工具栏
开发语言·数据库·c++·qt
高山有多高9 小时前
堆应用一键通关: 堆排序 +TOPk问题的实战解析
c语言·数据结构·c++·算法
2501_941237459 小时前
高性能计算通信库
开发语言·c++·算法
1白天的黑夜19 小时前
递归-二叉树中的剪枝-814.二叉树剪枝-力扣(LeetCode)
c++·leetcode·剪枝·递归
杜子不疼.9 小时前
【C++】红黑树为什么比AVL快?用C++亲手实现告诉你答案
开发语言·c++
2501_9412362111 小时前
C++与Node.js集成
开发语言·c++·算法
晨非辰11 小时前
【数据结构初阶系列】归并排序全透视:从算法原理全分析到源码实战应用
运维·c语言·数据结构·c++·人工智能·python·深度学习
2501_9411112417 小时前
C++与自动驾驶系统
开发语言·c++·算法