C++ Qt開發:MdiArea多窗體組件

来源:https://www.cnblogs.com/LyShark/archive/2023/12/19/17909890.html
-Advertisement-
Play Games

QMdiArea(Multiple Document Interface Area)是Qt中用於創建多文檔界面的組件。它提供了一種在單個視窗中管理多個文檔的方式,每個文檔通常是一個子視窗(`QMdiSubWindow`)。該組件主要用於設計多文檔界面應用程式,具備有多種窗體展示風格,實現了在父窗體中... ...


Qt 是一個跨平臺C++圖形界面開發庫,利用Qt可以快速開發跨平臺窗體應用程式,在Qt中我們可以通過拖拽的方式將不同組件放到指定的位置,實現圖形化開發極大的方便了開發效率,本章將重點介紹MdiArea組件的常用方法及靈活運用。

QMdiArea(Multiple Document Interface Area)是Qt中用於創建多文檔界面的組件。它提供了一種在單個視窗中管理多個文檔的方式,每個文檔通常是一個子視窗(QMdiSubWindow)。該組件主要用於設計多文檔界面應用程式,具備有多種窗體展示風格,實現了在父窗體中內嵌多種子窗體的功能,使開發者能夠輕鬆地創建支持多個文檔的應用程式。

下麵是一些常用的QMdiArea的方法,說明並概述成表格:

方法 說明
QMdiArea(QWidget *parent = nullptr) 構造函數,創建一個QMdiArea實例。
addSubWindow(QWidget *widget, Qt::WindowFlags flags = Qt::WindowFlags()) 將指定的QWidget添加為QMdiArea的子視窗。
cascadeSubWindows() 將所有子視窗進行層疊排列。
tileSubWindows() 平鋪排列所有子視窗。
closeAllSubWindows() 關閉所有子視窗。
setBackground(const QBrush &background) 設置QMdiArea的背景色或背景圖片。
setViewMode(QMdiArea::ViewMode mode) 設置子視窗排列模式,例如QMdiArea::SubWindowViewQMdiArea::TabbedView
setTabsClosable(bool closable) 設置子視窗標簽是否可關閉。
setTabsMovable(bool movable) 設置子視窗標簽是否可移動。
setTabShape(QTabWidget::TabShape shape) 設置子視窗標簽的形狀,例如QTabWidget::RoundedQTabWidget::Triangular
setDocumentMode(bool enabled) 設置是否以文檔模式顯示子視窗標簽。
setTabPosition(QTabWidget::TabPosition position) 設置子視窗標簽的位置,例如QTabWidget::NorthQTabWidget::South
setActivationOrder(QMdiArea::ActivationOrder order) 設置子視窗的激活順序,例如QMdiArea::StackingOrderQMdiArea::CreationOrder
setTabbedView(bool tabbed) 將QMdiArea設置為標簽視圖,即子視窗以標簽頁的形式顯示。
setOption(QMdiArea::AreaOption option, bool on = true) 設置QMdiArea的選項,例如QMdiArea::DontMaximizeSubWindowOnActivation
activeSubWindow() 返回當前激活的子視窗,如果沒有激活的子視窗則返回nullptr。
closeActiveSubWindow() 關閉當前激活的子視窗。

這隻是一些常用方法的概述,實際上QMdiArea提供了更多的方法和選項,以滿足不同應用場景的需求。開發者可以根據具體需求查閱官方文檔獲取更詳細的信息。

讀者在使用MDI組件時,需要在UI界面中增加mdiArea控制項容器,之後所有窗體創建與操作都要在容器內進行,其次由於MDI窗體組件僅僅是一個畫布只具備限制視窗的作用,無法實現生成窗體,所以需要在項目中手動增加自定義Dialog對話框,並對該對話框進行一定的定製,首先繪製如下案例,其頂部是一個QToolBar組件,底部則是一個QMidArea組件,如下圖;

接著我們需要以此對上述菜單綁定一個唯一的名稱及文本,這個過程可以通過代碼實現,也可以通過圖形化配置,如下圖我們直接通過圖形化模式增加其功能;

1.1 初始化控制項

如下代碼,使用QMdiArea創建多文檔界面的MainWindow類的構造函數和析構函數。

下麵是一些關鍵點的概述:

  1. QMdiArea設置為中央視窗:
    • this->setCentralWidget(ui->mdiArea);QMdiArea設置為主視窗的中央視窗,表示主要的工作區域將由QMdiArea管理。
  2. 主視窗最大化顯示(註釋部分):
    • this->setWindowState(Qt::WindowMaximized); 這是一行註釋掉的代碼,表示將主視窗設置為最大化顯示。你可以根據需要取消註釋,以便在啟動應用程式時視窗最大化。
  3. 工具欄設置:
    • ui->mainToolBar->setToolButtonStyle(Qt::ToolButtonTextUnderIcon); 設置工具欄按鈕的顯示風格為圖標下方顯示文本。這種設置在工具欄上同時顯示圖標和文本,提供了更直觀的用戶界面。
  4. 子視窗模式設置:
    • ui->mdiArea->setViewMode(QMdiArea::SubWindowView);QMdiArea的視圖模式設置為子視窗模式。在子視窗模式下,QMdiArea管理並顯示各個子視窗,允許用戶同時查看和編輯多個文檔。
  5. 析構函數:
    • 析構函數中執行了 delete ui;,確保在對象銷毀時釋放與ui相關的資源,避免記憶體泄漏。

這段代碼片段展示了一個使用QMdiArea創建多文檔界面的主視窗類的基本結構和初始化設置。在這個視窗中,用戶可以打開和管理多個子視窗,每個子視窗可以包含一個獨立的文檔。

MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    this->setCentralWidget(ui->mdiArea);

    // 視窗最大化顯示
    // this->setWindowState(Qt::WindowMaximized);
    ui->mainToolBar->setToolButtonStyle(Qt::ToolButtonTextUnderIcon);

    // 子視窗模式
    ui->mdiArea->setViewMode(QMdiArea::SubWindowView);
}

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

程式打開後可以看到如下圖所示的界面;

1.2 新建與關閉窗體

新建窗體時只需要調用new Dialog創建新的窗體,並通過addSubWindow()將新的窗體指針加入到組件內即可,當關閉時可以直接通過調用closeAllSubWindows()來實現,如下代碼則是創建與關閉的實現。

// 新建窗體
void MainWindow::on_actionOpen_triggered()
{
    // 創建Dialog窗體
    Dialog *formDoc = new Dialog(this);

    // 文檔視窗添加到MDI
    ui->mdiArea->addSubWindow(formDoc);

    // 在單獨的視窗中顯示
    formDoc->show();
}

// 關閉全部
void MainWindow::on_actionClose_triggered()
{
    // 關閉所有子視窗
    ui->mdiArea->closeAllSubWindows();
}

運行後可以點擊打開窗體創建,這個創建是無限制的,如下圖;

1.3 轉換窗體模式

針對模式的轉換此處提供了三種模式,分別是MDI模式、級聯模式及平鋪模式,三種模式的實現只需要調用不同的介面即可實現,代碼如下所示;

// 轉為MDI模式
void MainWindow::on_actionMID_triggered(bool checked)
{
    // Tab多頁顯示模式
    if (checked)
    {
        // Tab多頁顯示模式
        ui->mdiArea->setViewMode(QMdiArea::TabbedView);
        // 頁面可關閉
        ui->mdiArea->setTabsClosable(true);
        ui->actionLine->setEnabled(false);
        ui->actionTile->setEnabled(false);
    }
    // 子視窗模式
    else
    {
        // 子視窗模式
        ui->mdiArea->setViewMode(QMdiArea::SubWindowView);
        ui->actionLine->setEnabled(true);
        ui->actionTile->setEnabled(true);
    }
}

// 恢復預設模式
void MainWindow::on_actionWindow_triggered()
{
    ui->mdiArea->setViewMode(QMdiArea::SubWindowView);
    ui->actionLine->setEnabled(true);
    ui->actionMID->setEnabled(true);
    ui->actionTile->setEnabled(true);
}

// 級聯模式
void MainWindow::on_actionLine_triggered()
{
    ui->mdiArea->cascadeSubWindows();
}

// 平鋪模式
void MainWindow::on_actionTile_triggered()
{
    ui->mdiArea->tileSubWindows();
}

子視窗模式(QMdiArea::SubWindowView)

  • 這是多文檔界面的預設模式,允許用戶在主視窗內同時打開多個子視窗,每個子視窗可以包含一個獨立的文檔或視圖。
  • 子視窗可以重疊、平鋪、級聯等方式排列。

標簽頁多頁顯示模式(QMdiArea::TabbedView)

  • 在這種模式下,子視窗以標簽頁的形式顯示在主視窗的頂部,用戶可以通過點擊標簽頁來切換不同的子視窗。
  • 提供了標簽頁的關閉按鈕,允許用戶關閉特定的標簽頁。

級聯模式和平鋪模式

  • 這兩種模式是在標簽頁多頁顯示模式下的兩種特定排列方式。
  • 級聯模式(Cascade): 子視窗以重疊的方式顯示,類似級聯排列的效果,方便用戶查看和操作每個子視窗。

  • 平鋪模式(Tile): 子視窗以平鋪的方式顯示,使它們在主視窗中均勻分佈,方便用戶同時瀏覽多個子視窗內容。

這些模式提供了不同的用戶體驗,使用戶能夠根據實際需求選擇最適合他們工作流程的視窗排列方式。用戶可以根據應用程式的性質和自己的使用偏好在這些模式之間切換。

完整案例下載

文章出處:https://www.cnblogs.com/LyShark/p/17909890.html
本博客所有文章除特別聲明外,均採用 BY-NC-SA 許可協議。轉載請註明出處!
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 賦值語句的特點 賦值語句創建對象的引用:賦值語句總是創建對象的引用,而不是複製對象。因此,Python中的變數更像是指針,而不是數據儲存區域。 變數在首次賦值時會被創建:因此不需要提前聲明變數。 變數在引用前必須先賦值:如果引用未賦值的變數會報錯 2. 賦值語句的形式 (1. 普通形式 >>> ...
  • 這篇筆記深入介紹了AOP(面向切麵編程),這個技術可以在代碼中以模塊化的方式實現橫切關註點。它解決了業務層代碼中存在的問題,如額外功能代碼的冗餘和每個方法都需要書寫一遍額外功能代碼的情況。 AOP在Spring中的實現主要依靠Aspect切麵、Advice通知和Pointcut切入點的組合。Advi... ...
  • ArrayList是一個使用List介面實現的Java類。顧名思義,Java ArrayList提供了動態數組的功能,其中數組的大小不是固定的。它實現了所有可選的列表操作,並允許所有元素,包括null。 ...
  • 原文: https://openaigptguide.com/ai-picture-generator/ 在人工智慧(AI)圖像生成技術的推動下,各類AI圖片生成網站如雨後春筍般涌現,為我們的日常生活提供了豐富多彩的視覺體驗。 AI圖片生成技術原理 人工智慧(AI)圖片生成技術原理是通過電腦程式使 ...
  • 背景及問題 如下程式所示: #include<iostream> class MyString { public: MyString() = default; MyString(const char* data) { printf("%s", "MyString Constructed!!\n"); ...
  • 引言 在ChatGpt火了這麼久,他的那種單字單字返回的格式可能讓很多朋友感到好奇,在之前我用c#寫了一個版本的,同時支持IAsyncEnumerable以及SSE,今天把之前寫的Java版本的也發出來,和大家一起學習,有不對的地方,歡迎各位大佬指正。 Code 我這邊用的是JDK21版本,可以看到 ...
  • 需求 有些應用每次啟動都需要用管理員許可權運行,比如Python註入dll時,編輯器或cmd就需要以管理員許可權運行,不然註入就會失敗。 這篇文章用編程怎麼修改配置實現打開某個軟體都是使用管理員運行,就不用每次都右鍵點擊以管理員身份運行此程式。主要是給小白配置,防止他忘了以管理員許可權運行,又跑過來問我為 ...
  • Qt 是一個跨平臺C++圖形界面開發庫,利用Qt可以快速開發跨平臺窗體應用程式,在Qt中我們可以通過拖拽的方式將不同組件放到指定的位置,實現圖形化開發極大的方便了開發效率,本章將重點介紹`TableWidget`表格組件的常用方法及靈活運用。`QTableWidget` 是 Qt 中用於顯示表格數據... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...