QListWidget是一个方便类,它提供了一个类似于QListView提供的列表视图,但具有一个经典的基于项目的界面,用于添加和删除项目。QListWidget使用一个内部模型来管理列表中的每个QListWidgetItem。
QListWidget -> QListView -> QAbstractItemView -> QAbstractScrollArea -> QFrame -> QWidget
要获得更灵活的列表视图小部件,请将QListView类与标准模型一起使用。
列表窗口小部件的构造方式与其他窗口小部件相同:
QListWidget *listWidget = new QListWidget(this);
在QListWidget 指定位置(row参数)插入一项。
在这种方法中,需要注意一点:
在新建项的时候,项的父控件不能是QListWidget,否则还是添加到QListWidget的最后。
QListWidgetItem 表示 QListWidget 中的单个Item。每个Item可以包含多条信息,并将适当地显示它们。
QListWidgetItem 通常用于显示 文本 text() 和 图标 icon () 。这些是使用 setText() 和 setIcon() 函数设置的。文本的外观可以使用 setFont() 、setForeground() 和 setBackground() 进行自定义。列表项中的文本可以使用 setTextAlignment() 函数对齐。工具提示、状态提示和“这是什么?”帮助可以添加到使用 setToolTip() 、setStatusTip() 和 setWhatsThis() 的列表项中。
默认情况下,Item是 enabled, selectable, checkable的,并且配置 成可拖放、可编辑、可点击 check 的。这都是属于Item 的标志。
QListWidgetItem 专门用于表示列表控件 QListWidget 的数据条目,注意: QListWidgetItem 是一个纯数据类,不是控件,没有基类,也就没有信号和槽函数。QListWidgetItem 可以直接用数据流 QDataStream 读写。
QListWidgetItem 不单单有字符串,还可以有自己的图标、复选框等特性,列表控件会根据条目对象的丰富特性来呈现数据并进行交互操作。
#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include
#include QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();void initUi();void sortImage();void showSortImage04(QVector lst, QString path);void showSortImage02(QVector lst, QString path);void showSortImage05(QVector lst, QString path);public:QVector sortResult04;QVector sortResult02;QVector sortResult05;QVector m_vec03;private:Ui::MainWindow *ui;
};
#endif // MAINWINDOW_H
#include "MainWindow.h"
#include "ui_MainWindow.h"MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{ui->setupUi(this);initUi();sortImage();showSortImage04(sortResult04,":/picture/");showSortImage02(sortResult02,":/picture/");showSortImage05(sortResult05,":/picture/");
}MainWindow::~MainWindow()
{delete ui;
}void MainWindow::initUi()
{ui->listWidget04->resize(300, 900);ui->listWidget04->setViewMode(QListWidget::IconMode); //显示模式ui->listWidget04->setIconSize(QSize(300, 150));//设置图片大小ui->listWidget04->setSpacing(0);//间距ui->listWidget04->setResizeMode(QListWidget::Adjust); //适应布局调整ui->listWidget04->setMovement(QListWidget::Free); //可移动,static:不可移动ui->listWidget04->setDragDropMode(QAbstractItemView::InternalMove); //可拖拽ui->listWidget04->setWrapping(false); //自动换行ui->listWidget04->setFlow(QListWidget::TopToBottom); //从上到下 LeftToRight从左到右布局ui->listWidget02->resize(300, 900);ui->listWidget02->setViewMode(QListWidget::IconMode); //显示模式ui->listWidget02->setIconSize(QSize(300, 150));//设置图片大小ui->listWidget02->setSpacing(0);//间距ui->listWidget02->setResizeMode(QListWidget::Adjust); //适应布局调整 Adjustui->listWidget02->setMovement(QListWidget::Free); //可移动,static:不可移动ui->listWidget02->setDragDropMode(QAbstractItemView::InternalMove); //可拖拽ui->listWidget02->setWrapping(false); //自动换行ui->listWidget02->setFlow(QListWidget::TopToBottom); //从上到下 LeftToRight从左到右布局ui->listWidget05->resize(300, 900);ui->listWidget05->setViewMode(QListWidget::IconMode); //显示模式ui->listWidget05->setIconSize(QSize(300, 150));//设置图片大小ui->listWidget05->setSpacing(0);//间距ui->listWidget05->setResizeMode(QListWidget::Adjust); //适应布局调整ui->listWidget05->setMovement(QListWidget::Free); //可移动,static:不可移动ui->listWidget05->setDragDropMode(QAbstractItemView::InternalMove); //可拖拽ui->listWidget05->setWrapping(false); //自动换行ui->listWidget05->setFlow(QListWidget::TopToBottom); //从上到下 LeftToRight从左到右布局QPalette palette;palette.setColor(QPalette::Background,QColor(255,255,255,0));setPalette(palette);
// ui->listWidget04->setBackground(QColor(255,255,255,0));ui->listWidget04->setStyleSheet("background-color:rgba(0,0,0,0); border:1px solid rgb(0, 0,0)");ui->listWidget02->setStyleSheet("background-color:rgba(0,0,0,0); border:1px solid rgb(0, 0,0)");ui->listWidget05->setStyleSheet("background-color:rgba(0,0,0,0); border:1px solid rgb(0, 0,0)");}void MainWindow::sortImage()
{
// //04
// sortResult04.push_back("0011_052322_151412_04_002_00001_00004_00.jpg");
// sortResult04.push_back("0011_052322_151409_04_002_00001_00003_00.jpg");
// sortResult04.push_back("0011_052322_151406_04_002_00001_00002_00.jpg");
// sortResult04.push_back("0011_052322_151403_04_002_00001_00001_00.jpg");
// sortResult04.push_back("1754_040821_111917_04_001_00001_00006_00.jpg");
// sortResult04.push_back("1754_040821_111915_04_001_00001_00005_00.jpg");sortResult04.push_back("1.jpg");sortResult04.push_back("2.jpg");sortResult04.push_back("3.jpg");sortResult04.push_back("4.jpg");sortResult04.push_back("5.jpg");sortResult04.push_back("6.jpg");// //02
// sortResult02.push_back("0011_052322_151415_02_002_00001_00004_00.jpg");
// sortResult02.push_back("0011_052322_151411_02_002_00001_00003_00.jpg");
// sortResult02.push_back("0011_052322_151407_02_002_00001_00002_00.jpg");
// sortResult02.push_back("0011_052322_151403_02_002_00001_00001_00.jpg");
// sortResult02.push_back("0231_010421_130836_02_001_00001_00005_00.jpg");
// sortResult02.push_back("0231_010421_130834_02_001_00001_00004_00.jpg");
// sortResult02.push_back("0231_010421_130830_02_001_00001_00003_00.jpg");
// sortResult02.push_back("0231_010421_130828_02_001_00001_00002_00.jpg");
// sortResult02.push_back("0231_010421_130826_02_001_00001_00001_00.jpg");sortResult02.push_back("7.jpg");sortResult02.push_back("8.jpg");sortResult02.push_back("9.jpg");sortResult02.push_back("10.jpg");sortResult02.push_back("11.jpg");sortResult02.push_back("12.jpg");sortResult02.push_back("13.jpg");sortResult02.push_back("14.jpg");sortResult02.push_back("15.jpg");// //05
// sortResult05.push_back("0011_052322_151412_05_002_00001_00004_00.jpg");
// sortResult05.push_back("0011_052322_151409_05_002_00001_00003_00.jpg");
// sortResult05.push_back("0011_052322_151406_05_002_00001_00002_00.jpg");
// sortResult05.push_back("0011_052322_151403_05_002_00001_00001_00.jpg");
// sortResult05.push_back("1754_040821_111921_05_001_00001_00008_00.jpg");
// sortResult05.push_back("1754_040821_111919_05_001_00001_00007_00.jpg");sortResult05.push_back("16.jpg");sortResult05.push_back("17.jpg");sortResult05.push_back("18.jpg");sortResult05.push_back("19.jpg");sortResult05.push_back("20.jpg");sortResult05.push_back("21.jpg");}void MainWindow::showSortImage04(QVector lst, QString path)
{QStringList listMap;foreach(QString item, lst){listMap.append(item);}QString allPath = path + "/";for (int i = 0; i < lst.size(); i++){QString onlyFile = lst.at(i);int pos = onlyFile.lastIndexOf("/");onlyFile = lst.at(i).right(lst.at(i).size() - pos - 1);QListWidgetItem* imageItem = new QListWidgetItem(/*m_ImageList*/);QString allImgFiles = allPath + lst.at(i);/*QPixmap pPhoto;pPhoto.loadFromData(QByteArray(), "jpg");QIcon ico;ico.addPixmap(pPhoto);*/imageItem->setIcon(QIcon(allImgFiles));//imageItem->setText(onlyFile);imageItem->setSizeHint(QSize(190, 150));ui->listWidget04->addItem(imageItem);//m_ImageList->setItemWidget(imageItem, this);}/*QGridLayout* grid = new QGridLayout;grid->addWidget(m_ImageList);this->setLayout(grid);*///m_ImageList->setHidden(false);ui->listWidget04->show();
}void MainWindow::showSortImage02(QVector lst, QString path)
{QStringList listMap;foreach(QString item, lst){listMap.append(item);}QString allPath = path + "/";for (int i = 0; i < lst.size(); i++){QString onlyFile = lst.at(i);int pos = onlyFile.lastIndexOf("/");onlyFile = lst.at(i).right(lst.at(i).size() - pos - 1);QListWidgetItem* imageItem = new QListWidgetItem(/*m_ImageList*/);QString allImgFiles = allPath + lst.at(i);/*QPixmap pPhoto;pPhoto.loadFromData(QByteArray(), "jpg");QIcon ico;ico.addPixmap(pPhoto);*/imageItem->setIcon(QIcon(allImgFiles));//imageItem->setText(onlyFile);imageItem->setSizeHint(QSize(190, 150));ui->listWidget02->addItem(imageItem);//m_ImageList->setItemWidget(imageItem, this);}/*QGridLayout* grid = new QGridLayout;grid->addWidget(m_ImageList);this->setLayout(grid);*///m_ImageList->setHidden(false);ui->listWidget02->show();}void MainWindow::showSortImage05(QVector lst, QString path)
{QStringList listMap;foreach(QString item, lst){listMap.append(item);}QString allPath = path + "/";for (int i = 0; i < lst.size(); i++){QString onlyFile = lst.at(i);int pos = onlyFile.lastIndexOf("/");onlyFile = lst.at(i).right(lst.at(i).size() - pos - 1);QListWidgetItem* imageItem = new QListWidgetItem(/*m_ImageList*/);QString allImgFiles = allPath + lst.at(i);/*QPixmap pPhoto;pPhoto.loadFromData(QByteArray(), "jpg");QIcon ico;ico.addPixmap(pPhoto);*/imageItem->setIcon(QIcon(allImgFiles));//imageItem->setText(onlyFile);imageItem->setSizeHint(QSize(190, 150));ui->listWidget05->addItem(imageItem);//m_ImageList->setItemWidget(imageItem, this);}/*QGridLayout* grid = new QGridLayout;grid->addWidget(m_ImageList);this->setLayout(grid);*///m_ImageList->setHidden(false);ui->listWidget05->show();
}
在ui设计界面中添加QListWidget,用于显示图片
源码下载地址