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

相关推荐
苕皮蓝牙土豆10 小时前
Qt图形视图框架入门:坐标系统与鼠标事件处理详解
c++·qt
纤纡.11 小时前
基于 PyQt5 的桌面应用开发实战:登录、预测、计算器、摄像头多功能系统
开发语言·人工智能·qt·计算机视觉
Fleshy数模13 小时前
PyQt5 登录界面开发全流程:从环境配置到可视化设计
开发语言·python·qt
用户8055336980315 小时前
现代Qt开发教程(新手篇)1.6——内存管理
c++·qt
m0_5027249516 小时前
qt键盘钩子完善
stm32·qt·计算机外设
广州灵眸科技有限公司16 小时前
瑞芯微(EASY EAI)RV1126B QT GUI例程方案
linux·服务器·开发语言·网络·人工智能·qt·物联网
xcjbqd016 小时前
Qt Quick中QML与C++交互详解及场景切换实现
c++·qt·交互
小樱花的樱花17 小时前
5 实现文件打开功能
开发语言·数据库·c++·qt·ui
Drone_xjw1 天前
一次 Qt 程序在 Kylin 系统下表头“白屏”的排查之旅
qt·kylin·一次
尘中远1 天前
Qwt 7.0 新特性介绍 — 更现代、更强大的Qt数据可视化库
qt·qwt·科学绘图·曲线图