Какие виджеты Qt использовать для списка «только для чтения», с возможностью прокрутки, сворачивания, списка значков - PullRequest
14 голосов
/ 04 сентября 2010

Я относительно новичок в Qt и не совсем знаком с готовыми виджетами. У меня есть несколько (но не очень) сложный виджет для создания, и я не хочу изобретать какие-либо колеса. Что лучше QWidget для использования в качестве отправной точки для подкласса и / или QWidget для создания моего виджета. Вот конечный результат, который я ищу (извинения за грубый рисунок):

Widget

Ключевые моменты:

  • Все значки будут иметь одинаковый размер, скажем, 128 x 128. Игнорируя группировки категорий, все они должны выровняться в красивой сетке.
  • Виджет должен расширяться, чтобы заполнить всю горизонтальную и вертикальную область, которую он может занять. Увеличение / уменьшение по горизонтали может увеличивать / уменьшать количество значков, отображаемых в каждом ряду.
  • Значки сгруппированы, и эти группы должны быть разборными.
  • Если высота виджета превышает его пространство, должна появиться вертикальная полоса прокрутки.

1 Ответ

7 голосов
/ 04 сентября 2010

Вы действительно ищете некоторые из более эзотерических опций для QListView / QListWidget.

На верхнем уровне добавление QTreeWidget или QTreeView даст вам иерархию, которую вы ищете, а также управление областью прокрутки.

Каждый элемент в списке (расширенный) QTreeXItem будет QListView / QListWidget, устанавливая на них setViewMode(QListView::IconMode).

EDIT: Обратите внимание, что для того, чтобы получить точный внешний вид, который вы хотели выше, вам, вероятно, придется использовать QListView и использовать собственный делегат, обрабатывая чертеж самостоятельно (если вы не можете найти тему, которая будет делать именно то, что вы хотите). Однако ниже я написал небольшое решение PyQt, используя классы Q * Widget, потому что они короче и покажут, как получить правильный макет. Если вы используете C ++, применяются те же вызовы функций Qt, но, очевидно, у вас может быть больше или меньше бухгалтерии.

import sys
from PyQt4 import QtGui, QtCore

class displayItem(QtGui.QWidget):  #A simple widget to display, just centers a digit in a 100x100 widget
    def __init__(self,num):
        QtGui.QWidget.__init__(self)
        self.size=100
        self.resize(self.size,self.size)
        self.setMinimumSize(self.size,self.size)
        self.text = num
    def paintEvent(self,event):
        p = QtGui.QPainter(self)
        p.drawText(self.size//2,self.size//2,str(self.text))

app = QtGui.QApplication(sys.argv)
widget = QtGui.QTreeWidget()
widget.setWindowTitle('simple tree')

#Build the list widgets
treeItem1 = QtGui.QTreeWidgetItem(widget)
treeItem1.setText(0,"TreeWidget Parent")   #Sets the "header" for your [+] box

list1 = QtGui.QListWidget()                #This will contain your icon list
list1.setMovement(QtGui.QListView.Static)  #otherwise the icons are draggable
list1.setResizeMode(QtGui.QListView.Adjust) #Redo layout every time we resize
list1.setViewMode(QtGui.QListView.IconMode) #Layout left-to-right, not top-to-bottom

listItem = QtGui.QListWidgetItem(list1)
listItem.setSizeHint(QtCore.QSize(100,100)) #Or else the widget items will overlap (irritating bug)
list1.setItemWidget(listItem,displayItem(1))

listItem = QtGui.QListWidgetItem(list1)     #Add a few more items
listItem.setSizeHint(QtCore.QSize(100,100))
list1.setItemWidget(listItem,displayItem(2))

listItem = QtGui.QListWidgetItem(list1)
listItem.setSizeHint(QtCore.QSize(100,100))
list1.setItemWidget(listItem,displayItem(3))

list1.setAutoFillBackground(True)                #Required for a widget that will be a QTreeWidgetItem widget
treeSubItem1 = QtGui.QTreeWidgetItem(treeItem1)  #Make a subitem to hold our list
widget.setItemWidget(treeSubItem1,0,list1)       #Assign this list as a tree item

treeItem2 = QtGui.QTreeWidgetItem(widget)        #Make a fake second parent
treeItem2.setText(0,"TreeWidget Parent II")

widget.show()           #kick off the app in standard PyQt4 fashion
sys.exit(app.exec_())
...