【VS Code 與 Qt6】QAction 類的一些事

来源:https://www.cnblogs.com/tcjiaan/archive/2023/07/29/17590107.html
-Advertisement-
Play Games

QAction 類表示用戶命令的一種抽象,包括命令文本、圖標、命令觸發後要執行的代碼。菜單、工具欄按鈕往往存在相同的功能,將這些命令獨立抽出來,放到 QAction 以象上,可避免編寫重覆的代碼。比如“文件”菜單下有“保存”命令,工具欄上也會有“保存”按鈕。因此,創建一個表示“保存”的 QActio ...


QAction 類表示用戶命令的一種抽象,包括命令文本、圖標、命令觸發後要執行的代碼。菜單、工具欄按鈕往往存在相同的功能,將這些命令獨立抽出來,放到 QAction 以象上,可避免編寫重覆的代碼。比如“文件”菜單下有“保存”命令,工具欄上也會有“保存”按鈕。因此,創建一個表示“保存”的 QAction 對象,同時添加到菜單和工具欄中,它們就能共用相同的功能。

以上F話了這麼多,就是為了明確 QAction 類的作用。在創建 QAction 實例時,可以通過構造函數傳遞命令的文本,或圖標。如果在調用構造函數時不指定,那麼可以用下麵這些方法來“補做”:

1、setText 方法:設置命令文本。顯示在用戶界面上的文本;

2、setIcon 方法:看名識義,就是設置圖標;

3、setFont 方法:在呈現命令文本時用的字體。一般不需要特意去指定字體,它會繼承應用程式的預設字體;

4、setShortcut:設置命令的快捷鍵。

QAction 類有個核心的信號:triggered,當用戶通過點擊或快捷鍵激活菜單項或工具欄按鈕,就會發出 triggered 信號。

 

下麵咱們做個簡單的例子。這裡我用到了 QMainWindow 類來充當主視窗,因為它的“視窗功能”比較完善,創建個菜單欄、工具欄和狀態欄的都比較方便。

CMake 文件:

cmake_minimum_required(VERSION 3.20)
# 項目
project(myApp VERSION 1.0.0 LANGUAGES CXX)
find_package(Qt6 REQUIRED COMPONENTS Gui Core Widgets)
# 開啟MOC
set(CMAKE_AUTOMOC ON)
# 語言標準
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

# 源文件
add_executable(app WIN32 me.cpp)
target_link_libraries(app PRIVATE Qt6::Core Qt6::Gui Qt6::Widgets)

me.cpp 文件:

#include <QApplication>
#include <QMainWindow>
#include <QMenuBar>
#include <QMessageBox>
#include <QMenu>
#include <QAction>
#include <QIcon>

// 這三個逗丁用來接收信號的,slot 函數
void onNew();
void onSave();
void onExit();

int main(int argc, char** argv)
{
    QApplication app(argc,argv);
    // 創建主視窗
    QMainWindow win;
    // 視窗標題
    win.setWindowTitle("整活兒");
    // 這樣獲取,預設會創建空的菜單欄
    QMenuBar* menubar = win.menuBar();
    // 添加“文件”菜單
    QMenu* fileMenu = menubar -> addMenu("文件");
    // 創建三個QAction對象
    QAction *act1 = new QAction("新建", &win);
    QAction *act2 = new QAction("保存", &win);
    QAction *act3 = new QAction("退出", &win);
    // 連接triggered信號
    QObject::connect(act1, &QAction::triggered, &onNew);
    QObject::connect(act2, &QAction::triggered, &onSave);
    QObject::connect(act3, &QAction::triggered, &onExit);
    // 把三個action添加到菜單中
    fileMenu->addAction(act1);
    fileMenu->addAction(act2);
    fileMenu->addAction(act3);

    // 顯示主視窗
    win.show();
    // 進入事件迴圈
    return QApplication::exec();
}

void onNew()
{
    QMessageBox::information(nullptr, "提示", "新建文件");
}

void onSave()
{
    QMessageBox::information(nullptr, "提示", "保存文件");
}

void onExit()
{
    QApplication::exit();
}

QMainWindow 的 menuBar 方法用來獲取菜單欄(QMenuBar)引用的。但,當視窗中未設置過菜單欄時,它會自動創建一個空菜單欄,並將其引用返回。返回的 QMenu 對象表示菜單,調用它的 addAction 方法就能添加菜單項了。菜單項用 QAction 表示。

onNew、onSave、onExit 這三個函數分別作為三個 QAction 對象的 slot 函數,接收 triggered 信號。

運行後,你會看到,QAction 對象指定的文本,會自動呈現在菜單文本中。

 

通常,為了讓菜單命令更直觀,咱們會在重要的菜單項上加上圖標。接下來給上述三個 action 添上小圖標。這裡老周介紹一個獲取圖標的網站,很好用,要啥圖標,進去後直接搜索就行,而且可以選擇多尺寸下載。比那些要強制登錄才能用的騷站好很多。

瀏覽器打開 Download 1,301,500 free icons (SVG, PNG) (icons8.com)

菜單上的圖標,用 16×16 就夠了。把圖標文件放在與應用程式可執行文件相同的路徑下,依次命名為 new.png、save.png、exit.png。

接著,改一下代碼,需要用 QAction 帶 QIcon 參數的構造函數。

QAction *act1 = new QAction(QIcon("new.png"), "新建", &win);
QAction *act2 = new QAction(QIcon("save.png"), "保存", &win);
QAction *act3 = new QAction(QIcon("exit.png"), "退出", &win);

再次編譯,運行,效果如下:

 

對於常用的命令,有快捷鍵能大大提升效率。快捷鍵需要用到 QKeySequence 類。該類在 QtGui 基礎模塊中。這個類在調用構造函數時有一種特特簡單的用法,就是直接用字元串來描述快捷鍵。這些字元要求是人類可讀性較高的。比如下麵這些:

Ctrl+F               // Ctrl + F
Shift+H             // Shift+ H
Alt+W
Ctrl+Alt+E
F5           // 就是 F5    
D            // 就是字母D

給上面示例的三個菜單加上快捷鍵。

act1->setShortcut(QKeySequence("Ctrl+N"));
act2->setShortcut(QKeySequence("ctrl+S"));
act3->setShortcut(QKeySequence("Alt+E"));

描述按鍵的字元串不區分大小寫,所以,“Alt+E”和“alt+e”一樣。快捷鍵會顯示在菜單命令文本的右邊。如下所示

這時候,只要按下 Alt + E,程式就會退出。

 

應用程式除了菜單欄,通常還有工具欄(QToolBar)。QAction 類是命令的抽象,它可以在菜單欄與工具欄之間共用。所以,咱們上面的示例也可以加上工具欄。

// 創建三個QAction對象
QAction *act1 = new QAction(QIcon("new.png"), "新建", &win);
QAction *act2 = new QAction(QIcon("save.png"), "保存", &win);
QAction *act3 = new QAction(QIcon("exit.png"), "退出", &win);
……
// 創建工具欄
QToolBar *toolbar = new QToolBar(&win);
// 將那三個命令添加到工具欄
toolbar->addAction(act1);
toolbar->addAction(act2);
toolbar->addAction(act3);
// 工具欄添加到主視窗
win.addToolBar(toolbar);

重新編譯運行,結果如下:

 

QAction 的 triggered 信號是這樣定義的:

void QAction::triggered(bool checked = false)

它有個 bool 類型的參數,預設是 false。幹嗎用的呢?這是處理帶 check 功能的菜單用的。就是那種點一下 on,再點一下 off 的那種。咱們在上面的示例中增加一個“開機啟動”菜單項。

QAction *act4 = new QAction("開機啟動", &win);
// 開啟check功能
act4->setCheckable(true);

QObject::connect(act4, &QAction::triggered, &onAutoStart);
fileMenu->addAction(act4);

// 這個是slot函數
void onAutoStart(bool checked)
{
    if(checked){
        QMessageBox::information(nullptr,"提示", "程式開機啟動");
    }
    else
    {
        QMessageBox::information(nullptr,"提示","已取消開機啟動");
    }
}

setCheckable 方法如果傳遞 true,表示開啟 check 功能;若 false,關閉 check 功能。

當可check菜單處於 on 狀態時,它前面會顯示一個勾。如下圖所示:

 

有些時候,菜單命令的預設用戶界面不太符合需要。為了方便用戶操作,我可能想放一個別的 Widget 上去(比如放個滑塊條)。QAction 類做不到這個,但它的派生類可以:QWidgetAction。

咱們在菜單欄上添加一個顯示 QSpinBox 組件的命令。

// 創建spinBox組件
QSpinBox *spinbox = new QSpinBox(&win);
spinbox->show();
// 設置一下範圍0-300
spinbox->setRange(0, 300);
// 預設顯示的值50
spinbox->setValue(50);
// 將它放到工具欄和菜單上
QWidgetAction *act5 = new QWidgetAction(&win);
act5->setDefaultWidget(spinbox);

fileMenu->addAction(act5);

QWidgetAction 在實例化後,調用 setDefaultWidget 方法關聯要顯示在菜單上的組件即可。當然,咱們可以從 QWidgetAction 類派生出自己的類,來實現更高級的需求。這個老周留到下次寫水文時再說。

編譯運行,看看菜單的最後一項,有趣吧。

 

==========================================================================

好了,今天的話題就聊完了。下麵又是老周講故事時間。

以前老周分享過改 VS Code 全視窗背景的方法,就是設置 <body> 元素的背景圖,然後適當調一調透明度。

但,如果你不喜歡那樣覆蓋整個視窗,我只是想打開代碼編輯器時才看到背景圖呢。嗯,也就是只設置編輯器的背景圖。原理一樣,都是改 CSS 樣式。打開VS Code程式目錄下的 resources\app\out\vs\workbench\workbench.desktop.main.css 樣式表,添加以下樣式:

.monaco-editor, .monaco-editor-background {
  background: center/32% no-repeat url('vscode-file://vscode-app/c:/users/mmm/pictures/bg/20.png') !important;
}

對的,就是設置 background 屬性,後面的 important 表示強行覆蓋,不然不會生效。圖片URL 是 vscode-file 協議,加上 vscode-app 首碼,然後就是圖片的完整路徑。center/32% 表示圖片居中對齊,32% 是縮小圖片,變為原尺寸的32%,這個你得根據你的圖片自己調,調到合適就好。

建議使用透明背景的 PNG 圖片,因為太花的圖片會幹擾你寫代碼的。CSS 不要用 opacity 來調整透明度,因為這樣一調,連代碼的透明度也跟著變了,很影響視線,看不清代碼,容易導致高度近視。咱們可以在圖片上做手腳,就是讓原圖也具有一定的透明度。

方法是用 PS 打開圖片,在圖層面板的“不透明度”,改為 15-20% ,具體哪個值你也可以試試,只要看著舒服就行。

設置完後,效果如下:

《初代萌王陪我寫代碼》,豈不美哉!

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Windows 服務預設的遠程桌面服務埠號是3389,在創建完Azure VM之後基本都會添加一個any to any的防火牆規則,方便多人登錄這個機器。 但是隨時隨地的3389掃描搞得我很煩,就修改了預設的windows 遠程桌面服務的埠號,修改完沒有在VM里的windows 自帶防火牆中添加 ...
  • 千呼萬喚始出來的新版本MySQL 8.1及MySQL 8.0.34於2023年7月18日正式發行。從此,MySQL將開啟創新版和穩定版同時發行的階段。MySQL 8.1是MySQL的首個創新版,該版本主要增加瞭如下功能: 捕捉EXPLAIN FORMAT=JSON輸出, 為EXPLAIN FORMA ...
  • “莆仙小館”——莆田文化展示APP 文化展示程式目的在於應用科學技術助推家鄉優秀傳統文化的展示與交流。通過圖片、視頻、音頻等展示方式向用戶立體地展示一個文化城邦。傳統文化與科學技術的有效融合,順應了社會發展的需要。傳統文化與科學技術的有效融合是發展中國特色社會主義文化的客觀需要,是傳承中國優秀傳統文 ...
  • 摘要:本文將介紹 Vue 2 和 Vue 3 中 `toRefs` 函數的不同用法和行為,並解釋其在各個版本中的作用。 正文: Vue 是一款流行的 JavaScript 框架,用於構建用戶界面。在 Vue 2 和 Vue 3 中,都存在一個名為 `toRefs` 的函數,但其行為在這兩個版本中有所 ...
  • 博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
  • # Spring Cloud Demo 本文介紹Spring Cloud 常用的組件的demo代碼。gitee代碼:https://gitee.com/Aes_yt/spring-cloud-demo 包括Spring Cloud Eureka,Spring Cloud Feign,Spring C ...
  • Java解析、生成Excel比較有名的框架有Apache poi、jxl。但他們都存在一個嚴重的問題就是非常的耗記憶體,poi有一套SAX模式的API可以一定程度的解決一些記憶體溢出的問題,但POI還是有一些缺陷,比如07版Excel解壓縮以及解壓後存儲都是在記憶體中完成的,記憶體消耗依然很大。easyex ...
  • # Java 多態 # 1. 多態 ## 方法或對象具有多種形態。是面向對象的三大特征之一,多態是建立在封裝、繼承基礎之上的 # 2. 多態的實現: ## 方法的重載中,使用不同的形參調用方法體現出了多態 ## 方法的重寫中,使用父類或子類的對象調用方法體現出了多態 ## 對象的多態: ## 對象的 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...