RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1383519
Accepted
MRX
MRX
Asked:2022-07-18 23:57:45 +0000 UTC2022-07-18 23:57:45 +0000 UTC 2022-07-18 23:57:45 +0000 UTC

如何在 PySide2 或 PySide6 上制作这样的 GUI 界面?

  • 772

我想使用Python和PySide2或PySide6 library创建这样的东西(视觉上) 。它应该是一个带有图片、标题和描述的列表(我有所有这些数据)。

不幸的是,我没有找到如何大致实现它。
你能建议在这里使用哪个元素更好以及从哪里开始。
我为图片道歉,这个布局是在膝盖上制作的,元素应该是一样的,这很明显。

这大致是我想看到的。

python
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    S. Nick
    2022-07-19T02:09:09Z2022-07-19T02:09:09Z

    这个网站几乎应有尽有。你总是从这里开始寻找。

    你不必在膝盖上做任何事情。你应该总是展示你已经做了什么,并且善于说出你想做什么和你不能做什么。

    鉴于这是您的第一个问题,我将向您展示一种可能的解决方案来解决您的想法。

    为PySide2安装导入并试一试。

    import sys
    from PyQt5 import QtGui, QtWidgets, QtCore
    
    class CustomQWidget (QtWidgets.QWidget):
        def __init__ (self, parent = None):
            super(CustomQWidget, self).__init__(parent)
            
            self.titleLabel = QtWidgets.QLabel()                      
            self.titleLabel.setStyleSheet('background-color: #839B97; font-size:24px;')
            
            self.descriptionLabel  = QtWidgets.QLabel()             
            self.descriptionLabel.setWordWrap(True)
            self.descriptionLabel.setStyleSheet('background-color: #CFD3CE;')
            
            self.vBoxLayout = QtWidgets.QVBoxLayout()
            self.vBoxLayout.addWidget(self.titleLabel, 0)
            self.vBoxLayout.addWidget(self.descriptionLabel, 1)
            self.vBoxLayout.setSpacing(0)
            
            self.iconQLabel = QtWidgets.QLabel()
            self.iconQLabel.setMinimumSize(200, 200) 
            self.iconQLabel.setMaximumSize(200, 200) 
    
            self.hBoxLayout = QtWidgets.QHBoxLayout(self)        
            self.hBoxLayout.addWidget(self.iconQLabel, 0)
            self.hBoxLayout.addLayout(self.vBoxLayout, 1)
    
        def setTitle(self, text):
            self.titleLabel.setText(text)
    
        def setDescription(self, text):
            self.descriptionLabel.setText(text)
    
        def setIcon(self, imagePath):
            self.iconQLabel.setPixmap(QtGui.QPixmap(imagePath).scaled(
                200, 200, QtCore.Qt.KeepAspectRatio))
    
    
    class MainWindow (QtWidgets.QMainWindow):
        def __init__ (self):
            super().__init__()
            
            self.listWidget = QtWidgets.QListWidget(self)
            self.setCentralWidget(self.listWidget)
            
            myList = [
                ('Название 1', 
                 '''Какое-то описание 1.
    Я хочу создать что-то наподобие такого (визуально) используя python \
    и библиотеку pyside2 или pyside6, это должен быть список с картинкой, \
    названием и описанием (у меня есть все эти данные). К сожалению я не нашел \
    как это можно примерно реализовать, можете подсказать какой элемент тут \
    лучше использовать и с чего начать. (Прошу прощения за картинку это макет \
    был сделан на коленке, элементы должны быть одинаковы что очевидно)''',  
                 'lena.jpg'),
                ('Название 2', 
                 'Какое-то описание 2', 
                 'boy.jpg'),
                ('Название 3', 
                 'Какое-то описание 2',  
                 'im.png')
            ]
            
            for title, description, icon in myList:
                customQWidget = CustomQWidget()
                customQWidget.setTitle(title)
                customQWidget.setDescription(description)
                customQWidget.setIcon(icon)
                
                item = QtWidgets.QListWidgetItem(self.listWidget)
                item.setSizeHint(customQWidget.sizeHint())
                self.listWidget.addItem(item)
                self.listWidget.setItemWidget(item, customQWidget)
                
    
    if __name__ == "__main__":
        app = QtWidgets.QApplication(sys.argv)
        w = MainWindow()
        w.resize(700, 500)
        w.show()
        sys.exit(app.exec_())
    

    在此处输入图像描述

    • 1

相关问题

  • 是否可以以某种方式自定义 QTabWidget?

  • telebot.anihelper.ApiException 错误

  • Python。检查一个数字是否是 3 的幂。输出 无

  • 解析多个响应

  • 交换两个数组的元素,以便它们的新内容也反转

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5