QT5 QListView表格中添加复选框CheckBox

由于最近项目中需要用到在表格每行第一列添加复选框checkBox,用于选择是否打开IO板对应外部界接口,拟实现类似如下效果

 

在C#中对于ListView表格,可通过直接设置属性ListView.CheckBoxes=true来实现,但是QT中QStandardItemModel没有对应的function,需要通过其他方式来实现,可参考以下博文:https://www.cnblogs.com/godcity/p/5957256.html。博文中的实现方式可根据继承的不同类表格实现该功能

(1)对于QListWidgetItem类表格

QListWidgetItem *item = new QListWidgetItem;
item->setData( Qt::DisplayRole, "text" );
item->setData( Qt::CheckStateRole, Qt::Checked );
listWidget->addItem( item );

(2)对于QStandardItemModel类表格

QStandardItemModel *model = new QStandardItemModel();
QStandardItem *Item = new QStandardItem();
Item->setCheckable( true );
Item->setCheckState( Qt::Checked );
model->setItem( 0, Item ); 
listView->setModel( model );

我的具体项目,用到第二中类型,QT中实现如下:

在UI界面中添加TableView表格控件

(1)MainWindow.h中声明

QStandardItemModel *modelTabIOOut; //Tab表模型
QStandardItem *Item_IOCheckBox[32]; //表格共设置32行,需要32个Item_IOCheckBox复选框类对象

此处需注意用到对象数组动态初始化

类名称[] 对象数组名 = new 类名称[3];
对象数组名[0] = 对象;
对象数组名[1] = 对象;
对象数组名[2] = 对象;

在MainWindow.cpp的构造函数中

modelTabIOOut = new QStandardItemModel();//输出IO表格
for(int i=0;i<32;i++)
{
   Item_IOCheckBox[i] = new QStandardItem();
}

在MainWindow.cpp的初始化函数中

//输出IO表格模型
modelTabIOOut->setColumnCount(3);//设置列数
modelTabIOOut->setRowCount(32);//设置行数
modelTabIOOut->setHeaderData(0,Qt::Horizontal," ");
modelTabIOOut->setHeaderData(1,Qt::Horizontal,"位");
modelTabIOOut->setHeaderData(2,Qt::Horizontal,"标签");
//输出IO表属性
for(int i=0;i<32;i++)
{
    Item_IOCheckBox[i]->setCheckable(true);
    Item_IOCheckBox[i]->setCheckState( Qt::Checked );
    modelTabIOOut->setItem( i, Item_IOCheckBox[i] );
    modelTabIOOut->setItem( i, 1, new QStandardItem(QString::number(i)));
}
ui->tableView_IOOut->horizontalHeader()->setDefaultAlignment(Qt::AlignCenter);//字体居中
ui->tableView_IOOut->verticalHeader()->setDefaultSectionSize(20);//固定行高度为6
ui->tableView_IOOut->verticalHeader()->setVisible(false);    //列表头不可见
ui->tableView_IOOut->setShowGrid(true);//表中网格线可见
ui->tableView_IOOut->setModel(modelTabIOOut);
ui->tableView_IOOut->setColumnWidth(0,40);
ui->tableView_IOOut->setColumnWidth(1,40);
ui->tableView_IOOut->setColumnWidth(2,320);

最终效果:

 

  • 5
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Qt ListView添加复选框并实现全选功能,需要执行以下步骤: 1. 创建一个自定义的QAbstractListModel或QStandardItemModel来作为数据模型。 2. 在数据模型添加一个bool类型的属性来表示每个项目是否选。 3. 在ListView的delegate添加一个QCheckBox来显示每个项目的选状态。 4. 创建一个全选/取消全选按钮并连接到相应的槽函数。 5. 在槽函数遍历所有项目并设置它们的选状态。 以下是一个示例代码: ``` // 自定义数据模型 class MyModel : public QAbstractListModel { public: struct Item { QString name; bool selected; }; MyModel(QObject *parent = nullptr) : QAbstractListModel(parent) {} int rowCount(const QModelIndex &parent = QModelIndex()) const override { return m_items.count(); } QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const override { if (!index.isValid() || index.row() >= m_items.count()) return QVariant(); if (role == Qt::DisplayRole || role == Qt::EditRole) return m_items.at(index.row()).name; if (role == Qt::CheckStateRole) return m_items.at(index.row()).selected ? Qt::Checked : Qt::Unchecked; return QVariant(); } Qt::ItemFlags flags(const QModelIndex &index) const override { if (!index.isValid() || index.row() >= m_items.count()) return Qt::NoItemFlags; return Qt::ItemIsEnabled | Qt::ItemIsSelectable | Qt::ItemIsEditable | Qt::ItemIsUserCheckable; } bool setData(const QModelIndex &index, const QVariant &value, int role = Qt::EditRole) override { if (!index.isValid() || index.row() >= m_items.count()) return false; if (role == Qt::CheckStateRole) { m_items[index.row()].selected = value.toBool(); emit dataChanged(index, index, {role}); return true; } if (role == Qt::EditRole) { m_items[index.row()].name = value.toString(); emit dataChanged(index, index, {role}); return true; } return false; } QList<Item> items() const { return m_items; } void setItems(const QList<Item> &items) { beginResetModel(); m_items = items; endResetModel(); } void selectAll(bool selected) { for (int i = 0; i < m_items.count(); ++i) { if (m_items[i].selected != selected) { m_items[i].selected = selected; emit dataChanged(index(i), index(i), {Qt::CheckStateRole}); } } } private: QList<Item> m_items; }; // ListView的delegate class MyDelegate : public QStyledItemDelegate { public: MyDelegate(QObject *parent = nullptr) : QStyledItemDelegate(parent) {} QWidget *createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const override { QCheckBox *checkBox = new QCheckBox(parent); checkBox->setCheckState(index.data(Qt::CheckStateRole).toBool() ? Qt::Checked : Qt::Unchecked); return checkBox; } void setEditorData(QWidget *editor, const QModelIndex &index) const override { QCheckBox *checkBox = qobject_cast<QCheckBox *>(editor); checkBox->setCheckState(index.data(Qt::CheckStateRole).toBool() ? Qt::Checked : Qt::Unchecked); } void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const override { QCheckBox *checkBox = qobject_cast<QCheckBox *>(editor); model->setData(index, checkBox->isChecked(), Qt::CheckStateRole); } }; // MainWindow的代码 MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::MainWindow) { ui->setupUi(this); // 创建数据模型并设置ListView的model和delegate m_model = new MyModel(this); ui->listView->setModel(m_model); ui->listView->setItemDelegate(new MyDelegate(this)); // 添加测试数据 QList<MyModel::Item> items; items.append({"Item 1", false}); items.append({"Item 2", false}); items.append({"Item 3", false}); items.append({"Item 4", false}); m_model->setItems(items); // 创建全选/取消全选按钮并连接到槽函数 QPushButton *selectAllButton = new QPushButton("Select All", this); ui->mainToolBar->addWidget(selectAllButton); connect(selectAllButton, &QPushButton::clicked, this, &MainWindow::onSelectAllClicked); } void MainWindow::onSelectAllClicked() { m_model->selectAll(true); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值