Qt之按钮(QPushButton)

举报
人才程序员 发表于 2023/07/26 11:35:14 2023/07/26
【摘要】 @TOC 前言使用的qt版本为5.9提示:以下是本篇文章正文内容,下面案例可供参考 一、使用代码创建按钮使用QPushButton类即可创建按钮提示:在函数内要使用指针,类成员可以使用普通成员QPushButton *btn = new QPushButton(this);//参数:父类QPushButton btn2(this); 父类的概念如果是Qt组件的话:则指定这个Qt组件在哪里Qt...

@TOC

前言

使用的qt版本为5.9

提示:以下是本篇文章正文内容,下面案例可供参考

一、使用代码创建按钮

使用QPushButton类即可创建按钮
提示:在函数内要使用指针,类成员可以使用普通成员

QPushButton *btn = new QPushButton(this);//参数:父类
QPushButton btn2(this);

父类的概念

如果是Qt组件的话:则指定这个Qt组件在哪里Qt组件里面显示。
特点:声明的指针不需要自己释放。

指定组件的父类

setParent(QWidget *w);
//还有其他重载,只要知道这一个就可以

按钮的属性

获取和设置按钮上的文本

QString text() const
void setText(const QString &text)

设置按钮上的图标

QIcon icon() const
void setIcon(const QIcon &icon)

实验:

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{
    QPushButton *btn = new QPushButton(this);//指定父类为本窗口
    btn->setText("QPushButton");
    btn->move(10,10);
    //btn->setIcon(图片路径);
}

二、信号与槽的概念

在Qt中,一个组件是可以发送一个东西给另一个组件的,这个操作就是信号与槽。
信号与槽必须在Qt组件和Qt组件之间。

如何定义槽函数

和普通函数无差别。只是在类的修饰符要为private slots,在类的开头要为Q_OBJECT

void clicked()
{
	
}

连接信号与槽

connect(sender*,SIGNAL(信号),Receiver*,SLOT(槽函数));

当信号触发就会执行槽函数。

log打印

实验"qDebug() << "打印文本

实验:

/*.h*/
#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>

class Widget : public QWidget
{
    Q_OBJECT
    QPushButton * btn;

public:
    Widget(QWidget *parent = 0);
    ~Widget();
    
private slots:
    void click();
};

#endif // WIDGET_H


/*.cpp*/
#include "widget.h"
#include <QPushButton>
#include <QDebug>

Widget::Widget(QWidget *parent)
    : QWidget(parent)
{
    QPushButton *btn = new QPushButton(this);//指定父类为本窗口
    btn->setText("QPushButton");
    btn->move(10,10);
    
    connect(btn,SIGNAL(clicked()),this,SLOT(clicked()));
}

void Widget::click()
{
    qDebug() << "clicked";
}

点击按钮就会打印"clicked"

三、使用ui文件创建按钮

创建ui文件

1、在创建项目时,选择窗口,选择ui文件
2、右键项目,Qt,Qt设计师界面类,选择窗口类型。

在右边可以看到很多东西,我们把PushButton拖出来就可以了。

改变样式表

右键组件,改变样式表。
可以改变字体。
可以改变颜色–>要点击添加颜色右边的小箭头,去选择你需要的。

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。