QListWidget设置QWidget作为QListWidgetItem

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



1、实现QListWidget按照N像素进行滑动;
2、实现自定义QWidget作为QListWidgetItem;



代码实现:文章来源地址https://www.toymoban.com/news/detail-611231.html

from PyQt5.QtWidgets import QWidget, QLabel, QVBoxLayout, QHBoxLayout, QTextEdit, QListWidget, QListWidgetItem, QScrollArea
from PyQt5.QtGui import QFont
from PyQt5.Qt import Qt, QSize
from model.info_json_data import InfoJson

class InfoPanel(QWidget):
    def __init__(self, parent, info_dict):
        super(InfoPanel, self).__init__(parent)

        self.info_dict = info_dict

        #设置QListWidget
        self.info_item_s = QListWidget(self)
        self.info_item_s.setHorizontalScrollMode(QListWidget.ScrollPerPixel)
        self.info_item_s.setVerticalScrollMode(QListWidget.ScrollPerPixel)
        self.info_item_s.verticalScrollBar().setSingleStep(5)
        self.info_item_s.horizontalScrollBar().setSingleStep(5)

        self.hobby_widget = QWidget()
        self.matter_widget = QWidget()


        self.hobby_label = self.create_label(self.hobby_widget)
        self.matter_label = self.create_label(self.matter_widget)

        self.hobby_layout = QVBoxLayout()
        self.hobby_edit = self.create_edit(self.hobby_widget)
        self.hobby_layout.addWidget(self.hobby_label)
        self.hobby_layout.addWidget(self.hobby_edit)

        self.matter_layout = QVBoxLayout()
        self.matter_edit = self.create_edit(self.matter_widget)
        self.matter_layout.addWidget(self.matter_label)
        self.matter_layout.addWidget(self.matter_edit)

        # self.info_item_s.setLayout(self.hlayout)
        self.hobby_widget.setLayout(self.hobby_layout)

        self.matter_widget.setLayout(self.matter_layout)


        self.hobby_item = QListWidgetItem()
        self.hobby_item.setSizeHint(QSize(self.hobby_widget.width(), 300))
        self.info_item_s.addItem(self.hobby_item)
        self.info_item_s.setItemWidget(self.hobby_item, self.hobby_widget)

        self.matter_item = QListWidgetItem()
        self.matter_item.setSizeHint(QSize(self.matter_widget.width(), 300))
        self.info_item_s.addItem(self.matter_item)
        self.info_item_s.setItemWidget(self.matter_item, self.matter_widget)

        self.layout = QVBoxLayout()
        self.layout.addWidget(self.info_item_s)
        self.setLayout(self.layout)

        # signal -> slot
        self.matter_edit.textChanged.connect(self.save_matter_context)
        self.hobby_edit.textChanged.connect(self.save_hobby_context)


    @staticmethod
    def create_label(parent):
        font = QFont()
        font.setFamily('LiSu')
        font.setPointSize(16)

        label = QLabel(parent)
        label.setFont(font)
        label.setAlignment(Qt.AlignLeft)
        return label

    @staticmethod
    def create_edit(parent):
        font = QFont()
        font.setFamily('LiSu')
        font.setPointSize(14)
        edit = QTextEdit(parent)
        edit.setFont(font)
        edit.setAlignment(Qt.AlignLeft)
        return edit

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

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

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

相关文章

  • #Fortigate#LDAP 如何设置同步LDAP用户作为系统登录控制台的管理员账号

    1、首先创建一个LDAP用户服务器,在用户与认证--LDAP里面选择新建  先添加LDAP自定义名称、服务器IP、服务器端口(默认389)  然后填写common name标识符,常用标识符有三种:cn (常用名)、sAMAccountName (远程登录名)、uid (用户ID)。默认为cn。 a、当标识符为cn时,我们需要知道用户

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

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

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

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

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

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

    2024年02月16日
    浏览(48)
  • void QWidget::stackUnder(QWidget *w)

    Places the widget under w in the parent widget\\\'s stack. To make this work, the widget itself and w must be siblings. 在父窗口的栈中, 放置widget在w下面 。 为了生效,widget和w必须是兄弟。 什么意思呢? widget和w的父窗口必须是同一个,不然就不生效。 举例: 效果:黑色窗口在红色下面。  反例: u

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

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

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

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

    2024年02月13日
    浏览(43)
  • PyQT QListWidget 列表项添加、删除与编辑

    PyQT开发图形界面的应用时,QListWidget控件类用于生成列表,可以方便地以可视化方式对列表项进行选择,添加,删除,编辑操作。 如果要处理的数据是2维结构,如2维数组, Pandas DataFrame, 嵌套列表等, 请参考文章:PyQt QTableWidget 表格控件的使用 如果需要可视化处理数据库数

    2024年01月19日
    浏览(43)
  • Qt中设置QListWidget滑动条滚动速度

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

    2024年02月11日
    浏览(37)
  • QListWidget 自定义 item的图标和文字的位置

    楼主并没有完整的解决这个问题,如果你是着急寻找解决方案的就可以划走了,如果你对楼主的解决思路有兴趣,那么可以继续向下阅读。首先需求是可以控制 QListWidgetItem 的icon和text x轴的位置,但是同时保持icon在左text在右的基本布局,还要求styleSheet能够生效。 做一张两边

    2024年02月01日
    浏览(37)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包