[Qt的学习日常]--常用控件2

前言

作者:小蜗牛向前冲

名言:我可以接受失败,但我不能接受放弃

  如果觉的博主的文章还不错的话,还请点赞,收藏,关注👀支持博主。如果发现有问题的地方欢迎❀大家在评论区指正

目录

一、widget的核心属性               

1、cursor

2、font

  3、toolTip和focusPolicy 

 4、styleSheet

二、 按钮类控件

1、Push Button

2、RadioButtion

3、CheckBox


本期学习:进行学习widget的核心控件,cursor,font,toolTip,focusPilocy,styleSheet以及控件类型的按键pushButton,RadioButton和checkBox复选按键

一、widget的核心属性               

1、cursor

这个属性主要是对鼠标进行操作,结合前面文章讲的创建qrc文件,我们可以更改鼠标的图标的类型。

API

说明

cursor()

获取到当前widget的cursor属性,返回QCursor对象.
标悬停在该widget上时,就会显出对应的形状.

setCursor(const QCursor& cursor)

设置该widget光标的形状.仅在标停留在该widget上时效.

QGuiApplication::setOverrideCursor(co
nst QCursor&cursor)

设置全局光标的形状.对整个程序中的所有widget都会效.覆盖
的setCursor设置的内容.

 编写widget.cpp

#include <QPixmap>
Widget::Widget(QWidget *parent)
: QWidget(parent)
, ui(new Ui::Widget)
{
    ui->setupUi(this);
   // 创建⼀个位图对象, 加载⾃定义光标图⽚
   QPixmap pixmap(":/huaji.png");
   // 缩放图⽚为 64 * 64 的尺⼨.
   pixmap = pixmap.scaled(64, 64);
   // 创建 QCursor 对象, 并指定 "热点" 为 (2, 2) 坐标位置.
   // 所谓 "热点" 就是⿏标点击时⽣效的位置.
   QCursor cursor(pixmap, 2, 2);
   // 设置光标
   this->setCursor(cursor);
}

     这里会发现,我们的鼠标图案会变成我们 的资料图片。

当然我们也可以在  Qt Designer中的属性编辑器,进行选择cursor类型的选择。

2、font

      在Qt中,QFont 类用于表示字体。QFont 提供了一种方法来指定字体的各种属性,例如字体系列、字号、字重、字型等。您可以使用 QFont 来设置窗口小部件和绘图对象的字体。 

API

说明

font()

获取当前widget的字体信息.返回QFont对象.

setFont(constQFont&font)

设置当前widget的字体信息.

属性

说明

family

字体家族.如"楷体","宋体","微软雅"等.

pointSize

字体⼤⼩

weight

字体粗细.以数值式表粗细程度取值范围为[0,99],数值越,
粗.

bold

是否加粗.设置为true,相当于weight为75.设置为false相当于
weight为50.

italic

是否倾斜

underline

是否带有下划线

strikeOut

是否带有删除线

对于字体的调控往往是用来优化用户体验。

 在widget.cpp:

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //设置label标签的
    ui->label->setText("加油,你可以的");
    //创建字体对象
    QFont font;
    //设置字体
    font.setFamily("宋体");
    //设置字体大小
    font.setPointSize(20);
    //设置字体加粗
    font.setBold(true);
    //设置字体倾斜
    font.setItalic(true);
    //设置字体删除线
    font.setStrikeOut(true);
    //将设置实现到对象label上
    ui->label->setFont(font);
}

             

     对于这些设置的属性font我们也可以在 Qt Designer中的属性编辑器。这个工具允许您在设计用户界面时,直观地设置各种控件(如QLabelQPushButton等)的属性 

  3、toolTip和focusPolicy 

在Qt中,toolTip是一个属性,用于设置控件的工具提示(Tooltip)。工具提示是在用户将鼠标悬停在控件上时显示的一段文本,通常用于提供关于控件的额外信息或帮助。

API

说明

setToolTip

设置toolTip.
标悬停在该widget上时会有提说明.

setToolTipDuring

设置toolTip提的时间.单位ms.
时间到后toolTip
动消失.

 在Qt中,focusPolicy属性用于指定控件的焦点策略,决定控件是否可以接收键盘输入焦点以及如何接收焦点。焦点策略有助于管理用户界面的交互行为,特别是在使用键盘导航时

在英雄联盟选择英雄,点击鼠标让英雄到达指定位置,就是靠focusPolicy这个属性。                

PI

说明

focusPolicy()

获取该widget的focusPolicy,返回Qt::FocusPolicy

setFocusPolicy(Qt::FocusPolicypolicy)

设置widget的focusPolicy.

 Qt提供了几种焦点策略,可以通过Qt::FocusPolicy枚举类型进行设置:

  • Qt::NoFocus: 控件不能接收键盘焦点
  • Qt::TabFocus: 控件可以通过Tab键获得焦点。
  • Qt::ClickFocus: 控件可以通过鼠标点击获得焦点。
  • Qt::StrongFocus: 控件可以通过Tab键或鼠标点击获得焦点。
  • Qt::WheelFocus: 控件可以通过Tab键、鼠标点击或滚轮事件获得焦点。

 4、styleSheet

在Qt中,QStyleSheet(样式表)是一种类似于CSS(层叠样式表)的语言,用于定义和自定义控件的外观。通过使用样式表,您可以轻松地控制Qt应用程序中控件的样式,如颜色、字体、边框、大小等,从而使应用程序具有一致且美观的用户界面。

样式表的语法与CSS非常相似,以下是一些常用的属性:

  • background-color: 设置背景颜色。
  • color: 设置文本颜色。
  • font-size: 设置字体大小。
  • font-family: 设置字体系列。
  • border: 设置边框样式。
  • padding: 设置内边距。
  • margin: 设置外边距。

在Qt Designer中设置样式表

  1. 打开Qt Designer并选择一个控件。
  2. 在右侧的属性编辑器中找到styleSheet属性。
  3. 单击该属性字段,然后在弹出的样式编辑器中输入样式表代码。

在用styleSheet更改控件样式的时候,我们常常会遇到颜色的更改,那计算机中又是如何进行颜色的描述的?

 关于计算机中的颜⾊表⽰

计算机中使⽤"像素"表⽰屏幕上的⼀个基本单位(也就是⼀个发亮的光点).
每个光点都使⽤三个字节表⽰颜⾊,分别是R(red),G(green),B(blue)⼀个字节表⽰(取值范
围是0-255,或者0x00-0xFF).

混合三种不同颜⾊的数值⽐例,就能搭配出千千万万的颜⾊出来:

rgb(255, 0, 0) 或者 #FF0000 或者 #F00 表⽰纯红⾊.
rgb(0, 255, 0) 或者 #00FF00 或者 #0F0 表⽰纯绿⾊.
rgb(0, 0, 255) 或者 #0000FF 或者 #00F 表⽰纯蓝⾊.
rgb(255, 255, 255) 或者 #FFFFFF 或者 #FFF 表⽰纯⽩⾊.
rgb(0, 0, 0) 或者 #000000 或者 #000 表⽰纯⿊⾊.

二、 按钮类控件

1、Push Button

在Qt中QPushButton是一个用于创建按钮的控件,它继承自QAbstractButton,提供了按钮的基本功能和外观。QPushButton通常用于触发某个操作或事件,例如提交表单、打开对话框等。

 QAbstractButton 中,和 QPushButton 相关性较⼤的属性

属性

说明

text

按钮中的

icon

按钮中的图标

iconSize

按钮中图标的尺

shortCut

按钮对应的快捷键

autoRepeat

按钮是否会重复触发.当标左键按住不放时,
如果设为true,则会持续产
⽣⿏标点击事件;
如果设为false,则必须释放
标,再次按下标时才能产点击事件.
(相当于游戏
⼿柄上的"连发"效果)

autoRepeatDelay

重复触发的延时时间.按住按钮多久之后,开始重复触发.

autoRepeatInterval

重复触发的周期.

案例演示:这里我们用按键控制控制在窗口移动 

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //设置图标
    ui->pushButton_target->setIcon(QIcon(":/ice.png"));
    ui->pushButton_up->setIcon(QIcon(":/arrow.png"));
    ui->pushButton_down->setIcon(QIcon(":/down.png"));
    ui->pushButton_left->setIcon(QIcon(":/left.png"));
    ui->pushButton_right->setIcon(QIcon(":/right.png"));

    //设置大小
    ui->pushButton_target->setIconSize(QSize(120,120));

    //设置快捷键
    ui->pushButton_up->setShortcut(QKeySequence("w"));
    ui->pushButton_down->setShortcut(QKeySequence("s"));
    ui->pushButton_left->setShortcut(QKeySequence("a"));
    ui->pushButton_right->setShortcut(QKeySequence("d"));

    // 开启重复触发.这个是为了,一直按住鼠标也能够进触发
    ui->pushButton_up->setAutoRepeat(true);
    ui->pushButton_down->setAutoRepeat(true);
    ui->pushButton_left->setAutoRepeat(true);
    ui->pushButton_right->setAutoRepeat(true);

}

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


void Widget::on_pushButton_up_clicked()
{
    const QRect rect = ui->pushButton_target->geometry();
    ui->pushButton_target->setGeometry(rect.x(),rect.y()-5,rect.width(),rect.height());
    qDebug()<<"up";
}

void Widget::on_pushButton_down_clicked()
{
    const QRect rect = ui->pushButton_target->geometry();
    ui->pushButton_target->setGeometry(rect.x(),rect.y()+5,rect.width(),rect.height());
    qDebug()<<"down";
}

void Widget::on_pushButton_left_clicked()
{
    const QRect rect = ui->pushButton_target->geometry();
    ui->pushButton_target->setGeometry(rect.x()-5,rect.y(),rect.width(),rect.height());
    qDebug()<<"left";
}

void Widget::on_pushButton_right_clicked()
{
    const QRect rect = ui->pushButton_target->geometry();
    ui->pushButton_target->setGeometry(rect.x()+5,rect.y(),rect.width(),rect.height());
    qDebug()<<"right";
}

 

  • QAbstractButton 作为 QWidget 的⼦类,当然也继承了 QWidget 的属性.上⾯介绍的 QWidget ⾥的各种属性⽤法,对于 QAbstractButton 同样适⽤.因此表格仅列出 QAbstractButton 独有的属性.
  • Qt的api设计⻛格是⾮常清晰的.此处列出的属性都是可以 获取 和 设置 的.例如,使text() 获取按钮⽂本;使⽤ setText() 设置⽂本.

2、RadioButtion

在Qt中QRadio Button是一个单选按钮控件,通常用于让用户在一组选项中选择一个。单选按钮在用户界面设计中非常常见,例如在设置对话框中让用户选择某个特定的选项。 

QAbstractButton 中和 QRadioButton 关系较⼤的属性:

属性

说明

checkable

是否能选中

checked

是否已经被选中.checkable是checked的前提条件.

autoExclusive

是否排他.
选中
个按钮之后是否会取消其他按钮的选中.
对于
QRadioButton 来说默认就是排他的.

代码案例:

 

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);


    //设置默认选择按钮
    ui->radioButton_man->setChecked(true);//checked表示是否已经被选择,checkable是否能选中
    ui->label->setText("你选择的性别为:男");

    //设置其他不可以选中
    ui->radioButton_other->setCheckable(false);//这里虽然不会选中,但是仍会触发槽函数

    //彻底禁用other
    ui->radioButton_other->setEnabled(false);

}

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


void Widget::on_radioButton_man_clicked()
{
    ui->label->setText("你选择的性别为:男");
}

void Widget::on_radioButton_female_clicked()
{
    ui->label->setText("你选择的性别为:女");
}

void Widget::on_radioButton_other_clicked()
{
     ui->label->setText("你选择的性别为:其他");
}


                                                                                                        

这里我们不仅仅能够进行单个类型的选择,还能够进行多种类型用 RadioButtion进行选择。

引⼊QButtonGroup进⾏分组.

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);

    //创建三个组
    QButtonGroup* group1 = new QButtonGroup(this);
    QButtonGroup* group2 = new QButtonGroup(this);
    QButtonGroup* group3 = new QButtonGroup(this);

    //将按键进行分组
    group1->addButton(ui->radioButton);
    group1->addButton(ui->radioButton_2);

    group2->addButton(ui->radioButton_3);
    group2->addButton(ui->radioButton_4);

    group3->addButton(ui->radioButton_5);
    group3->addButton(ui->radioButton_6);

}

3、CheckBox

在Qt中,QCheckBox是一个复选框控件,允许用户选择或取消选择一个选项。复选框通常用于在一个表单或设置对话框中让用户选择多个选项。 

和QCheckBox 最相关的属性也是checkable 和 checked ,都是继承⾃
QAbstractButton .
 

案例演示:

void Widget::on_pushButton_clicked()
{
    QString result;
    if(ui->checkBox_sleep->isChecked())
    {
        result +=ui->checkBox_sleep->text();
    }
    if(ui->checkBox_play->isChecked())
    {
        result +=ui->checkBox_play->text();
    }
    if(ui->checkBox_study->isChecked())
    {
        result +=ui->checkBox_study->text();
    }
    qDebug()<<"选中的内容"<<result;
}

  

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/716453.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

U盘文件夹变exe:现象解析与数据恢复策略

一、U盘文件夹变exe现象描述 在日常使用U盘进行数据传输和存储的过程中&#xff0c;部分用户可能会遭遇一种异常现象&#xff1a;原本正常的文件夹突然变成了可执行文件&#xff08;即后缀为.exe的文件&#xff09;。这种变化不仅影响了用户对文件的正常访问和管理&#xff0c…

基于文本和图片输入的3D数字人化身生成技术解析

随着虚拟现实、增强现实和元宇宙等技术的飞速发展,对高度逼真且具有表现力的3D数字人化身的需求日益增长。传统的3D数字人生成方法往往需要依赖大量的3D数据集,这不仅增加了数据收集和处理的成本,还限制了生成的多样性和灵活性。为了克服这些挑战,我们提出了一种基于文本提…

短剧系统搭建全攻略:功能齐全,一步到位

前言 近年来&#xff0c;短剧系统以其独特魅力&#xff0c;成为大众消遣娱乐的热门选择。简单来说&#xff0c;短剧系统就是用来看短剧的小程序&#xff0c;它汇集了丰富多彩的短剧资源&#xff0c;让观众随时随地享受观影乐趣。本文将为你详细解析短剧系统的搭建全攻略&#…

GaussDB技术解读——GaussDB架构介绍(四)

目录 11 GaussDB云原生架构 11.1 云原生关键技术架构 11.2 关键技术方案 11.2.1 通信组件 11.2.2 集群管理组件 11.2.3 多租组件 GaussDB架构介绍&#xff08;三&#xff09;从智能关键技术方案、驱动接口关键技术方案等方面对GaussDB架构进行了解读&#xff0c;本篇将…

SpringBoot配置第三方专业缓存技术Memcached 下载 安装 整合测试 2024年5000字详解

Memcached下载和安装 是一个国内使用量还是比较大的技术 打开文件夹 我们需要在命令行窗口启动 注意要以管理员方式运行 先尝试进入指定文件 然后又再次运行 下载 memcached.exe -d install 启动 memcached.exe -d start 停止 memcached.exe -d stop memcached.exe -d i…

直播中的美颜技术详解:视频美颜SDK的开发与应用

今天&#xff0c;笔者将深入探讨直播中的美颜技术&#xff0c;解析视频美颜SDK的开发与应用。 一、视频美颜技术概述 视频美颜技术主要通过实时处理视频流&#xff0c;对人脸进行优化和修饰&#xff0c;使直播画面更加美观。这些功能不仅提升了用户的直播体验&#xff0c;还极…

程序员的悲哀是什么?

说在前面 在许多人眼中&#xff0c;程序员无疑是一份令人羡慕的职业。然而&#xff0c;这份工作背后隐藏的辛酸与挑战&#xff0c;却鲜为人知。技术的迅猛发展带来了持续的学习压力&#xff0c;孤独的编码长夜挑战着程序员的社交与情感需求。高强度的工作节奏和严苛的项目期限…

视觉应用线扫相机速度反馈(伺服转盘)

运动控制实时总线相关内容请参考运动控制专栏&#xff0c;这里不再赘述 1、运动控制常用单位u/s运动控制单位[u/s]介绍_运动控制 unit是什么单位-CSDN博客文章浏览阅读176次。运动控制很多手册上会写这样的单位&#xff0c;这里的u是英文单词unit的缩写&#xff0c;也就是单位…

10分钟部署一个个人博客

关于vuepress这里没必要过多介绍&#xff0c;感兴趣的可以直接去官网了解&#xff0c;下面是官网首页地址截图 &#xff1a;https://v2.vuepress.vuejs.org/zh/ 透过这张图&#xff0c;我们也可以大致的对这个框架的特点有一定的认识&#xff0c;这就够了。其他的东西我们在使用…

基于SSM框架的电影院售票网站

开头语&#xff1a; 你好呀&#xff0c;我是计算机学长猫哥&#xff01;如果您对我们的电影院售票网站感兴趣或者有相关需求&#xff0c;欢迎通过文末的联系方式与我联系。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;SSM框架 工具&#xff1a;ID…

m4s转mp3——B站缓存视频提取音频

前言 しかのこのこのここしたんたん&#xff08;鹿乃子乃子虎视眈眈&#xff09;非常之好&#xff0c;很适合当闹钟&#xff0c;于是缓存了视频&#xff0c;想提取音频为mp3 直接改后缀可乎&#xff1f;格式转换工具&#xff1f; 好久之前有记录过转MP4的&#xff1a; m4s转为…

Linux中文件查找相关命令比较

Linux中与文件定位的命令有find、locate、whereis、which&#xff0c;type。 一、find find命令最强&#xff0c;能搜索各种场景下的文件&#xff0c;需要配合相关参数&#xff0c;搜索速度慢。在文件系统中递归查找文件。 find /path/to/search -name "filename"…

数字孪生灌区信息化管理系统是如何实现水资源节水的?

在当今日益严峻的水资源形势下&#xff0c;如何实现水资源的节水利用已成为灌区管理的重中之重。幸运的是&#xff0c;随着信息化技术的快速发展&#xff0c;灌区信息化正成为推动水资源节水利用的有力工具。那么&#xff0c;数字孪生灌区信息化hua系统xit究竟如何实现水资源节…

Java环境安装

下载JDK https://www.oracle.com/cn/java/technologies/downloads/#jdk22-windows 点开那个下载都可以但是要记住下载的路径因为下一步要添加环境变量 选择编辑系统环境变量 点击环境变量 点击新建 新建环境变量JAVA_HOME 并输入JDK在计算机保存的路径 打开cmd 输入java -…

OSPF协议详解(二)

OSPF邻接关系建立流程 路由器在开启OSPF协议后先进入Down状态&#xff0c;此时路由器还未收到网络中其他路由器发送的Hello报文。 当路由器收到了其他路由器发送的Hello报文时&#xff0c;状态转发Init&#xff0c;当发来的Hello报文中有自己的Router ID时&#xff0c;状态转…

FPGA学习最好的2个网站?

自学FPGA最好的两个网站: Xilinx官方网站: ​网址链接&#xff1a; https://www.amd.com/zh-cn.html Xilinx Wiki - Confluence (http://atlassian.net) Xilinx GitHub&#xff08;https://github.com/Xilinx&#xff09; 电子创新网赛灵思社区 | 电子创新网 (http://eet…

Excel 常用技巧(五)

Microsoft Excel 是微软为 Windows、macOS、Android 和 iOS 开发的电子表格软件&#xff0c;可以用来制作电子表格、完成许多复杂的数据运算&#xff0c;进行数据的分析和预测&#xff0c;并且具有强大的制作图表的功能。由于 Excel 具有十分友好的人机界面和强大的计算功能&am…

Google Earth Engine(GEE)——导出影像video到自己的Google硬盘当中

函数: Export.video.toDrive(collection, description, folder, fileNamePrefix, framesPerSecond, dimensions, region, scale, crs, crsTransform, maxPixels, maxFrames) Creates a batch task to export an ImageCollection as a video to Drive. The collection must on…

idea-Spring框架与ioc容器

Sping是轻量级的开源J2EE框架&#xff0c;可以解决企业应用开发的复杂性 Spring有两个核心部分为Ioc和AOP Ioc:控制反转&#xff0c;吧创建对象过程交给Sping进行管理 AOP:面向切面&#xff0c;不修改代码进行功能增强 创建Maven项目 IDEA-2024 就直接创建java项目即可 创…

CD4069做陶瓷和晶体振荡器的试验初步

在面包板上面&#xff0c;供电5v。尝试用4069做晶体振荡器 465K&#xff0c;1M陶瓷&#xff0c;不起振 4M陶瓷&#xff0c;不起振&#xff0c;在1脚加上68pf电容后起振&#xff0c;但幅度没有后面写的10M陶瓷和17.6的晶振的幅度大 10M陶瓷&#xff0c;起振ok 16M陶瓷&#…