【二十一】【QT开发应用】ListWiddget图标模式

devtools/2024/9/20 12:54:08/

代码

demo13_listwidget::demo13_listwidget(QWidget* parent): QWidget(parent) {ui.setupUi(this);resize(600, 500);QVBoxLayout* pMainVLayout = new QVBoxLayout(this);QListWidget* pListWidget = new QListWidget(this);pListWidget->setViewMode(QListView::IconMode);pListWidget->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);pListWidget->setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);QString qss = "QListWidget{border:none; background:rgb(251,251,251);} \QListWidget::item{background:blue;  \margin-left:20px;  \margin-top:10px; \}";pListWidget->setStyleSheet(qss);int vScrollBarWidth = 30;pListWidget->setFixedWidth(180 * 3 + vScrollBarWidth + 1);for (int i = 0; i < 15; i++) {QIcon icon(":/demo13_listwidget/resources/editor.png");QString name = QString(u8"用户%1").arg(QString::number(i));QListWidgetItem* pItem = new QListWidgetItem(icon, name);pItem->setSizeHint(QSize(180, 180));pListWidget->addItem(pItem);}pMainVLayout->addWidget(pListWidget);}

调整窗口大小

resize(600, 500);
  • 调整窗口大小为600x500像素。

创建垂直布局

QVBoxLayout* pMainVLayout = new QVBoxLayout(this);
  • 创建一个垂直布局(QVBoxLayout),并将其设置为当前窗口的主布局,用于管理子部件的排列方式。

创建QListWidget

QListWidget* pListWidget = new QListWidget(this);
  • 创建一个新的QListWidget,用于显示带有图标和文本的项目列表,并将其作为当前窗口的子部件。

设置ListWedget为图标模式

pListWidget->setViewMode(QListView::IconMode);
  • 设置QListWidget的显示模式为QListView::IconMode,即以图标的方式显示每个列表项,而不是默认的文本列表模式。

设置滚动条策略

pListWidget->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
pListWidget->setVerticalScrollBarPolicy(Qt::ScrollBarAsNeeded);
  • 设置滚动条策略:
    • 水平滚动条始终关闭(Qt::ScrollBarAlwaysOff)。
    • 垂直滚动条根据需要显示(Qt::ScrollBarAsNeeded)。

定义样式表

QString qss = "QListWidget{border:none; background:rgb(251,251,251);} \QListWidget::item{background:blue;  \margin-left:20px;  \margin-top:10px; \
}";
pListWidget->setStyleSheet(qss);
  • 定义了一个样式表(QSS)来定制QListWidget的外观:
    • QListWidget{border:none; background:rgb(251,251,251);}:移除边框,设置背景颜色为浅灰(rgb(251,251,251))。
    • QListWidget::item{background:blue; margin-left:20px; margin-top:10px;}:每个项目的背景色为蓝色,并设置左边距为20像素,顶部边距为10像素。

设置ListWidget固定宽度

int vScrollBarWidth = 30;
pListWidget->setFixedWidth(180 * 3 + vScrollBarWidth + 1);
  • 设置了垂直滚动条的宽度为30像素。
  • pListWidget->setFixedWidth(180 * 3 + vScrollBarWidth + 1);:将QListWidget的宽度固定为显示三列图标的宽度(每列宽度180像素),加上滚动条的宽度和1像素的边距。

循环添加ListWidgetItem

for (int i = 0; i < 15; i++) {QIcon icon(":/demo13_listwidget/resources/editor.png");QString name = QString(u8"用户%1").arg(QString::number(i));QListWidgetItem* pItem = new QListWidgetItem(icon, name);pItem->setSizeHint(QSize(180, 180));pListWidget->addItem(pItem);
}
  • 创建一个循环,用来向QListWidget中添加15个带有图标和文本的列表项:
    • 每个列表项使用同一个图标(resources/editor.png)和文本(用户0用户14)。
    • pItem->setSizeHint(QSize(180, 180));:设置每个列表项的大小为180x180像素。
    • pListWidget->addItem(pItem);:将每个创建的项目添加到QListWidget中。

添加ListWidget到布局中

pMainVLayout->addWidget(pListWidget);
  • pListWidget添加到主垂直布局中,使其在窗口中显示。

程序运行结果

在这里插入图片描述

结尾

最后,感谢您阅读我的文章,希望这些内容能够对您有所启发和帮助。如果您有任何问题或想要分享您的观点,请随时在评论区留言。
同时,不要忘记订阅我的博客以获取更多有趣的内容。在未来的文章中,我将继续探讨这个话题的不同方面,为您呈现更多深度和见解。
谢谢您的支持,期待与您在下一篇文章中再次相遇!


http://www.ppmy.cn/devtools/113124.html

相关文章

windows server2012 配制nginx安装为服务的时候,直接跳要安装.net框架,用自动的安装,直接失败的解决。

1、上一个已成功在安装过程中的图&#xff1a; 2、之前安装过程中错误的图&#xff1a; 3、离线安装解决&#xff1a; 下载.net framework 3.5&#xff0c;然后解压后&#xff0c;选择指定备用源路径&#xff0c;然后选择.net安装包所在目录&#xff1a; 只要指定上面全路径就…

Python [ GUI编程自学 ],虽然但是,还是想出一个系列

本文主要介绍了GUI组件的其他常用组件部分&#xff1a;optionmenu选项菜单&#xff0c;scale滑块&#xff1b;颜色框、文件选择框&#xff0c;读取文件内容&#xff1b;简单对话框、通用消息、ttk子模块问题&#xff1b; 一系列GUI编程&#xff0c;有相关的专栏&#xff0c;欢迎…

【C++】入门基础(下)

Hi&#xff01;很高兴见到你~ 目录 7、引用 7.3 引用的使用&#xff08;实例&#xff09; 7.4 const引用 【第一分点】 【第二分点1】 【第二分点2】 7.5 指针和引用的关系&#xff08;面试点&#xff09; 8、inline 9、nullptr Relaxing Time&#xff01; ———…

实习期间git的分枝管理以及最常用的命令

各位找工作实习的友友在工作之前一定要把git的相关知识掌握呀&#xff0c;我实现期间被leader说过关于git规范的相关问题了 目前已更新系列&#xff1a; 当前&#xff1a;:实习期间git的分枝管理以及最常用的命令 Redis高级-----持久化AOF、RDB原理 Redis高级---面试总结5种…

容器技术--Dockerfile 构建镜像

Dockerfile dockerfile 是一系列命令&参数构成的脚本,这些命令应用于基础镜像,最终创建一个新的镜像,可以提供一致的运行环境。【也可以登录容器,自己安装软件,最后commit为镜像】 命令 FROM 指定基础镜像(必须),如FROM ubuntu;每一个指令就生成一层镜像;RUN 运…

【前端】ref引用的作用

首先&#xff0c;我们要明确一点&#xff0c;使用vue的好处是&#xff1a; 想要减少开发者直接操作dom元素。使用组件模版&#xff0c;实现代码的服用。 ref的属性的实现是为了取代原生js中使用id、class等标识来获取dom元素。 helloworld组件 <template><div clas…

面试官问:你在团队中的角色是什么?

面试官问你在团队中的角色是什么&#xff0c;其目的是了解你如何在团队环境中工作&#xff0c;以及你如何看待自己在团队中的定位。他们希望听到你如何与他人协作、你的领导能力或团队合作精神&#xff0c;以及你是否能适应不同的团队角色。 回答这类问题时&#xff0c;你可以…

多维时序 | Matlab基于BO-LSSVM贝叶斯优化最小二乘支持向量机数据多变量时间序列预测

多维时序 | Matlab基于BO-LSSVM贝叶斯优化最小二乘支持向量机数据多变量时间序列预测 目录 多维时序 | Matlab基于BO-LSSVM贝叶斯优化最小二乘支持向量机数据多变量时间序列预测效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.Matlab基于BO-LSSVM贝叶斯优化最小二乘支…