C++ Qt開發:ComboBox下拉組合框組件

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

在Qt中,ComboBox(組合框)是一種常用的用戶界面控件,它提供了一個下拉列表,允許用戶從預定義的選項中選擇一個。該組件提供了一種方便的方式讓用戶從預定義的選項中進行選擇,一般來說ComboBox會以按鈕的形式顯示在界面上,用戶點擊按鈕後,會彈出一個下拉列表,其中包含預定義的選項。當然ComboBox不僅侷限於選擇,也允許用戶手動輸入內容。

下面是QComboBox類的一些常用方法的說明和概述,按照表格形式列出:

方法 描述
QComboBox(QWidget *parent = nullptr) 構造函數,創建一個組件對象。
addItem(const QString &text, const QVariant &userData = QVariant()) 向組件添加一個項,可以附帶用戶數據。
addItems(const QStringList &texts) 向組件添加多個項,使用字符串列表。
insertItem(int index, const QString &text, const QVariant &userData = QVariant()) 在指定索引處插入一個項。
insertItems(int index, const QStringList &texts) 在指定索引處插入多個項。
removeItem(int index) 移除指定索引處的項。
clear() 清除組件中的所有項。
setCurrentIndex(int index) 設置組件當前選擇的項的索引。
currentText() 返回當前組件中顯示的文本。
currentIndex() 返回當前組件中選擇的項的索引。
count() 返回組件中項的總數。
itemText(int index) 返回指定索引處項的文本。
itemData(int index, int role = Qt::UserRole) 返回指定索引處項的用戶數據。
setItemText(int index, const QString &text) 設置指定索引處項的文本。
setItemData(int index, const QVariant &value, int role = Qt::UserRole) 爲指定索引處項設置額外的數據。
clearEditText() 清除組件的編輯文本。
setEditable(bool editable) 設置組件是否可編輯。如果可編輯,用戶可以手動輸入文本。
setMaxCount(int max) 設置組件中顯示的最大項數。如果超過該數目,將出現垂直滾動條。
setMinimumContentsLength(int characters) 設置組件的最小內容長度,以便顯示完整的項。
setModel(QAbstractItemModel *model) 設置組件的數據模型。通過模型,可以更靈活地管理組件中的項。
view() 返回組件的視圖,允許對視圖進行定製。
clear() 清除組件中的所有項。
showPopup() 打開組件的下拉列表。
hidePopup() 隱藏組件的下拉列表。
activated(int index) 信號,當用戶選擇組件中的項時發出。
currentIndexChanged(int index) 信號,當組件中的當前項發生變化時發出。

上述這些方法提供了對ComboBox進行配置、管理和與之交互的靈活性。你可以根據具體的應用需求使用這些方法,使ComboBox在你的Qt應用程序中按照期望的方式工作。

如下圖所示,我們分別增加三個ComboBox組件,其中前兩個組件是默認的,最後一個是Font ComboBox字體選擇框,其實該選擇框也是標準選擇框的模板,只不過其默認爲我們初始化了系統字體方便選擇而已但在使用上與ComboBox是一致的。

通常情況下使用ComboBox組件與前幾章中所示案例保持一致,只需要通過ui->comboBox_Main->調用不同的屬性即可實現賦值或取值,此處我們來演示一個更復雜的需求,實現選擇組件的聯動效果,即用戶選擇主選擇框時自動列出該主選擇框的子項,這也是開發中最常見的需求。

首先我們先來演示一下如何向Main選擇框內批量追加選項,爲了能更好的展示圖標的導入,此處分別增加browser alt.icoksirtet.ico兩個ICO圖標,讀者可通過 《C++ Qt開發:PushButton按鈕組件》中所使用的方法將圖標導入,接着在主函數初始化中我們可以使用以下代碼將其初始化。

MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    QIcon icon;
    icon.addFile(":/image/ksirtet.ico");

    // 填充第一個Main
    for(int x=0;x<10;x++)
    {
        ui->comboBox_Main->addItem(icon,QString::asprintf("元素_%d",x));
    }

    // 填充第二個SubMain
    icon.addFile(":/image/browser alt.ico");
    for(int x=0;x<10;x++)
    {
        ui->comboBox_SubMain->addItem(icon,QString::asprintf("元素_%d",x));
    }
}

運行上述代碼片段,則可以輸出如下圖所示的效果,可以看到兩個選擇框已被初始化。

接着我們來實現菜單的聯動,該功能的實現依賴於QMap容器,其中Key定義地區,而Value值則定義一個QList該容器類存儲特定地區的城市,如下核心代碼中MainWindow用於初始化,將默認的comboBox_Main填充爲四大地區,依次初始化map容器映射。

#include <iostream>
#include <QList>
#include <QMap>

// --------------------------------------
// 定義全局變量
// --------------------------------------

// 存儲城市與ID
QMap<QString,int> City_Zone;

// 存儲地區與城市
QMap<QString,QList <QString>> map;

// 臨時變量
QList<QString> tmp;

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

    // --------------------------------------------
    // comboBox_Main設置主菜單
    ui->comboBox_Main->clear();
    QStringList str;
    str << "北京" << "上海" << "廣州" << "深圳";

    // 添加元素到主菜單
    ui->comboBox_Main->addItems(str);

    // 依次設置圖標
    ui->comboBox_Main->setItemIcon(0,QIcon(":/image/ksirtet.ico"));
    ui->comboBox_Main->setItemIcon(1,QIcon(":/image/ksirtet.ico"));
    ui->comboBox_Main->setItemIcon(2,QIcon(":/image/ksirtet.ico"));
    ui->comboBox_Main->setItemIcon(3,QIcon(":/image/ksirtet.ico"));

    // --------------------------------------------
    // 設置城市和序號
    ui->comboBox_Main->clear();
    City_Zone.insert("請選擇",0);
    City_Zone.insert("北京",1);
    City_Zone.insert("上海",2);
    City_Zone.insert("廣州",3);
    City_Zone.insert("深圳",4);

    // --------------------------------------------
    // 循環填充一級菜單
    ui->comboBox_Main->clear();
    foreach(const QString &str,City_Zone.keys())
    {
        ui->comboBox_Main->addItem(QIcon(":/image/ksirtet.ico"),str,City_Zone.value(str));
    }

    // --------------------------------------------
    // 插入二級菜單
    tmp.clear();
    tmp << "大興區" << "昌平區" << "東城區" << "西城區";
    map["北京"] = tmp;

    tmp.clear();
    tmp << "黃浦區" << "徐彙區" << "長寧區" << "楊浦區";
    map["上海"] = tmp;

    tmp.clear();
    tmp << "荔灣區" << "越秀區" << "花都區" << "增城區";
    map["廣州"] = tmp;

    tmp.clear();
    tmp << "羅湖區" << "福田區" << "龍崗區" << "光明區";
    map["深圳"] = tmp;

    // 設置默認選擇第4個
    ui->comboBox_Main->setCurrentIndex(4);
}

菜單聯動的第二部則是對特定槽函數的實現,當我們點擊comboBox_Main組件時,觸發currentTextChanged(QString)槽函數,此時只需要在全局map容器內提取出所需要的子標籤,並依次賦值到comboBox_SubMain組件內即可,代碼如下所示;

// 觸發子標籤填充
void MainWindow::on_comboBox_Main_currentTextChanged(const QString &arg1)
{
    ui->comboBox_SubMain->clear();
    QList<QString> qtmp;

    qtmp = map.value(arg1);
    for(int x=0;x<qtmp.count();x++)
    {
        ui->comboBox_SubMain->addItem(QIcon(":/image/browser alt.ico"),qtmp[x]);
    }
}

// 觸發按鈕點擊
void MainWindow::on_pushButton_clicked()
{
    QString one = ui->comboBox_Main->currentText();
    QString two = ui->comboBox_SubMain->currentText();
    std::cout << one.toStdString().data() << " | " << two.toStdString().data() << std::endl;
}

運行後輸出效果如下,當讀者選擇主選擇框時子選擇框將被填充,此時讀者只需要根據標籤號的對應關係,即可判斷用戶選擇了那個選項。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章