<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                # Qt5 中的菜單和工具欄 > 原文: [http://zetcode.com/gui/qt5/menusandtoolbars/](http://zetcode.com/gui/qt5/menusandtoolbars/) 在 Qt5 C++ 編程教程的這一部分中,我們將討論 Qt5 應用中的菜單和工具欄。 菜單欄是 GUI 應用的常見部分。 它是位于各個位置(稱為菜單)的一組命令。 菜單將我們可以在應用中使用的命令分組。 使用工具欄可以快速訪問最常用的命令。 ## 簡單菜單 第一個示例顯示了一個簡單的菜單。 `simplemenu.h` ```cpp #pragma once #include <QMainWindow> #include <QApplication> class SimpleMenu : public QMainWindow { public: SimpleMenu(QWidget *parent = 0); }; ``` 這是我們的代碼示例的頭文件。 `simplemenu.cpp` ```cpp #include "simplemenu.h" #include <QMenu> #include <QMenuBar> SimpleMenu::SimpleMenu(QWidget *parent) : QMainWindow(parent) { QAction *quit = new QAction("&Quit", this); QMenu *file; file = menuBar()->addMenu("&File"); file->addAction(quit); connect(quit, &QAction::triggered, qApp, QApplication::quit); } ``` 我們有一個菜單欄,一個菜單和一個動作。 為了使用菜單,我們必須從`QMainWindow`小部件繼承。 ```cpp QAction *quit = new QAction("&Quit", this); ``` 此代碼行創建一個`QAction`。 每個`QMenu`具有一個或多個動作對象。 ```cpp QMenu *file; file = menuBar()->addMenu("&File"); ``` 我們創建一個`QMenu`對象。 ```cpp file->addAction(quit); ``` 我們使用`addAction()`方法在菜單中放置一個動作。 ```cpp connect(quit, &QAction::triggered, qApp, QApplication::quit); ``` 當我們從菜單中選擇此選項時,應用退出。 `main.cpp` ```cpp #include "simplemenu.h" int main(int argc, char *argv[]) { QApplication app(argc, argv); SimpleMenu window; window.resize(250, 150); window.setWindowTitle("Simple menu"); window.show(); return app.exec(); } ``` 主文件。 ![Simple menu](https://img.kancloud.cn/b2/c3/b2c3a458fcf317c4483aa39c18856b89_252x176.jpg) 圖:簡單菜單 ## 圖標,快捷方式和分隔符 在以下示例中,我們將進一步增強以前的應用。 我們將圖標添加到菜單,使用快捷方式和分隔符。 `anothermenu.h` ```cpp #pragma once #include <QMainWindow> #include <QApplication> class AnotherMenu : public QMainWindow { public: AnotherMenu(QWidget *parent = 0); }; ``` 該示例的頭文件。 `anothermenu.cpp` ```cpp #include "anothermenu.h" #include <QMenu> #include <QMenuBar> AnotherMenu::AnotherMenu(QWidget *parent) : QMainWindow(parent) { QPixmap newpix("new.png"); QPixmap openpix("open.png"); QPixmap quitpix("quit.png"); QAction *newa = new QAction(newpix, "&New", this); QAction *open = new QAction(openpix, "&Open", this); QAction *quit = new QAction(quitpix, "&Quit", this); quit->setShortcut(tr("CTRL+Q")); QMenu *file; file = menuBar()->addMenu("&File"); file->addAction(newa); file->addAction(open); file->addSeparator(); file->addAction(quit); qApp->setAttribute(Qt::AA_DontShowIconsInMenus, false); connect(quit, &QAction::triggered, qApp, &QApplication::quit); } ``` 在我們的示例中,我們有一個包含三個動作的菜單。 如果我們選擇退出操作,則實際上只有退出操作才可以執行某些操作。 我們還創建一個分隔符和`CTRL+Q`快捷方式,以終止應用。 ```cpp QPixmap newpix("new.png"); QPixmap openpix("open.png"); QPixmap quitpix("quit.png"); ``` 這些是我們在菜單中使用的圖像。 請注意,某些桌面環境可能不會在菜單中顯示圖像。 ```cpp QAction *newa = new QAction(newpix, "&New", this); QAction *open = new QAction(openpix, "&Open", this); QAction *quit = new QAction(quitpix, "&Quit", this); ``` 在此代碼中,我們將`QAction`構造器與像素映射用作第一個參數。 ```cpp quit->setShortcut(tr("CTRL+Q")); ``` 在這里,我們創建鍵盤快捷鍵。 通過按下此快捷方式,我們將運行退出操作,該操作將退出應用。 ```cpp file->addSeparator(); ``` 我們創建一個分隔符。 分隔符是一條水平線,使我們能夠將菜單操作分組為一些邏輯組。 ```cpp qApp->setAttribute(Qt::AA_DontShowIconsInMenus, false); ``` 在某些環境中,默認情況下不顯示菜單圖標。 在這種情況下,我們可以禁用`Qt::AA_DontShowIconsInMenus`屬性。 `main.cpp` ```cpp #include "anothermenu.h" int main(int argc, char *argv[]) { QApplication app(argc, argv); AnotherMenu window; window.resize(350, 200); window.setWindowTitle("Another menu"); window.show(); return app.exec(); } ``` 這是主文件。 ![Another menu example](https://img.kancloud.cn/07/33/07332225e498dc2529e8c693a82ea654_352x226.jpg) 圖:另一個菜單示例 ## 復選菜單 在下一個示例中,我們創建一個復選菜單。 這將是帶有復選框的操作。 該選項可切換狀態欄的可見性。 `checkable.h` ```cpp #pragma once #include <QMainWindow> #include <QApplication> class Checkable : public QMainWindow { Q_OBJECT public: Checkable(QWidget *parent = 0); private slots: void toggleStatusbar(); private: QAction *viewst; }; ``` 該示例的頭文件。 `checkable.cpp` ```cpp #include "checkable.h" #include <QMenu> #include <QMenuBar> #include <QStatusBar> Checkable::Checkable(QWidget *parent) : QMainWindow(parent) { viewst = new QAction("&View statusbar", this); viewst->setCheckable(true); viewst->setChecked(true); QMenu *file; file = menuBar()->addMenu("&File"); file->addAction(viewst); statusBar(); connect(viewst, &QAction::triggered, this, &Checkable::toggleStatusbar); } void Checkable::toggleStatusbar() { if (viewst->isChecked()) { statusBar()->show(); } else { statusBar()->hide(); } } ``` 復選菜單項切換狀態欄的可見性。 ```cpp viewst = new QAction("&View statusbar", this); viewst->setCheckable(true); viewst->setChecked(true); ``` 我們創建一個動作,并使用`setCheckable()`方法對其進行檢查。 `setChecked()`方法進行檢查。 ```cpp if (viewst->isChecked()) { statusBar()->show(); } else { statusBar()->hide(); } ``` 在`toggleStatusbar()`方法內部,我們確定菜單項是否已選中,并相應地隱藏或顯示狀態欄。 `main.cpp` ```cpp #include "checkable.h" int main(int argc, char *argv[]) { QApplication app(argc, argv); Checkable window; window.resize(250, 150); window.setWindowTitle("Checkable menu"); window.show(); return app.exec(); } ``` 這是主文件。 ![Checkable menu](https://img.kancloud.cn/f3/3e/f33e203f0a10e250cf864b4319d56d94_252x176.jpg) 圖:可選菜單 ## `QToolBar` `QToolBar`類提供了一個可移動面板,其中包含一組控件,這些控件可快速訪問應用動作。 `toolbar.h` ```cpp #pragma once #include <QMainWindow> #include <QApplication> class Toolbar : public QMainWindow { Q_OBJECT public: Toolbar(QWidget *parent = 0); }; ``` 該示例的頭文件。 `toolbar.cpp` ```cpp #include "toolbar.h" #include <QToolBar> #include <QIcon> #include <QAction> Toolbar::Toolbar(QWidget *parent) : QMainWindow(parent) { QPixmap newpix("new.png"); QPixmap openpix("open.png"); QPixmap quitpix("quit.png"); QToolBar *toolbar = addToolBar("main toolbar"); toolbar->addAction(QIcon(newpix), "New File"); toolbar->addAction(QIcon(openpix), "Open File"); toolbar->addSeparator(); QAction *quit = toolbar->addAction(QIcon(quitpix), "Quit Application"); connect(quit, &QAction::triggered, qApp, &QApplication::quit); } ``` 要創建工具欄,我們從`QMainWindow`小部件繼承。 ```cpp QToolBar *toolbar = addToolBar("main toolbar"); ``` `addToolBar()`方法創建一個工具欄并返回指向它的指針。 ```cpp toolbar->addAction(QIcon(newpix), "New File"); toolbar->addAction(QIcon(openpix), "Open File"); toolbar->addSeparator(); ``` 在這里,我們向工具欄添加了兩個動作和一個分隔符。 `main.cpp` ```cpp #include "toolbar.h" int main(int argc, char *argv[]) { QApplication app(argc, argv); Toolbar window; window.resize(300, 200); window.setWindowTitle("QToolBar"); window.show(); return app.exec(); } ``` 這是主文件。 ![QToolBar](https://img.kancloud.cn/8c/de/8cde06d4c6b658c1fd55834668951088_302x226.jpg) 圖:`QToolBar` ## 應用框架 在 C++ Qt5 教程的這一部分的最后,我們創建了一個應用框架。 該示例主要基于`QMainWindow`小部件。 `skeleton.h` ```cpp #pragma once #include <QMainWindow> #include <QApplication> class Skeleton : public QMainWindow { Q_OBJECT public: Skeleton(QWidget *parent = 0); }; ``` 該示例的頭文件。 `skeleton.cpp` ```cpp #include "skeleton.h" #include <QToolBar> #include <QIcon> #include <QAction> #include <QMenu> #include <QMenuBar> #include <QStatusBar> #include <QTextEdit> Skeleton::Skeleton(QWidget *parent) : QMainWindow(parent) { QPixmap newpix("new.png"); QPixmap openpix("open.png"); QPixmap quitpix("quit.png"); QAction *quit = new QAction("&Quit", this); QMenu *file; file = menuBar()->addMenu("&File"); file->addAction(quit); connect(quit, &QAction::triggered, qApp, &QApplication::quit); QToolBar *toolbar = addToolBar("main toolbar"); toolbar->addAction(QIcon(newpix), "New File"); toolbar->addAction(QIcon(openpix), "Open File"); toolbar->addSeparator(); QAction *quit2 = toolbar->addAction(QIcon(quitpix), "Quit Application"); connect(quit2, &QAction::triggered, qApp, &QApplication::quit); QTextEdit *edit = new QTextEdit(this); setCentralWidget(edit); statusBar()->showMessage("Ready"); } ``` 在這里,我們創建一個菜單,一個工具欄和一個狀態欄。 ```cpp QTextEdit *edit = new QTextEdit(this); setCentralWidget(edit); ``` 我們創建一個`QTextEdit`小部件,并將其放入`QMainWindow`小部件的中央部分。 `main.cpp` ```cpp #include "skeleton.h" int main(int argc, char *argv[]) { QApplication app(argc, argv); Skeleton window; window.resize(350, 250); window.setWindowTitle("Application skeleton"); window.show(); return app.exec(); } ``` 這是主文件。 ![Application skeleton](https://img.kancloud.cn/e2/cc/e2cccb5959fd9203c1b081c812ca8daf_352x276.jpg) 圖:應用骨架 在 Qt5 教程的這一部分中,我們介紹了菜單和工具欄。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看