ListWidget列表框组件与TreeWidget有点相似。但是,TreeWidget实现嵌套和多字段结构,而ListWidget组件只能实现单个字段结构。ListWidget组件通常用于显示单个记录,如仅显示IP地址、用户名等,如下所示
常用的节点间操作方法如下:
ListView组件和应用程序默认的ListWidget初始化ListWidget更改行(触发事件)设置ListWidget编辑状态ListWidget全选/全部不选ListWidget反选(真或假)插入ListWidget指定位置/ListWidget只能预览。
#include 'mainwindow.h '
#include 'ui_mainwindow.h '
#include QListView
#include QStandardItem
#include QStringListModel
主视窗:3360主视窗(q widget * parent): qmainwindow(parent)、ui(new ui 33603360主视窗)
{
ui-setupUi(this);
}
Main window :3360至Main window()
{
Delete ui
}
//View组件初始化在ListView组件中填充数据
//by3360lyshark
//
void main window :3360 on _ push button _ clicked()
{
QStringList数据;
Qstringlistmodel *型号:
//向ListView添加数据
data QString(' 192 . 168 . 1 . 1 ');
data QString(' 192 . 168 . 1 . 2 ');
data QString(' 192 . 168 . 1 . 3 ');
data QString(' 192 . 168 . 1 . 4 ');
model=new QStringListModel(data);
Ui-listview-setmodel(型号);
//删除第一个地址
da(0);
重新整理//ListView
model=new QStringListModel(data);
Ui-listview-setmodel(型号);
}
//初始化实施间隔,每行一种颜色
void main window :3360 on _ push button _ 2 _ clicked()
{
QStringList数据;
qstandarditemmodel * model=new qstandarditemmodel();
//清除记录
Model-removerows (0,model-rowcount());
//向ListView添加数据
data QString(' 192 . 168 . 1 . 1 ');
//添加循环
for(int x=2;X5;x)
{
Dataqstring ('192.168.1)。“% 0”)。arg(x);
}
//导出为ListView记录
int nCount=da();
for(int x=0;XnCountx)
{
qstringstring=static _ castqstring((x));//strong制转换为QString类型
qstandard item * item=new qstandard item(string);
If(x%2==0)
{
//颜色设置
qlineargradientlinear _ grad(qpointf(0,0)、qpointf (200,200));
Linear _ grad.setcolorat (0,Qt :3360 dark green);
q brush brush(linear _ grad);
item-set background(brush);
}
添加到//mode模型
model->appendRow(item); } // 设置模型 ui->listView->setModel(model); //ui->listView->setFixedSize(200,300); }代码运行效果如下:
上方代码中我们多数都是在使用View视图组件,接下来将具体分析Widget组件的使用细节,View组件与Widget组件看似一致,但却存在本质区别,其大致区别如下:
- Widget 组件可以直接通过如AddItem等一系列函数操作特定数据集,该组件还具有直接编辑的能力。
- View 组件是基于Model模型映射工作的,每次操作数据时都需要借助QAbstractListModel数据模型来操作。
简单来说View组件适合于浏览展示数据较多的场景,因为其绑定了链表结构从而在数据的展示上更为灵活,而Widget组件更适合于更新或修改数据较多的使用场景。
ListWidget 节点初始化: 节点的初始化就是向widget组件内插入一个QListWidgetItem类。
// 初始化列表 listWidget
// By: LyShark
void MainWindow::on_pushButton_clicked()
{
// 每一行是一个QListWidgetItem
QListWidgetItem *aItem;
// 设置ICON的图标
QIcon aIcon;
aIcon.addFile(":/image;);
ui->listWidget->clear();
for(int x=0;x<10;x++)
{
QString str = QString::asprintf("192.168.1.%d",x);
aItem = new QListWidgetItem(); // 新建一个项
aItem->setText(str); // 设置文字标签
aItem->setIcon(aIcon); // 设置图标
aItem->setCheckState(Qt::Checked); // 设为选中状态
aItem->setFlags(Qt::ItemIsSelectable | // 设置为不可编辑状态
Qt::ItemIsUserCheckable
|Qt::ItemIsEnabled);
ui->listWidget->addItem(aItem); //增加项
}
}
代码运行效果如下:
ListWidget 行内文本变化: 当我们点击行内任意一个列表选项时,我们让其触发currentItemChanged并将变化行更新到窗体上。
// listWidget 当前选中项发生变化
// By: LyShark
void MainWindow::on_listWidget_currentItemChanged(QListWidgetItem *current, QListWidgetItem *previous)
{
QString str;
if (current != NULL) //需要检测变量指针是否为空
{
if (previous==NULL) //需要检测变量指针是否为空
{
str="当前:"+current->text();
this->setWindowTitle(QString(current->text()));
}
else
{
str="前一项:" + previous->text() + "; 当前项:" + current->text();
std::cout << ().data() << std::endl;
this->setWindowTitle(QString(current->text()));
}
}
}
代码运行效果如下:
ListWidget 编辑状态设置: 默认情况下ListWidget组件内所有文件是不可编辑的,我们也可以将编辑属性打开。
// 设置所有项设置为可编辑状态
//
void MainWindow::on_pushButton_5_clicked()
{
int x,cnt;
QListWidgetItem *aItem;
cnt = ui->listWidget->count();
for(x=0;x<cnt;x++)
{
aItem = ui->listWidget->item(x);
aItem->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEditable
|Qt::ItemIsUserCheckable |Qt::ItemIsEnabled);
}
}
代码运行效果如下:
ListWidget 全选/全不选: 全选顾名思义就是选中菜单中的所有数据,使用aItem->setCheckState(Qt::Checked)实现选中,通过循环计数即可。
// 全选按钮
//
void MainWindow::on_pushButton_2_clicked()
{
int cnt = ui->listWidget->count(); // 获取总数
for(int x=0;x<cnt;x++)
{
QListWidgetItem *aItem = ui->listWidget->item(x); // 获取到一项指针
aItem->setCheckState(Qt::Checked); // 设置为选中
}
}
// 全不选
// By: LyShark
void MainWindow::on_pushButton_3_clicked()
{
int cnt = ui->listWidget->count(); // 获取总数
for(int x=0;x<cnt;x++)
{
QListWidgetItem *aItem = ui->listWidget->item(x); // 获取到一项指针
aItem->setCheckState(Qt::Unchecked); // 设置为非选中
}
}
代码运行效果如下:
ListWidget 反选功能: 反选的含义是,用户选中菜单反选后会变为未选中状态,未选中则变为选中,只需要增加一个判断即可实现。
// By: LyShark
void MainWindow::on_pushButton_4_clicked()
{
int x,cnt;
QListWidgetItem *aItem;
cnt = ui->listWidget->count();
for(x=0;x<cnt;x++)
{
aItem = ui->listWidget->item(x);
if(aItem->checkState() != Qt::Checked)
aItem->setCheckState(Qt::Checked);
else
aItem->setCheckState(Qt::Unchecked);
}
}
代码运行效果如下:
ListWidget 指定位置插入/追加插入: 在选中行的上方插入一行新的表项,以及追加到末尾一行。
// 指定位置插入一项
// www.cnblogs.com/lyshark
void MainWindow::on_pushButton_8_clicked()
{
QIcon aIcon;
aIcon.addFile(":/image;);
QListWidgetItem *aItem = new QListWidgetItem("插入的数据");
aItem->setIcon(aIcon);
aItem->setCheckState(Qt::Checked);
aItem->setFlags(Qt::ItemIsSelectable |Qt::ItemIsUserCheckable |Qt::ItemIsEnabled);
// 在当前行的上方插入一个项
ui->listWidget->insertItem(ui->listWidget->currentRow(),aItem);
}
// 增加一项,尾部追加
void MainWindow::on_pushButton_7_clicked()
{
QIcon aIcon;
aIcon.addFile(":/image;);
QListWidgetItem *aItem = new QListWidgetItem("新增的项目"); // 增加项目名
aItem->setIcon(aIcon); // 设置图标
aItem->setCheckState(Qt::Checked); // 设置为选中
aItem->setFlags(Qt::ItemIsSelectable |Qt::ItemIsUserCheckable |Qt::ItemIsEnabled);
ui->listWidget->addItem(aItem); // 增加到控件
}
代码运行效果如下:
ListWidget 删除选中项: 删除当前选中的一项,并清理释放内存。
// 删除选中项
void MainWindow::on_pushButton_6_clicked()
{
int row = ui->listWidget->currentRow(); // 获取当前行
QListWidgetItem *aItem = ui->listWidget->takeItem(row); // 移除指定行的项,但不delete
delete aItem; // 释放空间
}
代码运行效果如下: