在 QTreeWidget 中设置编辑器宽度以填充单元格
Set editor width in QTreeWidget to fill cell
默认情况下,如果在 QTreeWidget 中编辑单元格,编辑器会根据文本长度更改其宽度。
是否可以设置编辑器的宽度来填充单元格?
这里是重现屏幕截图的代码:
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
class Example(QTreeWidget):
def __init__(self):
super().__init__()
self.resize(600, 400)
self.setHeaderLabels(['Col1', 'Col2', 'Col3', 'Col4'])
self.setRootIsDecorated(False)
self.setAlternatingRowColors(True)
self.setSelectionBehavior(QAbstractItemView.SelectItems)
# self.setSelectionMode(QAbstractItemView.SingleSelection)
self.setStyleSheet('QTreeView { show-decoration-selected: 1;}')
for i in range(5):
item = QTreeWidgetItem(['hello', 'bello'])
item.setFlags(item.flags() | Qt.ItemIsEditable)
self.addTopLevelItem(item)
def main():
app = QApplication(sys.argv)
ex = Example()
ex.show()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
您可以创建一个简单的 QStyledItemDelegate 并覆盖其 updateEditorGeometry()
以便始终将其调整为索引矩形:
class FullSizedDelegate(QStyledItemDelegate):
def updateEditorGeometry(self, editor, opt, index):
editor.setGeometry(opt.rect)
class Example(QTreeWidget):
def __init__(self):
# ...
self.setItemDelegate(FullSizedDelegate(self))
** 更新 **
所有项目视图的默认文本编辑器是一个自动扩展的 QLineEdit,如果文本长于项目的可视矩形,它会尝试将自身扩展到最大可用宽度(视口的右边缘)。为了避免这种行为并始终使用项目矩形,您必须 return 一个标准的 QLineEdit。在这种情况下,通常不再需要 updateGeometry
覆盖(但我还是会保留它,因为某些样式可能仍然会阻止它):
class FullSizedDelegate(QStyledItemDelegate):
def createEditor(self, parent, opt, index):
if index.data() is None or isinstance(index.data(), str):
return QLineEdit(parent)
return super().createEditor(parent, opt, index)
默认情况下,如果在 QTreeWidget 中编辑单元格,编辑器会根据文本长度更改其宽度。
是否可以设置编辑器的宽度来填充单元格?
这里是重现屏幕截图的代码:
import sys
from PyQt5.QtWidgets import *
from PyQt5.QtCore import *
from PyQt5.QtGui import *
class Example(QTreeWidget):
def __init__(self):
super().__init__()
self.resize(600, 400)
self.setHeaderLabels(['Col1', 'Col2', 'Col3', 'Col4'])
self.setRootIsDecorated(False)
self.setAlternatingRowColors(True)
self.setSelectionBehavior(QAbstractItemView.SelectItems)
# self.setSelectionMode(QAbstractItemView.SingleSelection)
self.setStyleSheet('QTreeView { show-decoration-selected: 1;}')
for i in range(5):
item = QTreeWidgetItem(['hello', 'bello'])
item.setFlags(item.flags() | Qt.ItemIsEditable)
self.addTopLevelItem(item)
def main():
app = QApplication(sys.argv)
ex = Example()
ex.show()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
您可以创建一个简单的 QStyledItemDelegate 并覆盖其 updateEditorGeometry()
以便始终将其调整为索引矩形:
class FullSizedDelegate(QStyledItemDelegate):
def updateEditorGeometry(self, editor, opt, index):
editor.setGeometry(opt.rect)
class Example(QTreeWidget):
def __init__(self):
# ...
self.setItemDelegate(FullSizedDelegate(self))
** 更新 **
所有项目视图的默认文本编辑器是一个自动扩展的 QLineEdit,如果文本长于项目的可视矩形,它会尝试将自身扩展到最大可用宽度(视口的右边缘)。为了避免这种行为并始终使用项目矩形,您必须 return 一个标准的 QLineEdit。在这种情况下,通常不再需要 updateGeometry
覆盖(但我还是会保留它,因为某些样式可能仍然会阻止它):
class FullSizedDelegate(QStyledItemDelegate):
def createEditor(self, parent, opt, index):
if index.data() is None or isinstance(index.data(), str):
return QLineEdit(parent)
return super().createEditor(parent, opt, index)