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);

}
相关推荐
米优15 分钟前
qt+gstreamer实现播放功能
qt·gstreamer
zjun100129 分钟前
QT:语言翻译
开发语言·qt
久爱物联网1 小时前
【WinForm UI控件系列】Breadcrumb 面包屑控件,支持三种样式
ui·breadcrumb·面包屑控件·winformui·csharpui控件·桌面ui控件
久爱物联网1 小时前
【WinForm UI控件系列】PieChart饼状图控件
ui·winformui控件·c#控件ui·桌面应用ui控件·gdi绘制控件
久爱物联网2 小时前
【WinForm UI控件系列】Blower 鼓风机控件
ui·ui控件·桌面应用控件·鼓风机控件·winfrom控件
-凌凌漆-2 小时前
【Qt】const QString &与QString的区别
开发语言·qt
Drone_xjw2 小时前
Qt QTableView 表头变白问题(Kylin/UKUI系统)原因分析与解决方案
开发语言·qt·kylin
mabing9932 小时前
Qt 实现自定义分段控制器
开发语言·qt
誰能久伴不乏3 小时前
Qt 混合编程核心原理:C++ 与 QML 通信机制详解
linux·c++·qt·架构·状态模式
久爱物联网3 小时前
【WinForm UI控件系列】Battery 电池电量控件
ui·winformui控件·桌面应用控件·c#控件ui·ui控件gdi