C/C++ Qt StringListModel 字串列表對映元件

lyshark發表於2021-12-04

StringListModel 字串列表對映元件,該元件用於處理字串與列表框元件中資料的轉換,通常該元件會配合ListView元件一起使用,例如將ListView元件與Model模型繫結,當ListView元件內有資料更新時,我們就可以利用對映將資料模型中的數值以字串格式提取出來,同理也可實現將字串賦值到指定的ListView元件內。

首先在UI介面中排版

預設的MainWindow::MainWindow建構函式中,我們首先初始化一個QStringList字串連結串列並對該連結串列賦值,通過new QStringListModel(this);建立一個資料模型,並通過ui->listView->setModel(model);屬性將模型與ListView元件繫結,當ListView元件被選中是則觸發on_listView_clicked事件實現輸出當前選中行,其初始化程式碼部分如下:

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QStringList>
#include <QStringListModel>

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

    // 初始化一個StringList字串列表
    QStringList theStringList;
    theStringList << "北京" << "上海" << "廣州";

    // 建立並使用資料模型
    model = new QStringListModel(this);     // 建立模型
    model->setStringList(theStringList);    // 匯入模型資料

    ui->listView->setModel(model);          // 為listView設定模型
    ui->listView->setEditTriggers(QAbstractItemView::DoubleClicked |
                                  QAbstractItemView::SelectedClicked);
}

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

// 當ListView列表項被選中時,顯示QModelIndex的行、列號
void MainWindow::on_listView_clicked(const QModelIndex &index)
{
        ui->LabInfo->setText(QString::asprintf("當前項:row=%d, column=%d",
                            index.row(),index.column()));
}

程式碼執行效果:

新增程式碼:需要通過model->index()獲取到最後一行的索引,然後使用model->setData()追加寫入資料到最後一條索引位置。
插入程式碼: 需要通過ui->listView->currentIndex()獲取到當前游標位置,並呼叫model->setData()插入到指定位置。
刪除程式碼: 直接呼叫model->removeRows()等函式即可將指定位置刪除。

// 新增一行
void MainWindow::on_btnListAppend_clicked()
{
    model->insertRow(model->rowCount());                       // 在尾部插入一行
    QModelIndex index = model->index(model->rowCount()-1,0);   // 獲取最後一行的索引
    QString LineText = ui->lineEdit->text();
    model->setData(index,LineText,Qt::DisplayRole);            // 設定顯示文字
    ui->listView->setCurrentIndex(index);                      // 設定當前行選中
    ui->lineEdit->clear();
}

// 插入一行資料到ListView
void MainWindow::on_btnListInsert_clicked()
{
    QModelIndex index;

    index= ui->listView->currentIndex();             // 獲取當前選中行
    model->insertRow(index.row());                   // 在當前行的前面插入一行
    QString LineText = ui->lineEdit->text();
    model->setData(index,LineText,Qt::DisplayRole);             // 設定顯示文字
    model->setData(index,Qt::AlignRight,Qt::TextAlignmentRole); // 設定對其方式
    ui->listView->setCurrentIndex(index);                       // 設定當前選中行
}

// 刪除當前選中行
void MainWindow::on_btnListDelete_clicked()
{
    QModelIndex index;
    index = ui->listView->currentIndex();    // 獲取當前行的ModelIndex
    model->removeRow(index.row());           // 刪除選中行
}

// 清除當前列表
void MainWindow::on_btnListClear_clicked()
{
   model->removeRows(0,model->rowCount());
}

程式碼執行效果:

如果需要實現將ListView資料模型中的資料匯出到plaintextEdit元件中,則需要通過model->stringList()獲取到ListView中的每行並將其賦值到QStringList字串連結串列中,最後通過迴圈的方式依次插入到plainTextEdit中即可,插入時預設會以逗號作為分隔符。

// 顯示資料模型文字到QPlainTextEdit
void MainWindow::on_btnTextImport_clicked()
{
    QStringList pList;

    pList = model->stringList();    // 獲取資料模型的StringList
    ui->plainTextEdit->clear();     // 先清空文字框

    // 迴圈追加資料
    for(int x=0;x< pList.count();x++)
    {
        ui->plainTextEdit->appendPlainText(pList.at(x) + QString(","));
    }
}

程式碼執行效果:

相關文章