rou*_*rld 2 python qt qml pyside2
我TableView在 PySide2 Qt 5.13.0 中创建了一个。我想要TableView填充父项的宽度,但除非我拖动表格,否则它不会调整列的大小。从程序开始,我希望列更宽。
主文件
import sys
from PySide2.QtCore import QUrl
from PySide2.QtQml import QQmlApplicationEngine, qmlRegisterType
from PySide2.QtWidgets import QApplication
from table_model import TableModel
import qml_rc # noqa: F401
if __name__ == "__main__":
app = QApplication(sys.argv)
engine = QQmlApplicationEngine()
qmlRegisterType(TableModel, "TableModel", 1, 0, "TableModel")
engine.load(QUrl("qrc:/main.qml"))
if not engine.rootObjects():
sys.exit(-1)
sys.exit(app.exec_())
Run Code Online (Sandbox Code Playgroud)
主文件
import QtQuick 2.13
import QtQuick.Controls 2.13
import TableModel 1.0
ApplicationWindow {
visible: true
Component.onCompleted: {
showMaximized()
}
TableView {
id: tableView
clip: true
anchors.fill: parent
model: TableModel {}
topMargin: columnsHeader.implicitHeight
columnWidthProvider: function () { return tableView.width / tableView.model.columnCount(); }
delegate: Rectangle {
implicitWidth: tableView.columnWidthProvider()
implicitHeight: 40
Text {
text: display
}
}
Row {
id: columnsHeader
y: tableView.contentY
z: 2
Repeater {
model: tableView.columns > 0 ? tableView.columns : 1
Rectangle {
width: tableView.columnWidthProvider()
height: 60
clip: true
Label {
id: headerText
width: parent.width
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
text: tableView.model.headerData(modelData, Qt.Horizontal)
elide: Text.ElideRight
clip: true
}
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
表模型.py
import QtQuick 2.13
import QtQuick.Controls 2.13
import TableModel 1.0
ApplicationWindow {
visible: true
Component.onCompleted: {
showMaximized()
}
TableView {
id: tableView
clip: true
anchors.fill: parent
model: TableModel {}
topMargin: columnsHeader.implicitHeight
columnWidthProvider: function () { return tableView.width / tableView.model.columnCount(); }
delegate: Rectangle {
implicitWidth: tableView.columnWidthProvider()
implicitHeight: 40
Text {
text: display
}
}
Row {
id: columnsHeader
y: tableView.contentY
z: 2
Repeater {
model: tableView.columns > 0 ? tableView.columns : 1
Rectangle {
width: tableView.columnWidthProvider()
height: 60
clip: true
Label {
id: headerText
width: parent.width
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
text: tableView.model.headerData(modelData, Qt.Horizontal)
elide: Text.ElideRight
clip: true
}
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
表.py
from typing import Any, Optional
from PySide2.QtCore import QAbstractTableModel, QModelIndex, QObject, Qt
from table import Table
class TableModel(QAbstractTableModel):
def __init__(self, parent: QObject = None) -> None:
super().__init__(parent)
self._model_data = Table(
["This", "Is", "A", "Test", "Of", "Headers"],
[
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
["A", 1, 2, "B", "C", "D"],
["E", 3, 4, "F", "G", "H"],
["I", 5, 6, "J", "K", "L"],
["M", 7, 8, "N", "O", "P"],
])
def rowCount(self, parent=QModelIndex()) -> int:
return len(self._model_data.rows)
def columnCount(self, parent=QModelIndex()) -> int:
return len(self._model_data.headers)
def data(self, index: QModelIndex, role=Qt.DisplayRole) -> Optional[Any]:
if role != Qt.DisplayRole:
return None
if not self.checkIndex(index, QAbstractTableModel.CheckIndexOption.IndexIsValid):
return None
return self._model_data.rows[index.row()][index.column()]
def headerData(self, section: int, orientation, role) -> Optional[str]:
if role != Qt.DisplayRole:
return None
if section < 0 or section >= len(self._model_data.headers):
return None
return self._model_data.headers[section]
def reset_with_data(self, model_data: Table) -> None:
self.beginResetModel()
self._model_data = model_data
self.endResetModel()
Run Code Online (Sandbox Code Playgroud)
qml.qrc
<RCC>
<qresource prefix="/">
<file>main.qml</file>
</qresource>
</RCC>
Run Code Online (Sandbox Code Playgroud)
跑:
pipenv run pyside2-rcc -o qml_rc.py qml.qrc
pipenv run python main.py
Run Code Online (Sandbox Code Playgroud)
正如文档指出的那样:
行高和列宽
当一个新列被轻弹到视图中时,TableView 将通过调用 columnWidthProvider 函数来确定它的宽度。TableView 本身永远不会存储行高或列宽,因为它旨在支持包含任意数量行和列的大型模型。相反,它会在需要知道时询问应用程序。
TableView 使用项中最大的隐式宽度作为列宽,除非明确设置了 columnWidthProvider 属性。找到列宽后,同一列中的所有其他项目都将调整为该宽度,即使稍后轻弹的新项目具有更大的隐式宽度。在项目上设置显式宽度将被忽略并覆盖。
注意:列的计算宽度在从视口中弹出时会被丢弃,如果该列被弹回,则重新计算。计算始终基于该列弹入时可见的项目。这意味着它每次都可能会有所不同,具体取决于您在列进入时所在的行。因此,您应该对列中的所有项目具有相同的隐式宽度,或设置 columnWidthProvider。相同的逻辑适用于行高计算。
如果更改 rowHeightProvider 或 columnWidthProvider 为视口内的行和列返回的值,则必须调用 forceLayout。这会通知 TableView 它需要再次使用提供程序函数来重新计算和更新布局。
从 Qt 5.13 开始,如果要隐藏特定列,可以从该列的 columnWidthProvider 返回 0。同样,您可以从 rowHeightProvider 返回 0 以隐藏行。如果返回负数,TableView 将回退以根据委托项计算大小。
注意:行或列的大小应为整数,以避免项目的亚像素对齐。
下面的示例展示了如何设置一个简单的 columnWidthProvider 以及一个修改函数返回值的计时器。当数组被修改时,会调用 forceLayout 让修改生效:
Run Code Online (Sandbox Code Playgroud)TableView { id: tableView property var columnWidths: [100, 50, 80, 150] columnWidthProvider: function (column) { return columnWidths[column] } Timer { running: true interval: 2000 onTriggered: { tableView.columnWidths[2] = 150 tableView.forceLayout(); } } }
(强调我的)
因此,在这种情况下,当 TableView 的宽度发生变化时,您应该调用forceLayout(). 就我而言(Qt 5.13.1、PySide2 5.13.1、Linux),我还必须为 ApplicationWindow 设置宽度和高度:
import QtQuick 2.13
import QtQuick.Controls 2.13
import TableModel 1.0
ApplicationWindow {
visible: true
Component.onCompleted: {
showMaximized()
}
width: 640
height: 480
TableView {
id: tableView
clip: true
anchors.fill: parent
model: TableModel{}
topMargin: columnsHeader.implicitHeight
columnWidthProvider: function (column) {
return tableView.model ? tableView.width/tableView.model.columnCount() : 0
}
onWidthChanged: tableView.forceLayout()
delegate: Rectangle {
implicitWidth: tableView.columnWidthProvider(column)
implicitHeight: 40
Text {
text: display
}
}
Row {
id: columnsHeader
y: tableView.contentY
z: 2
Repeater {
model: tableView.columns > 0 ? tableView.columns : 1
Rectangle {
width: tableView.columnWidthProvider(modelData)
height: 60
clip: true
Label{
id: headerText
width: parent.width
horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
text: tableView.model ? tableView.model.headerData(modelData, Qt.Horizontal): 0
elide: Text.ElideRight
clip: true
}
}
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3241 次 |
| 最近记录: |