QT_UI设计


mainwindow.h

bash 复制代码
#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

QT_BEGIN_NAMESPACE //命名空间
namespace Ui { class MainWindow; } //ui_MainWindow文件里定义的类,外部声明
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT //宏,使用QT信号和槽机制必须添加

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

private slots:
    void on_pushButton_clicked();
    
private:
    Ui::MainWindow *ui; //Ui::Widget类型的一个指针,指向可视化的界面
};
#endif // MAINWINDOW_H

main.cpp

bash 复制代码
```bash
#include "mainwindow.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv); //定义并创建应用程序 
    MainWindow w; //定义并创建窗口
    w.show(); //窗口显示
    return a.exec(); //应用程序运行,开始消息循环和事件处理
}

mainwindow.cpp

bash 复制代码
#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this); //实现了组件的各种设置,信号和槽的关联
}

MainWindow::~MainWindow()
{
    delete ui; //析构函数
}

void MainWindow::on_pushButton_clicked()
{
    ui->pushButton\
}

写一个简单的QT ui 程序

bash 复制代码
#ifndef DIALOG_H
#define DIALOG_H

#include <QDialog>

QT_BEGIN_NAMESPACE
namespace Ui { class Dialog; }
QT_END_NAMESPACE

class Dialog : public QDialog
{
    Q_OBJECT

public:
    Dialog(QWidget *parent = nullptr);
    ~Dialog();

private slots:
    //void on_PBCancel_clicked();

    //void on_checkBox_stateChanged(int arg1);

    //void on_checkBox_clicked(bool checked);

    //void on_plainTextEdit_textChanged();


    void on_underline_clicked(bool checkd); //构建控件函数的时候记得在头文件中声明完整的控件函数(包括传入参数)

    void on_italic_clicked(bool checked);

    void on_bold_clicked(bool checked);

    void setTextFontColor();

private:
    Ui::Dialog *ui;
};
#endif // DIALOG_H
bash 复制代码
#include "dialog.h"
#include "ui_dialog.h"

Dialog::Dialog(QWidget *parent)
    : QDialog(parent)
    , ui(new Ui::Dialog)
{
    ui->setupUi(this);
    QObject::connect(ui->rBtnRed,SIGNAL(clicked()),this,SLOT(setTextFontColor()));
    QObject::connect(ui->rBtnBlue,SIGNAL(clicked()),this,SLOT(setTextFontColor()));
    QObject::connect(ui->rBtnBlack,SIGNAL(clicked()),this,SLOT(setTextFontColor()));

}

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

//调整控件后记得重新构建,构建控件函数的时候记得在头文件中声明完整的控件函数(包括传入参数)


void Dialog::on_underline_clicked(bool checked)
{
    QFont font = ui->plainTextEdit->font();
    font.setUnderline(checked);
    ui->plainTextEdit->setFont(font);
}


void Dialog::on_italic_clicked(bool checked)
{
    QFont font = ui->plainTextEdit->font();
    font.setItalic(checked);
    ui->plainTextEdit->setFont(font);
}

void Dialog::on_bold_clicked(bool checked)
{
    QFont font = ui->plainTextEdit->font();
    font.setBold(checked);
    ui->plainTextEdit->setFont(font);
}

void Dialog::setTextFontColor()
{
    QPalette plet = ui->plainTextEdit->palette();
    if(ui->rBtnBlack->isChecked())
    plet.setColor(QPalette::Text,Qt::black);
    else if(ui->rBtnBlue->isChecked())
    plet.setColor(QPalette::Text,Qt::blue);
    else if(ui->rBtnRed->isChecked())
    plet.setColor(QPalette::Text,Qt::red);
    else
    plet.setColor(QPalette::Text,Qt::black);
    ui->plainTextEdit->setPalette(plet);

}
相关推荐
OrangeJiuce17 分钟前
【QT中的一些高级数据结构,持续更新中...】
数据结构·c++·qt
程序员-King.3 小时前
【接口封装】——13、登录窗口的标题栏内容设置
c++·qt
虚假程序设计7 小时前
python用 PythonNet 从 Python 调用 WPF 类库 UI 用XAML
python·ui·wpf
敢嗣先锋12 小时前
鸿蒙5.0实战案例:基于原生能力的深色模式适配
ui·移动开发·harmonyos·arkui·组件化·鸿蒙开发
进击ing小白12 小时前
QSplashScreen --软件启动前的交互
qt
柳鲲鹏15 小时前
Ubuntu编译jetlinks-ui-vue
vue.js·ui
终极定律17 小时前
qt:输入控件操作
开发语言·qt
道剑剑非道20 小时前
QT开发技术 【opencv图片裁剪,平均哈希相似度判断,以及获取游戏窗口图片】
qt·opencv·哈希算法
年轮不改20 小时前
ARM Linux平台下 OpenCV Camera 实验
linux·arm开发·qt
Pan_peter21 小时前
零基础学QT、C++(五)QT编译、导入OpenCV
开发语言·c++·qt