63 lines
No EOL
2.2 KiB
Markdown
63 lines
No EOL
2.2 KiB
Markdown
# QListView
|
||
|
||
- 目录
|
||
- [删除自定义Item](#1删除自定义Item)
|
||
- [自定义可拖拽Item](#2自定义可拖拽Item)
|
||
- [腾讯视频热播列表](#3腾讯视频热播列表)
|
||
- [仿折叠控件效果](#4仿折叠控件效果)
|
||
- [列表常用信号](#5列表常用信号)
|
||
|
||
## 1、删除自定义Item
|
||
[运行 DeleteCustomItem.py](DeleteCustomItem.py)
|
||
|
||
1. 删除item时先要通过`QListWidget.indexFromItem(item).row()`得到它的行数
|
||
2. 通过`takeItem`函数取出该Item并删除掉,`item = self.listWidget.takeItem(row)`
|
||
3. 移除item对应的自定义控件`self.listWidget.removeItemWidget(item)`
|
||
4. 如果是清空所有Item,可以通过循环删除,但是删除的时候行号一直是0即可,原因和删除list数组一样。
|
||
|
||
![CustomWidgetItem](ScreenShot/DeleteCustomItem.gif)
|
||
|
||
## 2、自定义可拖拽Item
|
||
[运行 DragDrop.py](DragDrop.py)
|
||
|
||
![CustomWidgetSortItem](ScreenShot/DragDrop.gif)
|
||
|
||
## 3、腾讯视频热播列表
|
||
[运行 HotPlaylist.py](HotPlaylist.py)
|
||
|
||
简单思路说明:
|
||
|
||
- 利用`QListWidget`设置一些特殊的参数达到可以横向自动显示
|
||
- `QNetworkAccessManager`异步下载网页和图片
|
||
- 滚动到底部触发下一页加载
|
||
|
||
自定义控件说明:
|
||
|
||
- 主要是多个layout和控件的结合,其中图片`QLabel`为自定义,通过`setPixmap`设置图片,重写`paintEvent`绘制底部渐变矩形框和白色文字
|
||
- 字体颜色用qss设置
|
||
- 图标利用了`QSvgWidget`显示,可以是svg 动画(如圆形加载图)
|
||
|
||
`QListWidget`的参数设置
|
||
|
||
1. `setFlow(QListWidget.LeftToRight)`
|
||
2. `setWrapping(True)`
|
||
3. `setResizeMode(QListWidget.Adjust)`
|
||
|
||
![HotPlaylist](ScreenShot/HotPlaylist.gif)
|
||
|
||
## 4、仿折叠控件效果
|
||
[运行 FoldWidget.py](FoldWidget.py)
|
||
|
||
1. 利用`QListWidget`设置Item的自定义控件
|
||
2. `QListWidget`通过间隔设置`QPushButton`和`CustomWidget`来添加
|
||
3. 绑定按钮的选中状态通过`setHidden`设置Item的隐藏和显示
|
||
4. 自定义控件中尺寸发生变化后需要调用`adjustSize()`来同步
|
||
|
||
![FoldWidget](ScreenShot/FoldWidget.gif)
|
||
|
||
## 5、列表常用信号
|
||
[运行 SignalsExample.py](SignalsExample.py)
|
||
|
||
根据官网文档 https://doc.qt.io/qt-5/qlistwidget.html#signals 中的信号介绍编写
|
||
|
||
![SignalsExample](ScreenShot/SignalsExample.gif) |