Qt中QListWidget/QListWidgetItem详解

这篇具有很好参考价值的文章主要介绍了Qt中QListWidget/QListWidgetItem详解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Qt系列文章目录

前言

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 <QMainWindow>
#include <QVector>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

    void initUi();
    void sortImage();
    void showSortImage04(QVector<QString> lst, QString path);
    void showSortImage02(QVector<QString> lst, QString path);
    void showSortImage05(QVector<QString> lst, QString path);

public:
    QVector<QString> sortResult04;
    QVector<QString> sortResult02;
    QVector<QString> sortResult05;
    QVector<QString> 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); //适应布局调整  Adjust
    ui->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<QString> 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<QString> 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<QString> 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();
}

二、添加资源图片

1.ui设计界面中添加QListWidget

在ui设计界面中添加QListWidget,用于显示图片
Qt中QListWidget/QListWidgetItem详解

2.添加资源图片

Qt中QListWidget/QListWidgetItem详解

Qt中QListWidget/QListWidgetItem详解

三、 运行效果

Qt中QListWidget/QListWidgetItem详解

四、源码下载

源码下载地址文章来源地址https://www.toymoban.com/news/detail-429070.html

到了这里,关于Qt中QListWidget/QListWidgetItem详解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vscode 系列文章目录 - ctrl+鼠标左键无效

    vscode 中有时会遇到 “Alt + 鼠标点击” 有效,但 “Ctrl + 鼠标点击” 无效,这时可以通过 Ctrl + , 进行系统配置。 进入VScode的首选项,选择设置(快捷键 Ctrl + , ),输入Go to definition,找到如下两个设置。 Editor: Multi Cursor Modifier 设置成 alt “editor.gotoLocation.multipleDefinitions” 设置

    2024年04月23日
    浏览(54)
  • Git系列文章目录 - Git 子模块git submodule使用

    项目中有时会遇到会涉及子模块的使用,比如 flatpak 项目包含多个子模块。 进入需要添加子模块的目录,一般是项目根目录。 删除子模块目录及源码: 删除项目目录下.gitmodules文件中子模块相关条目: 删除配置项中子模块相关条目: 删除模块下的子模块目录: 清除子模块

    2024年01月20日
    浏览(66)
  • AIGC系列文章目录 第一章 AIGC 与AI对话,如何写好prompt?

    生成式人工智能AIGC(Artificial Intelligence Generated Content)是人工智能1.0时代进入2.0时代的重要标志。 AIGC对于人类社会、人工智能的意义是里程碑式的。 短期来看 AIGC改变了基础的生产力工具, 中期来看 会改变社会的生产关系, 长期来看 促使整个社会生产力发生质的突破,在

    2024年02月06日
    浏览(48)
  • QT基础:遍历QListWidget,及QListWidget简单演示,适合初学者食用

    QListWidget 是一个列表框,关于它的详细介绍可以参考:Qt QListWidget详解 初学者如果只是想在短时间内了解 QListWidget 的话,可以参考这里 1、打开QT,创建一个 widget 项目,在UI中加入 QListWidget 和一个 PushButton(等会备用) 可以双击 QListWidget 小部件 , 点左下角的 + 可以在里

    2024年02月12日
    浏览(49)
  • 【QT】——QListWidget的使用

    目录 1.QListWidget和QListWidgetItem 2.外观 2.1列表模式 2.2图标模式 3.常用接口 4.示例 删除列表项 添加列表项 QListWidget 是qt中的列表框控件,它用于显示多个列表项, 列表项 对应的类是 QListWidgetItem . QListWidgetItem可以只包含文字 QListWidgetItem 中可以同时包含 图片和文字 。 列表框控

    2024年02月16日
    浏览(52)
  • QT的QListWidget使用

     本文进行的了QListWidget的使用,设计了如上所示的UI界面信息,具有以下几个功能: 添加,插入,删除,显示模式调整等功能 初始化 模式确定 双击显示处理 具体处理的信号槽函数 结果显示

    2024年02月16日
    浏览(49)
  • Qt QListWidget列表框控件

    Qt中的列表框控件,对应的类是 QListWidget 它用于显示多个列表项,列表项对应的类是 QListWidgetitem QListWidget 有很多属性和方法,完整的可查看帮助文档。这里列出常用的属性和方法: 列表框控件,支持两种显示模式:列表模式和图标模式 其中, QListView::ViewMode 是一个枚举,有

    2024年02月02日
    浏览(45)
  • 【QT基础教程 十二】QListWidget类解析

    概要:本期介绍QListWidget类的使用,包含QListWidget如何添加项、删除项、遍历等操作。 头文件:#includeQListWidget 模块:QT += widgets 父类:QListView QListWidget类提供了一个基于项(QListWIdgetItem)的列表控件 ,它拥有属于自己的界面。当然,照我们之前说的,它也继承与QWidget类。 其

    2024年02月13日
    浏览(47)
  • AIGC系列文章目录 第三章 AIGC 简单易用免费的AI图像生成器: Stable Diffusion

    目前亲测体验的AI图像生成器有NovelAI、MJ和Stable Diffusion。其中, 支持免费、无限生成、超高专业级画质 的只有 Stable Diffusion 。 Stable Diffusion 由 Stable Diffusion XL 提供支持,是一款最先进的工具,可以将您的想象力变为现实。 只需点击几下和简单的文本输入,您就可以创建令人

    2024年02月03日
    浏览(68)
  • Qt中设置QListWidget滑动条滚动速度

    QListWidget继承QListView控件,Qt帮助文档中说 QAbstractItemView::ScrollPerPixel 和QAbstractItemView::ScrollPerItem分别可以实现按item滚动和像数点滚动,但是好像都没效果。还有就是说通过创建QScrollBar有用,但是也没效果。 亲测还是这样有用,记录一下,记录一下!!!

    2024年02月11日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包