Qt第三课 ----------按钮的控件属性

news2024/9/21 17:56:41

作者前言

🎂 ✨✨✨✨✨✨🍧🍧🍧🍧🍧🍧🍧🎂
​🎂 作者介绍: 🎂🎂
🎂 🎉🎉🎉🎉🎉🎉🎉 🎂
🎂作者id:老秦包你会, 🎂
简单介绍:🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂🎂
喜欢学习C语言、C++和python等编程语言,是一位爱分享的博主,有兴趣的小可爱可以来互讨 🎂🎂🎂🎂🎂🎂🎂🎂
🎂个人主页::小小页面🎂
🎂gitee页面:秦大大🎂
🎂🎂🎂🎂🎂🎂🎂🎂
🎂 一个爱分享的小博主 欢迎小可爱们前来借鉴🎂


按钮

  • **作者前言**
  • Push Button
    • text
    • icon
    • iconsize
    • shortCut
    • autoRepeat
  • redioButton
    • checkable
    • checked
    • autoExclusive
  • check box

Push Button

前面我们简单的使用了QPushbutton这个类, 大致知道了 QAbstractButton
这个类是其他按钮的父类
在这里插入图片描述

text

在这里插入图片描述
text();获取文本
setText();设置文本

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    QPushButton* btntext = new QPushButton(this);
    btntext->setText("我很厉害");
    qDebug()<< btntext->text();
}

如图:
在这里插入图片描述

icon

在这里插入图片描述
前面我们在介绍windowIcon设置窗口图标的时候,就介绍icon是一个类,一个图片,
如果要使用这个, 需要把资源放入到qrc文件中,

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    QPushButton* btntext = new QPushButton(this);
    btntext->setText("我很厉害");
    qDebug()<< btntext->text();
    btntext->setIcon(QIcon(":/new/prefix1/cat.png"));

}

如图:
在这里插入图片描述

iconsize

在这里插入图片描述
Iconsize(); 返回一个Qsize类型的对象,
seticonsize(QSize& size); 设置图标的大小;

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    QPushButton* btntext = new QPushButton(this);
    QRect rect(10,20, 1000,1000);
    btntext->setGeometry(rect);
    btntext->setText("我很厉害");
    qDebug()<< btntext->text();
    btntext->setIcon(QIcon(":/new/prefix1/cat.png"));

    qDebug()<<btntext->iconSize();
    btntext->setIconSize(QSize(50,50));

}

在这里插入图片描述

shortCut

给按钮添加快捷键
前面我们设置过使用鼠标点击按钮移动按钮,这里我们就使用快捷键来移动一个按钮
使⽤ setShortcut 给按钮设置快捷键. 参数是⼀个 QKeySequence 对象. 表⽰⼀个按键序列. ⽀
持组合键 (ctrl + c 这种).
下面使用Qt Designer来连接信号和槽, 没有使用connect


Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->pushButton_5->setText("");
    ui->pushButton_5->setIconSize(QSize(50,50));
    ui->pushButton_5->setIcon(QIcon(":/new/prefix1/cat.png"));

    ui->pushButton->setIcon(QIcon(":/new/prefix1/left.png"));
    ui->pushButton_2->setIcon(QIcon(":/new/prefix1/top.png"));
    ui->pushButton_3->setIcon(QIcon(":/new/prefix1/right.png"));
    ui->pushButton_4->setIcon(QIcon(":/new/prefix1/down.png"));

    ui->pushButton_5->setGeometry(10,10,100,100);
    ui->pushButton->setShortcut(QKeySequence("a"));
    ui->pushButton_2->setShortcut(QKeySequence("w"));
    ui->pushButton_3->setShortcut(QKeySequence("d"));
    ui->pushButton_4->setShortcut(QKeySequence("s"));
}

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


void Widget::on_pushButton_clicked()
{
    QRect rect = ui->pushButton_5->geometry();
    ui->pushButton_5->setGeometry(rect.x()-0.1, rect.y(), rect.width(), rect.height());
}

void Widget::on_pushButton_2_clicked()
{
    QRect rect = ui->pushButton_5->geometry();
    ui->pushButton_5->setGeometry(rect.x(), rect.y()-0.1, rect.width(), rect.height());
}

void Widget::on_pushButton_3_clicked()
{
    QRect rect = ui->pushButton_5->geometry();
    ui->pushButton_5->setGeometry(rect.x()+1, rect.y(), rect.width(), rect.height());
}

void Widget::on_pushButton_4_clicked()
{
    QRect rect = ui->pushButton_5->geometry();
    ui->pushButton_5->setGeometry(rect.x(), rect.y()+1, rect.width(), rect.height());
}

如图:
在这里插入图片描述
这样写出来的效果,按住按键会连续触发,使用鼠标就不能连发,
上面的设置按键的方式,按照上面的代码进行设置,如果设置错了,是不会报错, 如果是通过枚举的来设置快捷键就可以避免这个问题

ui->pushButton->setShortcut(QKeySequence(Qt::Key_A));
ui->pushButton_2->setShortcut(QKeySequence(Qt::Key_W));
ui->pushButton_3->setShortcut(QKeySequence(Qt::Key_D));
ui->pushButton_4->setShortcut(QKeySequence(Qt::Key_S));

设置错了就会报错

autoRepeat

设置鼠标的连发功能
在这里插入图片描述
在上面的代码上我们设置一下鼠标的连发

        ui->pushButton->setAutoRepeat(true);
        ui->pushButton_2->setAutoRepeat(true);
        ui->pushButton_3->setAutoRepeat(true);
        ui->pushButton_4->setAutoRepeat(true);

redioButton

这是一个单选的按钮
一般常用的属性如下:

在这里插入图片描述

checkable

一般情况下,创建的radiobutton默认是可以不选中的, 使用这个只能让被选中,或者还是通过鼠标去点击选中

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    QLabel* label = new QLabel(this);
    label->setText("选择你的性别:");
    QRadioButton* radiobuttonOne = new QRadioButton("男",this);
     radiobuttonOne->setChecked(true);
     radiobuttonOne->setGeometry(radiobuttonOne->geometry().x(),radiobuttonOne->geometry().y()+50,radiobuttonOne->geometry().width(),radiobuttonOne->geometry().height());
    QRadioButton* radiobuttonTwo = new QRadioButton("女",this);
    radiobuttonTwo->setGeometry(radiobuttonOne->geometry().x(),radiobuttonOne->geometry().y()+50,radiobuttonOne->geometry().width(),radiobuttonOne->geometry().height());

    QRadioButton* radiobuttonThree = new QRadioButton("人妖",this);
    radiobuttonThree->setGeometry(radiobuttonTwo->geometry().x(),radiobuttonTwo->geometry().y()+50,radiobuttonTwo->geometry().width(),radiobuttonTwo->geometry().height());
    auto funtion = [=]()
    {
       connect(radiobuttonOne, &QRadioButton::clicked, this, [=]()
       {
           radiobuttonTwo->setChecked(false);
           radiobuttonThree->setChecked(false);
           qDebug() << "点击成功";

       }
       );
       connect(radiobuttonTwo, &QRadioButton::clicked, this, [=]()
       {
           radiobuttonOne->setChecked(false);
           radiobuttonThree->setChecked(false);
           qDebug() << "点击成功";

       }
       );
       connect(radiobuttonThree, &QRadioButton::clicked, this, [=]()
       {
           radiobuttonTwo->setChecked(false);
           radiobuttonOne->setChecked(false);
           qDebug() << "点击成功";

       }
       );

    };
    funtion();

}

如图:
在这里插入图片描述

如果要实现禁用按钮可以使用enable这个属性达到禁用

checked

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    QLabel* label = new QLabel(this);
    label->setText("选择你的性别:");
    QRadioButton* radiobuttonOne = new QRadioButton("男",this);
    radiobuttonOne->setChecked(true);
     radiobuttonOne->setGeometry(radiobuttonOne->geometry().x(),radiobuttonOne->geometry().y()+50,radiobuttonOne->geometry().width(),radiobuttonOne->geometry().height());
    QRadioButton* radiobuttonTwo = new QRadioButton("女",this);
    radiobuttonTwo->setGeometry(radiobuttonOne->geometry().x(),radiobuttonOne->geometry().y()+50,radiobuttonOne->geometry().width(),radiobuttonOne->geometry().height());

    QRadioButton* radiobuttonThree = new QRadioButton("人妖",this);
    radiobuttonThree->setGeometry(radiobuttonTwo->geometry().x(),radiobuttonTwo->geometry().y()+50,radiobuttonTwo->geometry().width(),radiobuttonTwo->geometry().height());
    auto funtion = [=]()
    {
       connect(radiobuttonOne, &QRadioButton::clicked, this, [=](bool elemeset)
       {
           qDebug() << "radiobuttonOne:"<<elemeset;
           qDebug() << "点击成功";

       }
       );
       connect(radiobuttonTwo, &QRadioButton::clicked, this, [=](bool elemeset)
       {
            qDebug() << "radiobuttonTwo:"<<elemeset;
           qDebug() << "点击成功";

       }
       );
       connect(radiobuttonThree, &QRadioButton::clicked, this, [=](bool elemeset)
       {
            qDebug() << "radiobuttonThree:"<<elemeset;
           qDebug() << "点击成功";

       }
       );

    };
    funtion();

}

如图:
在这里插入图片描述
这是使用的checked是含有参数的,获取到当前点击按钮是否被选中

autoExclusive

前面我们看到过很多多选按钮,这个就是用来控制是否可以多选的

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    QLabel* label = new QLabel(this);
    label->setText("选择你的性别:");
    //是否多选
    QRadioButton* Manybutton= new  QRadioButton("多选",this);
    Manybutton->move(150,0);

    QRadioButton* radiobuttonOne = new QRadioButton("男",this);
    radiobuttonOne->setChecked(true);
     radiobuttonOne->setGeometry(radiobuttonOne->geometry().x(),radiobuttonOne->geometry().y()+50,radiobuttonOne->geometry().width(),radiobuttonOne->geometry().height());
    QRadioButton* radiobuttonTwo = new QRadioButton("女",this);
    radiobuttonTwo->setGeometry(radiobuttonOne->geometry().x(),radiobuttonOne->geometry().y()+50,radiobuttonOne->geometry().width(),radiobuttonOne->geometry().height());

    QRadioButton* radiobuttonThree = new QRadioButton("人妖",this);
    radiobuttonThree->setGeometry(radiobuttonTwo->geometry().x(),radiobuttonTwo->geometry().y()+50,radiobuttonTwo->geometry().width(),radiobuttonTwo->geometry().height());
    auto funtion = [=]()
    {
       connect(radiobuttonOne, &QRadioButton::clicked, this, [=](bool elemeset)
       {
           qDebug() << "radiobuttonOne:"<<elemeset;
           qDebug() << "点击成功";

       }
       );
       connect(radiobuttonTwo, &QRadioButton::clicked, this, [=](bool elemeset)
       {
            qDebug() << "radiobuttonTwo:"<<elemeset;
           qDebug() << "点击成功";

       }
       );
       connect(radiobuttonThree, &QRadioButton::clicked, this, [=](bool elemeset)
       {
            qDebug() << "radiobuttonThree:"<<elemeset;
           qDebug() << "点击成功";

       }
       );
       connect(Manybutton, &QRadioButton::clicked, this, [=](bool multi)
       {
           if(multi== true)
           {
               radiobuttonThree->setAutoExclusive(false);
               radiobuttonOne->setAutoExclusive(false);
               radiobuttonTwo->setAutoExclusive(false);
               qDebug()<< "多选成功";
           }
           else
           {
               radiobuttonThree->setAutoExclusive(true);
               radiobuttonOne->setAutoExclusive(true);
               radiobuttonTwo->setAutoExclusive(true);
               qDebug()<< "取消多选";
           }
       }
       );

    };
    funtion();

}

如图:
在这里插入图片描述
一般这个属性在radiobutton使用的话不怎么建议, 一般是加入到一个组里面去

check box

这个多选按钮的属性跟单选按钮是一样的,支持checked 、checkable,等属性,下面就简单的写一下

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    //一
    QCheckBox* checkbokOne = new QCheckBox("吃饭", this);
    checkbokOne->move(0,20);
    connect(checkbokOne, &QCheckBox::clicked, this, [=](bool elemest)
    {
        qDebug()<< "one:" << elemest;

    });
    //二
    QCheckBox* checkbokTwo = new QCheckBox("睡觉", this);
    checkbokTwo->move(0,40);
    connect(checkbokTwo, &QCheckBox::clicked, this, [=](bool elemest)
    {
        qDebug()<< "two:" << elemest;

    });

    //三
    QCheckBox* checkbokThree = new QCheckBox("打豆豆", this);
    checkbokThree->move(0,60);
    connect(checkbokThree, &QCheckBox::clicked, this, [=](bool elemest)
    {
        qDebug()<< "Three:" << elemest;

    });
}

如图
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

视频推拉流/直播点播EasyDSS平台安装失败并报错“install mediaserver error”是什么原因?

TSINGSEE青犀视频推拉流/直播点播EasyDSS平台支持音视频采集、视频推拉流、播放H.265编码视频、存储、分发等视频能力服务&#xff0c;在应用场景中可实现视频直播、点播、转码、管理、录像、检索、时移回看等。此外&#xff0c;平台还支持用户自行上传视频文件&#xff0c;也可…

openeuler-无法dnf安装包问题

有个openEuler release 22.09系统机器&#xff0c;需要dnf安装些包等 [rootlydb ~]# more /etc/openEuler-release openEuler release 22.09 [rootlydb ~]# dnf -y install lrzsz OS …

【C++】Stack

个人主页~ Stack 一、Stack的介绍和使用1、stack的介绍2、stack的使用3、stack的模拟实现 二、容器适配器1、什么是适配器2、容器适配器的使用 三、deque1、原理介绍2、deque的使用3、deque的缺陷 一、Stack的介绍和使用 1、stack的介绍 stack详细解释 stack是一种容器适配器…

onlyoffice 使用记录(前端开发角度)

前端和Web文档生成器服务器交互 对于与 Web 文档生成器服务的交互&#xff0c;使用 POST 请求。 请求参数在请求正文中以 JSON 格式输入。 请求被发送到 https://documentserver/docbuilder 地址&#xff0c;其中 documentserver 是安装了 ONLYOFFICE 文档服务器的服务器的名称…

创新实验报告VC++案例开发十二生肖的俄罗斯方块智力游戏完整代码设计方案

一&#xff0e;项目名称 十二生肖俄罗斯方块 二&#xff0e;开发背景&#xff1a; 俄罗斯方块是一个很低古老的一个小游戏&#xff0c;到但今日它还有很大的魅力。 三&#xff0e;技术路线或工作原理&#xff1a; 采用的软件及开发平台 Micosoft Visual 6.0 项目的总体方…

1.安卓逆向-说明

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 内容参考于&#xff1a;图灵Python学院 正常来爬一个app的数据&#xff0c;在没有加密的情况下&#xff0c;就不需要去逆向&#xff0c;app没有加密也就可以正…

SprinBoot+Vue高校就业管理系统的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍&#xff1a;CSDN认证博客专家&#xff0c;CSDN平台Java领域优质…

RickdiculouslyEasy--CTF-综合靶场

废话不多说&#xff0c;一个靶机&#xff0c;好几个flag&#xff0c;开整&#xff01;&#xff01;&#xff01; 使用命令如下&#xff0c;来进行主机发现。 netdiscover -r 172.16.1.10 找到目标靶机 扫描端口 nmap 172.16.1.7 -p 1-65535 依次访问 第一个flag 9090端口 第…

使用CUBE_MX实现STM32 DMA 功能(存储器到存储器)

目录 一、使用DMA实现从存储器1发送数据到存储器2中 1.CUBE_MX配置 2.KEIL5配置 一、使用DMA实现从存储器1发送数据到存储器2中 1.CUBE_MX配置 1.在DMA选项中添加MEMORY TO MEMORY 选择数据宽度&#xff0c;并确保地址递增功能打开。 2.系统时钟72MHz 3.生成代码 2.KEIL5配…

创建Django 项目

创建一个新的 Django 项目&#xff1a; django-admin startproject myproject cd myproject 在 Django 项目中创建一个新的应用&#xff1a; python manage.py startapp myapp设置数据库 编辑 myproject/settings.py 文件中的数据库设置&#xff1a; DATABASES {default:…

研究: 用于训练大型语言模型的数据集往往缺乏透明度

研究人员开发了一种易于使用的工具&#xff0c;使人工智能从业人员能够找到适合其模型目的的数据&#xff0c;从而提高准确性并减少偏差。 这款名为 “数据出处资源管理器”(Data Provenance Explorer) 的新工具可以帮助从业人员在训练模型时对数据做出更明智的选择。 为了训练…

随机规划及其MATLAB实现

目录 引言 随机规划的基本模型 随机动态规划 随机动态规划建模实例​(随机动态规划)&#xff1a; MATLAB中的随机规划实现 示例&#xff1a;两阶段随机规划 表格总结&#xff1a;随机规划求解方法与适用场景 结论 引言 随机规划&#xff08;Stochastic Programming&…

SpringCloud之配置中心svn示例和refresh

SpringCloud之配置中心svn示例和refresh 上一篇配置中心git示例留了一个小问题&#xff0c;当重新修改配置文件提交后&#xff0c;客户端获取的仍然是修改前的信息&#xff0c;这个 问题我们先放下&#xff0c;待会再讲。国内很多公司都使用的svn来做代码的版本控制&#xff…

LabVIEW项目硬件设备选择

在LabVIEW开发项目中&#xff0c;硬件设备的选择至关重要&#xff0c;直接影响系统的性能、稳定性和开发效率。合适的硬件设备不仅能够有效支持项目目标的实现&#xff0c;还能提高整体测试和控制系统的灵活性。因此&#xff0c;从性能需求、兼容性、成本、扩展性等多个角度出发…

vue3 图片裁剪

最终效果 插件下载 pnpm install vue-cropper 配置 在main.js中配置: import VueCropper from vue-cropper; import vue-cropper/dist/index.css;app.use(VueCropper); 组件封装 components/Cropper/index.vue <temp

Linux基础---04vi编辑器指令常用集合及如何恢复意外断开未保存的文件

一.光标移动快键键集合 操作解释h,j,k,l左下上右i在光标位置编辑a在光标后一位编辑o换行编辑&#xff0c;另起一行ctrl f下翻一页ctrl b上翻一页ctrl d下翻半页ctrl u上翻半页数字0跳到行首&#xff0c;也就是跳到第0个字符^跳到行首的第一个字符shift 4跳到行尾shift g…

技术成神之路:设计模式(十三)访问者模式

介绍 访问者模式&#xff08;Visitor Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许你在不改变对象结构的前提下&#xff0c;定义作用于这些对象的新操作。这种模式通过将操作逻辑从对象结构中抽离出来&#xff0c;使得新的操作可以无缝地添加到现有对象中。 1.定…

【漏洞复现】用友 NC pagesServlet Sql注入漏洞

免责声明&#xff1a; 本文内容旨在提供有关特定漏洞或安全漏洞的信息&#xff0c;以帮助用户更好地了解可能存在的风险。公布此类信息的目的在于促进网络安全意识和技术进步&#xff0c;并非出于任何恶意目的。阅读者应该明白&#xff0c;在利用本文提到的漏洞信息或进行相关测…

安装docker-compose最新版本

github下载地址 在github上下载最新版本&#xff0c;这里是centos7的环境直接下载这个就好了。 这里下载好传到服务器即可&#xff0c;这里查看没有权限 需要给文件增加x的执行权限。 ~]# ls -lh 总用量 61M -rw-------. 1 root root 1.7K 7月 29 2022 anaconda-ks.cfg -rw-r…

【最新综述】基于深度学习的超声自动无损检测(下)

4.Levels of automation 5.Basic axioms for DL-based ultrasonic NDE 在回顾了最新技术和每个自动化级别的贡献之后&#xff0c;我们不难发现&#xff0c;目前的数字语言方法论在不同论文之间存在着很大的差异。例如&#xff0c;有些作者提出了同时处理不同步骤的模型[121]&…