qt经典界面框架

目的

其实就是一个简单的界面显示,是很常用的形式。

说起来简单也是简单,但当初,刚开始做时,感觉非常的复杂,不知如何下手。

现在感觉简单多了。

这个框架利用了QT的现成的MainWindow与QDockWidget,这样就很轻松拥有了界面上的组件。

然则,这离系统要加菜单之类的东西,边界的设置,还是有差距的。

这就用到了,QT的界面组合。

QT的界面可以任意的组合,就像搭建积木一样。

情况

界面:

这一个界面很简单,里面有很多可以扩充的地方,扩充好了,就是一个非常漂亮的系统,上面只是一个界面的架子,其它的东西,包括界面,可以任意向里面填充。

最外层是一个 widget,其包含了MainWindows

关键代码如下:

cpp 复制代码
MainView_qss::MainView_qss(QWidget *parent) : QWidget(parent)
{
    m_mainWindow = new MainWindow();
    QVBoxLayout *vlayout_main = new QVBoxLayout();
    this->setLayout(vlayout_main);
    vlayout_main->setContentsMargins(5,5,5,5);
    vlayout_main->setSpacing(0);
    ......
}

mainwindow可以显示多窗体,其有包括了三个QDockWidget,部分代码如下:

v

cpp 复制代码
oid MainWindow::initLogView()
{
    if (nullptr == m_logView)
    {
        m_logView = new QDockWidget(this);
        //set dock widget feature: not move, enable close.
        //|QDockWidget::DockWidgetMovable|QDockWidget::DockWidgetFloatable
        m_logView->setFeatures(QDockWidget::DockWidgetClosable);
        m_logView->setAllowedAreas(Qt::BottomDockWidgetArea);
        m_logView->setWindowTitle("日志输出");
        m_logView->setMaximumHeight(100*8);
        //m_logView->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred);
        m_logBody = new QTextEdit(this);
        //m_logBody->setSizePolicy(QSizePolicy::Preferred, QSizePolicy::Preferred);
        m_logView->setWidget(m_logBody);
    }
    ......
}

工作区的QDocketWidget又包含了QTabWidget,其里面,又可包含很多窗体,关键代码如下:

cpp 复制代码
void MainWindow::initWorkSpaceView()
{
    if (nullptr == m_workspace)
    {
        m_workspace = new QTabWidget(this);
        m_workspace->setWindowTitle("工作区");
        this->setCentralWidget(m_workspace);
        ......
    }
        qDebug() << "工作区 id:" << m_workspace->winId() << ", name:" << m_workspace->windowTitle();
}

总结

说起来简单,不会时,也是很头疼,界面,弄明白了,就很简单了,很简单,上面的事事,可以如下图所示:

项目链接:https://download.csdn.net/download/maokexu123/89464466

相关推荐
mahuifa10 小时前
混合开发环境---使用编程AI辅助开发Qt
人工智能·vscode·qt·qtcreator·编程ai
冷眼看人间恩怨10 小时前
【Qt笔记】QDockWidget控件详解
c++·笔记·qt·qdockwidget
云空14 小时前
《QT 5.14.1 搭建 opencv 环境全攻略》
开发语言·qt·opencv
小老鼠不吃猫16 小时前
力学笃行(二)Qt 示例程序运行
开发语言·qt
晓纪同学17 小时前
QT创建一个模板槽和信号刷新UI
开发语言·qt·ui
爱码小白19 小时前
PyQt5 学习方法之悟道
开发语言·qt·学习方法
人才程序员1 天前
QML z轴(z-order)前后层级
c语言·前端·c++·qt·软件工程·用户界面·界面
学习BigData1 天前
【使用PyQt5和YOLOv11开发电脑屏幕区域的实时分类GUI】——选择检测区域
qt·yolo·分类
yerennuo2 天前
FFmpeg库之ffmpeg
qt·ffmpeg
冷眼看人间恩怨2 天前
【Qt笔记】QComboBox控件详解
c++·笔记·qt