Qt Widgets——抽象滑块及其继承类
三个可视类的默认外观分别如下(win7):它们的滑块都处于最小值0处。
理解QAbstractSlider时
可将它想成就是QScrollBar(该小部件的外观比较多地拥有QAbstractSlider属性):
属性列表如下:
|
|
不进行人为设置时的默认值如下:
公有函数主要是对以上属性的赋值或取值,列表如下:(以横向滚动条(图中右上角那个)说明)
QAbstractSlider(QWidget * parent = )
~QAbstractSlider() //基本使用,需要设置以下几项
void setMinimum(int)//滑块处于最左端时它代表的值
void setMaximum(int)//滑块处于最右端时它代表的值
void setSingleStep(int)//单击左或右小箭头时,滑块变化的长度
void setPageStep(int)
void setSliderPosition(int)//设置滑块初始化后处的位置
//特殊要求时,需要设置以下
void setTracking(bool enable)//设置是否追踪,默认true,追踪时,只要滑块值在改变,它就不断发出信号(较多次),false时,只在松开滑块值改变时才发出(较少次)具体可试试例子的输出
void setInvertedAppearance(bool)//设置成true后,最大最小值位置调换,且点击箭头时,滑块向相反方向走
void setInvertedControls(bool)
void setSliderDown(bool)
//以下取回值,绝大部分与以上对应
int value() const
int maximum() const
int minimum() const
int singleStep() const
int pageStep() const
int sliderPosition() const bool hasTracking() const
bool invertedAppearance() const
bool invertedControls() const
bool isSliderDown() const void triggerAction(SliderAction action)
Qt::Orientation orientation() const
公有槽函数如下:
void setOrientation(Qt::Orientation)//代码创建的默认为竖直向的,需要横向的可设置这个,枚举值在下方
void setRange(int min, int max)//设置值在变化范围,与setMinimun与setMaxmun两函数效果相同
void setValue(int)
enum Qt::Orientation:
Constant Value
Qt::Horizontal 0x1
Qt::Vertical 0x2
信号如下:
void actionTriggered(int action)
void rangeChanged(int min, int max)
void sliderMoved(int value)
void sliderPressed()
void sliderReleased()
void valueChanged(int value)//一般使用这个
QScrollBar大多函数都继承自上述类,
它的公有函数只有构造函数:
QScrollBar(QWidget * parent = )
QScrollBar(Qt::Orientation orientation, QWidget * parent = )
~QScrollBar()
示例如下:
#include "dialog.h"
#include "ui_dialog.h"
#include <QGridLayout>
#include <QScrollBar>
#include <QDebug>
Dialog::Dialog(QWidget *parent) :
QDialog(parent),
ui(new Ui::Dialog)
{
ui->setupUi(this);
ScrollBar=new QScrollBar;
ScrollBar->setMinimum();
ScrollBar->setMaximum();
ScrollBar->setSingleStep();
ScrollBar->setPageStep();
ScrollBar->setSliderPosition();
ScrollBar->setOrientation(Qt::Horizontal);//将它改为水平的
//ScrollBar->setInvertedAppearance(true);
//ScrollBar->setInvertedControls(true);
//ScrollBar->setTracking(false); QGridLayout *Layout = new QGridLayout;//布局类,用于将部件显示到建立的ui上
Layout->addWidget(ScrollBar, , );
setLayout(Layout); connect(ScrollBar,SIGNAL(valueChanged(int)),this,SLOT(SB_value_changed(int)));//连接信号,值一变就输出
} Dialog::~Dialog()
{
delete ui;
} void Dialog::SB_value_changed(int a)
{
qDebug()<<a;
}
————————————————————————————————————————————————————————————
QSlider相比而言,
多出了tick(记号,翻译成刻度比较好),它在中心线的两端加了刻度用于标记值。
公有函数如下:
<span style="white-space:pre"> </span>QSlider(QWidget * parent = )
<span style="white-space:pre"> </span>QSlider(Qt::Orientation orientation, QWidget * parent = )
<span style="white-space:pre"> </span>~QSlider()
void setTickInterval(int ti)//设置刻度间隔
void setTickPosition(TickPosition position)//刻度位置,枚举值,见下方
int tickInterval() const
TickPosition tickPosition() const
刻度位置的枚举值enum QSlider::TickPosition
| QSlider::NoTicks | 0 | 无刻度,默认 |
| QSlider::TicksBothSides | 3 | 中线两端绘制 |
| QSlider::TicksAbove | 1 | 绘制线的上方 |
| QSlider::TicksBelow | 2 | 线下方 |
| QSlider::TicksLeft | TicksAbove | 线左方 |
| QSlider::TicksRight | TicksBelow | 线右方 |
设置刻度后图:
代码:
Slider=new QSlider;
Slider->setOrientation(Qt::Horizontal);
Slider->setTickPosition(QSlider::TicksAbove);
Slider->setTickInterval();
其它常用函数及信号都来自抽象类,这里不赘述
————————————————————————————————————————————————————————————
QDial同Qslider类似,也多了个notch(刻痕)的概念
公有函数如下:
QDial(QWidget * parent = )
~QDial()
int notchSize() const
qreal notchTarget() const
bool notchesVisible() const
void setNotchTarget(double target)//notch target指两刻度之间的像素距离,默认3.7px
bool wrapping() const
公有槽:
void setNotchesVisible(bool visible)//设置刻痕是否可见,默认不可见
void setWrapping(bool on)
wrap有缠绕,盘绕的意思,可理解为首尾相接,设置成true(左)与不设置false效果分别如下:
Qt Widgets——抽象滑块及其继承类的更多相关文章
- Qt Widgets——抽象按钮及其继承类
QAbstractButton是有关“按钮”的基类 描述了一个按钮应该具有的组成.它的公有函数如下: QAbstractButton(QWidget * parent = ) ~QAbstractBu ...
- Qt Widgets——抽象旋转框及其继承类
默认外观分别如下(win7,与上述顺序对应): 可看出,都是由一个可编辑的文本框及右端小箭头组成 QAbstractSpinBox 属性简单解释如下: Properties accelerated : ...
- Qt Widgets、QML、Qt Quick的区别
Qt Widgets.QML.Qt Quick的区别 简述 看了之前关于 QML 的一些介绍,很多人难免会有一些疑惑: Q1:QML 和 Qt Quick 之间有什么区别? Q2:QtQuick 1. ...
- Qt Widgets——主窗口及其主要组成部分
Main Window and Related Classes QAction 动作类,用于当做一个菜单项或工具项插入菜单或工具栏 QActionGroup 动作组,用于管理多个动作,设置它们之间的互 ...
- QEvent整理归纳:140种类型,29个继承类,7个函数,3种事件来源
140种事件类型: QEvent::None QEvent::AccessibilityDescription QEvent::AccessibilityHelp QEvent::Accessibil ...
- Asp.net MVC中三大描述对象之ActionDescriptor 以及继承类ReflectedControllerDescriptor
ActionDescriptor抽象类中几个基本的属性: ControllerName:被描述的Controller名称,去除后缀Controller的名称.例如:HomeController则为Ho ...
- 【QT相关】Qt Widgets Module
Qt Widgets Module:提供了一些列UI元素. 使用: //头文件包含 #include <QtWidgets> //链接模式,在.pro文件中添加行: QT += widge ...
- Qt4项目迁移到Qt5问题:greaterThan(QT_MAJOR_VERSION, 4): QT += widgets .
文章来源:http://blog.csdn.net/ccf19881030/article/details/18220447 问题一:错误:C1083: 无法打开包括文件:"QApplica ...
- python定义接口继承类
zxq547 python定义接口继承类invalid syntax解决办法 1 2 3 4 5 6 7 class s_all(metaclass=abc.ABCMeta): #python ...
随机推荐
- 转一篇 ShaderVariantCollection介绍的比较详细的文章 感谢作者
http://www.seven-fire.cn/archives/174 Unity3D Shader加载时机和预编译 焱燚(七火) | 2016年7月6日 | UnityShader ...
- Selenium 页面自动化测试 面试 问题汇总
1. 专业技术 在学习完Selenium的大部分接口或者方法之后,你可能会去面试自动化测试,主要是Selenium的自动化测试.下面这些问题总结,可能会对你有所帮助. 什么是Selenium? S ...
- 力扣(LeetCode)1009. 十进制整数的反码
每个非负整数 N 都有其二进制表示.例如, 5 可以被表示为二进制 "101",11 可以用二进制 "1011" 表示,依此类推.注意,除 N = 0 外,任何 ...
- 淘宝开源的H5移动开发UI框架genie-ui
官网地址: https://npm.taobao.org/package/genie-ui
- python测试相关小问题
实操中的小问题 pycharm 一次运行多个test configuration 项目分层,分包之后,tests也分到不同层的不同project里了,tests也分开. 为了防止基层模块改动,影响上层 ...
- Codeforces 841 D - Leha and another game about graph
D - Leha and another game about graph 思路:首先,如果所有点的度数加起来是奇数,且没有-1,那么是不可以的. 其他情况都可以构造,我们先dfs出一个生成树,然后从 ...
- xlua怎么样hotfix C#中的重写方法???
问题的来源之这样的: 线上项目遇到一个问题,就是子类 override 了父类的一个 virtual 方法,并且调用到了父类里面的 virtual 方法.现在子类 override 的方法里有一些错 ...
- Unity---资源管理中不同资源的路径获取方式
1.首先需要先了解两个知识点: Unity内置的文件路径获取方式.windows的Directory.GetFiles文件获取方式: 1>Unity内置的文件路径获取方式,一下是官方解释:h ...
- Unity 通过代码简单实现文理的灰化显示
1.可以用于纹理的处理,也可用于模型显示的处理(比如某件准备或者服饰未获取的时候,灰化显示) 线上对比图: using System.Collections; ...
- RESTful Web Services中API的设计原则(转)
当下前后端分离的设计已经是web app开发的标配,但是如何设计一个强壮,扩展性好,又规范的API呢 参考以下link,可以得到需要有益的启示.同时个人推荐一本书<web API的设计和开发&g ...