【QT】03 QPushButton按钮

3.1 窗口创建(其他组件的容器)

  注意: 组件要依赖窗口存在,因此在学习按钮的时候首先需要创建窗口,后续的按钮或者其他组件,都依赖与该窗口,即都包含在这个窗口中

3.1.1 窗口.h文件

#ifndef MYWIDGET_H
#define MYWIDGET_H

#include <QWidget>//窗口类头文件

class myWidget : public QWidget//自定义窗口继承自QWiget窗口
{
    Q_OBJECT

public:
    myWidget(QWidget *parent = nullptr);
    ~myWidget();
};
#endif // MYWIDGET_H

在这里插入图片描述

3.1.2 窗口.cpp文件

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
   
}

myWidget::~myWidget()
{
}

在这里插入图片描述

3.2 创建按钮

QPushButton类

在这里插入图片描述
  注意:QPushBoutton是按钮控件,因此需要依赖于窗口存在。
  main函数内引入窗口,并显示。
  窗口的创建及相关设置在mywidget.cpp/h中,因此创建按钮等控件的时候在窗口的.cpp文件中创建
在这里插入图片描述

#include "mywidget.h"//窗口头文件:该头文件内包含窗口设置及窗口内的包含的组件设置
#include <QApplication>//应用程序头文件:
int main(int argc, char *argv[])
{
    //(1)创建程序对象
    QApplication a(argc, argv);
    //(2)创建窗口对象
    myWidget w;
    //显示窗口
    w.show();
    return a.exec();
}

3.2.1 创建按钮方法1

   创建代码: QPushButton * btn=new QPushButton
   显示代码: btn—>show(),这种显示方法是独立显示空间,不依赖与窗口

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
    //(2)创建第一个按钮:首先引入头文件
    QPushButton *btn=new QPushButton;
    //2.1 显示按钮
    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
    btn->show();
}
myWidget::~myWidget()
{
}

在这里插入图片描述

3.2.2 设置按钮的依赖(父亲)

   代码: btn->setParent(this);这种显示方法按钮依赖于当前窗口

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
    //(2)创建第一个按钮:首先引入头文件
    QPushButton *btn=new QPushButton;
    //2.1 显示按钮
    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
    //btn->show();
    //2.1.2 方法:让窗口或控件依赖在父窗口中(mywidget窗口)
    btn->setParent(this);
}
myWidget::~myWidget()
{
}

在这里插入图片描述

3.2.3 设置按钮文本

   代码: btn->setText(“第一个按钮”);

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
    //(2)创建第一个按钮:首先引入头文件
    QPushButton *btn=new QPushButton;

    //2.1 显示按钮
    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
    //btn->show();
    //2.1.2 方法:让窗口或控件依赖在父窗口中(mywidget窗口)
    btn->setParent(this);

    //2.2显示按钮上文本
    btn->setText("第一个按钮");

}

myWidget::~myWidget()
{
}

在这里插入图片描述

3.2.4 创建按钮方法2

  创建代码:QPushButton * btn=new QPushButton(“第二个按钮”,this);,
  优点:这种创建方式,自动设置了按钮的名称和按钮的依赖。
  缺点:但是会导致按照按钮组件的大小生成窗口,因此需要重新调整窗口大小

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
//    //(2)创建第一个按钮:首先引入头文件
//    QPushButton *btn=new QPushButton;

//    //2.1 显示按钮
//    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
//    //btn->show();
//    //2.1.2 方法:让窗口或控件依赖在父窗口中(mywidget窗口)
//    btn->setParent(this);
//    //2.2显示按钮上文本
//    btn->setText("第一个按钮");

    //(3)创建第二个按钮:
    //这种方法创建,会按照控件的大小生成窗口,需要重置窗口大小
    QPushButton *btn=new QPushButton("第二个按钮",this);
    //重置窗口大小
    resize(600,400);
}
myWidget::~myWidget()
{
}

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

3.2.5 设置按钮位置

   创建代码: btn2->move(100,100);

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
    //(2)创建第一个按钮:首先引入头文件
    QPushButton *btn=new QPushButton;

    //2.1 显示按钮
    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
    //btn->show();
    //2.1.2 方法:让窗口或控件依赖在父窗口中(mywidget窗口)
    btn->setParent(this);
    //2.2显示按钮上文本
    btn->setText("第一个按钮");

    //(3)创建第二个按钮:
    //这种方法创建,会按照控件的大小生成窗口,需要重置窗口大小
    QPushButton *btn2=new QPushButton("第二个按钮",this);

    //移动按钮
    btn2->move(100,100);

    //重置窗口大小
    resize(600,400);
}
myWidget::~myWidget()
{
}

在这里插入图片描述

3.2.6 设置按钮大小

   创建代码: btn2->move(100,100);

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
    //(2)创建第一个按钮:首先引入头文件
    QPushButton *btn=new QPushButton;
    //2.1 显示按钮
    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
    //btn->show();
    //2.1.2 方法:让窗口或控件依赖在父窗口中(mywidget窗口)
    btn->setParent(this);
    //2.2显示按钮上文本
    btn->setText("第一个按钮");

    //(3)创建第二个按钮:
    //这种方法创建,会按照控件的大小生成窗口,需要重置窗口大小
    QPushButton *btn2=new QPushButton("第二个按钮",this);

    //移动按钮
    btn2->move(100,100);

    //重置窗口大小
    resize(600,400);
    //设置按钮大小
    btn->resize(50,50);

}
myWidget::~myWidget()
{
}


在这里插入图片描述

3.3 窗口操作

3.3.1 设置窗口标题

   创建代码:setWindowTitle(“第一个窗口”);

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
    //(2)创建第一个按钮:首先引入头文件
    QPushButton *btn=new QPushButton;
    //2.1 显示按钮
    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
    //btn->show();
    //2.1.2 方法:让窗口或控件依赖在父窗口中(mywidget窗口)
    btn->setParent(this);
    //2.2显示按钮上文本
    btn->setText("第一个按钮");

    //(3)创建第二个按钮:
    //这种方法创建,会按照控件的大小生成窗口,需要重置窗口大小
    QPushButton *btn2=new QPushButton("第二个按钮",this);

    //移动按钮
    btn2->move(100,100);

    //重置窗口大小
    resize(600,400);

    //设置窗口标题
    setWindowTitle("第一个窗口");

}
myWidget::~myWidget()
{
}

在这里插入图片描述

3.4.2 设置固定窗口大小

   创建代码: setFixedSize(600,400);

#include "mywidget.h"
//(1)引入按钮头文件
#include "QPushButton"
myWidget::myWidget(QWidget *parent)
    : QWidget(parent)
{
    //(2)创建第一个按钮:首先引入头文件
    QPushButton *btn=new QPushButton;
    //2.1 显示按钮
    //2.1.1方法:使用show以顶层的方式弹出窗口或控件(新开辟窗口进行显示)
    //btn->show();
    //2.1.2 方法:让窗口或控件依赖在父窗口中(mywidget窗口)
    btn->setParent(this);
    //2.2显示按钮上文本
    btn->setText("第一个按钮");

    //(3)创建第二个按钮:
    //这种方法创建,会按照控件的大小生成窗口,需要重置窗口大小
    QPushButton *btn2=new QPushButton("第二个按钮",this);

    //移动按钮
    btn2->move(100,100);

    //重置窗口大小
    resize(600,400);

    //设置窗口标题
    setWindowTitle("第一个窗口");

    //设置固定窗口大小
     setFixedSize(600,400);

}

myWidget::~myWidget()
{
}

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用QSS(Qt Style Sheet)来设置QPushButton的颜色。具体方法如下: 1. 在QPushButton所在的窗口或对话框,右键单击选择“添加样式表”。 2. 在弹出的样式表编辑器,输入以下代码: QPushButton { background-color: #FF0000; } 其,#FF0000是十六进制的颜色代码,表示红色。你可以根据需要修改颜色代码。 3. 点击“应用”按钮,即可看到QPushButton的颜色已经改变了。 注意:如果你想对所有QPushButton都设置相同的颜色,可以将上述代码放在应用程序的全局样式表。 ### 回答2: qt可以使用QSS(Qt Style Sheets)来设置QPushbutton的颜色。QSS是基于CSS语法的Qt界面风格表,它允许一个程序员通过CSS样式对QT界面进行美化。 1.设置按钮颜色 如果要设置QPushbutton的背景颜色和前景颜色,可以使用QSS样式表来实现。例如,以下代码将QPushbutton设置为红色背景、白色前景: ```python QPushButton { background-color: red; color: white; } ``` 您可以将这些代码添加到您的qt应用程序,然后使用样式表将QtObject设置为QPushButton类。或者,如果您要设置QPushbutton特定的ID颜色,那么您可以添加以下代码开头: ```python # myButton: QPushButton { background-color: red; color: white; } ``` 这会将具有myButton ID的所有QPushbutton设置为红色背景、白色前景。 2.悬停时更改按钮颜色 有时,您可能想更新QPushbutton的背景颜色和前景颜色,以便在悬停时进行更改。这可以通过以下代码来实现: ```python QPushButton:hover { background-color: green; color: blue; } ``` 当用户将鼠标悬停在QPushbutton上时,此代码将使用绿色背景、蓝色前景更新控件。 3.按下更改按钮颜色 最后,您可能需要通过更改用户按下QPushbutton时的背景颜色和前景颜色,使UI更加互动。这可以通过以下代码来实现: ```python QPushButton:pressed { background-color: orange; color: black; } ``` 当用户按下QPushbutton时,此代码将使用橙色背景、黑色前景更新控件。 总结: 以上是设置QPushbutton按钮颜色的方法,通过QSS样式表可以在QT方便地进行定制。您可以使用这些方法来创建令人愉悦的用户体验,同时使您的UI更加互动。 ### 回答3: 在Qt,QPushButton是最常用的控件之一,它允许用户在界面上进行交互,并触发事件。设置QPushButton的颜色可以使界面更加美观和个性化。下面我们来看一下如何在Qt设置QPushButton的颜色。 在Qt,通常有两种方法可以设置QPushButton的背景颜色:使用CSS和使用QPalette。 使用CSS设置QPushButton的颜色: 1.在Qt Creator,打开界面设计器。从界面构建工具箱将QPushButton拖入界面图形视图。 2.选QPushButton。在属性编辑器的下拉菜单选择StyleSheet,然后单击右侧的小箭头。这将打开CSS编辑器。 3.在CSS编辑器,可以使用CSS语法设置QPushButton的样式。例如,可以使用background-color属性来设置背景颜色。以下是设置背景颜色为红色的样例代码: QPushButton { background-color: red } 4.单击“确定”以保存CSS样式并关闭CSS编辑器。此时,界面设计器的QPushButton将呈现出红色背景色。 使用QPalette设置QPushButton的颜色: 1.在Qt Creator,打开界面设计器。从界面构建工具箱将QPushButton拖入界面图形视图。 2.选QPushButton。在属性编辑器,展开palette属性组并单击编辑按钮。这将打开QPalette编辑器。 3.在QPalette编辑器,可以设置QPushButton使用的颜色组合。例如,可以设置背景颜色为红色。以下是设置背景色为红色的样例代码: palette.setColor(QPalette::Button, QColor(Qt::red)); 4.单击“确定”以保存QPalette并关闭QPalette编辑器。此时,界面设计器的QPushButton将呈现出红色背景色。 总之,无论是使用CSS还是QPalette,都可以轻松地设置QPushButton的颜色,从而使界面更加个性化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值