Pyqt5——带图标的表格(Model/View)
2024-08-30 07:07:19
需求:表格中第一列内容为学生学号,为了突出学号的表示,在第一列的学号旁增加学号图标。
实现:(1)使用Qt的model-view模式生成表格视图。
(2)重写代理(QAbstractItemDelegate)。
表格样式如下图所示。
代码块。
Model部分:
class MyTableModel(QAbstractTableModel):
"""Model"""
def __init__(self):
super(MyTableModel, self).__init__()
self._data = []
self._background_color = []
self._headers = ['学号', '姓名', '性别', '年龄'] self._generate_data() def _generate_data(self):
"""填充表格数据"""
name_list = ['张三', '李四', '王五', '王小二', '李美丽', '王二狗'] for id_num, name in enumerate(name_list):
self._data.append([str(id_num), name, '男', str(random.randint(20, 25))]) # :默认单元格颜色为白色
self._background_color.append([QColor(255, 255, 255) for i in range(4)]) def rowCount(self, parent=QModelIndex()):
"""返回行数量。"""
return len(self._data) def columnCount(self, parent=QModelIndex()):
"""返回列数量。"""
return len(self._headers) def headerData(self, section, orientation, role):
"""设置表格头"""
if role == Qt.DisplayRole and orientation == Qt.Horizontal:
return self._headers[section] def data(self, index, role):
"""显示表格中的数据。"""
if not index.isValid() or not 0 <= index.row() < self.rowCount():
return QVariant() row = index.row()
col = index.column() if role == Qt.DisplayRole:
return self._data[row][col]
elif role == Qt.BackgroundColorRole:
return self._background_color[row][col]
elif role == Qt.TextAlignmentRole:
return Qt.AlignCenter return QVariant()
Delegate部分:
class MyDelegate(QAbstractItemDelegate):
"""Delegate"""
def __init__(self):
super(MyDelegate, self).__init__() def paint(self, painter, option, index):
"""绘制单元格。"""
if index.column() == 0:
# :表格第一列是ID,单元格中绘制一个图片和ID。
p = QStyleOptionViewItem()
p.index = index
p.rect = option.rect
p.features = QStyleOptionViewItem.HasDecoration | QStyleOptionViewItem.HasDisplay
p.text = str(index.data())
p.decorationSize = QSize(44, 44) # 设置装饰图标的大小。
p.icon = QIcon('../image/id.png') # 设置装饰图标路径名
p.state = option.state
p.showDecorationSelected = True # 开启选中时,单元格高亮显示
# :若项目被选择,则高亮绘制其矩形
#if p.state & QStyle.State_Selected:
#painter.fillRect(option.rect, option.palette.highlight()) p.decorationPosition = QStyleOptionViewItem.Left # 图片在文字的左边
p.displayAlignment = Qt.AlignLeft | Qt.AlignCenter # 设置文字的位置
QApplication.style().drawControl(QStyle.CE_ItemViewItem, p, painter)
else:
# :向表格中渲染数据,如果缺少下面代码,表格中数据不能正常显示。
# :这里应该在model的data函数之后调用,此时通过index可以获取要显示。
# :的数据。
p = QStyleOptionViewItem()
p.features = QStyleOptionViewItem.HasDisplay
p.index = index # 表格QModelIndex索引
p.rect = option.rect
p.state = option.state p.showDecorationSelected = True # 开启选中时,单元格高亮显示
p.text = str(index.data()) # 表格中的数据
QApplication.style().drawControl(QStyle.CE_ItemViewItem, p, painter)
完整代码查看:https://gitee.com/cui_zhen/pyqt5-example.git
最新文章
- mysql 事件
- Jackson的简单用法
- 教你看懂 OpenStack 日志 - 每天5分钟玩转 OpenStack(29)
- iOS 图片选择器 总结
- 我的面经(ing)
- 上传图片预览设置src不显示
- 烂泥:kickstart无人值守安装CentOS6.5
- C++基础(2)
- MZhong&#39;s Cover Letter
- 高质量JavaScript代码书写基本要点
- PHP发送微信模版消息
- VirtualBox虚拟机网络设置
- [Leetcode][Python]41: First Missing Positive
- ALEX WANG(王培沂)品牌_时尚频道_凤凰网
- 在CentOS下安装crontab服务
- 【Linux】gdb调试
- 伪Ajax-iframe
- SpringSecurityOAuth认证配置及Token的存储
- 裸奔的bootloader单步调试
- 【译】如何在 Android 5.0 上获取 SD卡 的读写权限
热门文章
- CF 1326 D. Prefix-Suffix Palindrome
- POJ-2411 Mondriann&#39;s Dream (状压DP)
- codeforces 580D. Kefa and Dishes
- Educational Codeforces Round 89 (Rated for Div. 2) A. Shovels and Swords (贪心)
- Codeforces Round #658 (Div. 2) D. Unmerge (思维,01背包)
- python-零基础入门-自学笔记
- Kubernets二进制安装(7)之部署主控节点服务--apiserver二进制安装
- woj1018(HDU4384)KING KONG 循环群
- JavaScript调试技巧之console.log()
- Java开发工程师最新面试题库系列——Java基础部分