The QGraphicsGridLayout class provides a grid layout for managing widgets in Graphics View. More...
Header: | #include <QGraphicsGridLayout> |
CMake: | find_package(Qt6 REQUIRED COMPONENTS Widgets) target_link_libraries(mytarget PRIVATE Qt6::Widgets) |
qmake: | QT += widgets |
Inherits: | QGraphicsLayout |
QGraphicsGridLayout(QGraphicsLayoutItem *parent = nullptr) | |
virtual | ~QGraphicsGridLayout() |
void | addItem(QGraphicsLayoutItem *item, int row, int column, int rowSpan, int columnSpan, Qt::Alignment alignment = Qt::Alignment()) |
void | addItem(QGraphicsLayoutItem *item, int row, int column, Qt::Alignment alignment = Qt::Alignment()) |
Qt::Alignment | alignment(QGraphicsLayoutItem *item) const |
Qt::Alignment | columnAlignment(int column) const |
int | columnCount() const |
qreal | columnMaximumWidth(int column) const |
qreal | columnMinimumWidth(int column) const |
qreal | columnPreferredWidth(int column) const |
qreal | columnSpacing(int column) const |
int | columnStretchFactor(int column) const |
qreal | horizontalSpacing() const |
QGraphicsLayoutItem * | itemAt(int row, int column) const |
void | removeItem(QGraphicsLayoutItem *item) |
Qt::Alignment | rowAlignment(int row) const |
int | rowCount() const |
qreal | rowMaximumHeight(int row) const |
qreal | rowMinimumHeight(int row) const |
qreal | rowPreferredHeight(int row) const |
qreal | rowSpacing(int row) const |
int | rowStretchFactor(int row) const |
void | setAlignment(QGraphicsLayoutItem *item, Qt::Alignment alignment) |
void | setColumnAlignment(int column, Qt::Alignment alignment) |
void | setColumnFixedWidth(int column, qreal width) |
void | setColumnMaximumWidth(int column, qreal width) |
void | setColumnMinimumWidth(int column, qreal width) |
void | setColumnPreferredWidth(int column, qreal width) |
void | setColumnSpacing(int column, qreal spacing) |
void | setColumnStretchFactor(int column, int stretch) |
void | setHorizontalSpacing(qreal spacing) |
void | setRowAlignment(int row, Qt::Alignment alignment) |
void | setRowFixedHeight(int row, qreal height) |
void | setRowMaximumHeight(int row, qreal height) |
void | setRowMinimumHeight(int row, qreal height) |
void | setRowPreferredHeight(int row, qreal height) |
void | setRowSpacing(int row, qreal spacing) |
void | setRowStretchFactor(int row, int stretch) |
void | setSpacing(qreal spacing) |
void | setVerticalSpacing(qreal spacing) |
qreal | verticalSpacing() const |
virtual int | count() const override |
virtual void | invalidate() override |
virtual QGraphicsLayoutItem * | itemAt(int index) const override |
virtual void | removeAt(int index) override |
virtual void | setGeometry(const QRectF &rect) override |
virtual QSizeF | sizeHint(Qt::SizeHint which, const QSizeF &constraint = QSizeF()) const override |
The most common way to use QGraphicsGridLayout is to construct an object on the heap with no parent, add widgets and layouts by calling addItem(), and finally assign the layout to a widget by calling QGraphicsWidget::setLayout(). QGraphicsGridLayout automatically computes the dimensions of the grid as you add items.
QGraphicsScene scene; QGraphicsWidget *textEdit = scene.addWidget(new QTextEdit); QGraphicsWidget *pushButton = scene.addWidget(new QPushButton); QGraphicsGridLayout *layout = new QGraphicsGridLayout; layout->addItem(textEdit, 0, 0); layout->addItem(pushButton, 0, 1); QGraphicsWidget *form = new QGraphicsWidget; form->setLayout(layout); scene.addItem(form);
The layout takes ownership of the items. In some cases when the layout item also inherits from QGraphicsItem (such as QGraphicsWidget) there will be a ambiguity in ownership because the layout item belongs to two ownership hierarchies. See the documentation of QGraphicsLayoutItem::setOwnedByLayout() how to handle this. You can access each item in the layout by calling count() and itemAt(). Calling removeAt() will remove an item from the layout, without destroying it.
QGraphicsGridLayout respects each item's size hints and size policies, and when a cell in the grid has more space than the items can fill, each item is arranged according to the layout's alignment for that item. You can set an alignment for each item by calling setAlignment(), and check the alignment for any item by calling alignment(). You can also set the alignment for an entire row or column by calling setRowAlignment() and setColumnAlignment() respectively. By default, items are aligned to the top left.
See also QGraphicsLinearLayout and QGraphicsWidget.
Constructs a QGraphicsGridLayout instance. parent is passed to QGraphicsLayout's constructor.
[virtual]
QGraphicsGridLayout::~QGraphicsGridLayout()Destroys the QGraphicsGridLayout object.
Adds item to the grid on row and column. You can specify a rowSpan and columnSpan and an optional alignment.
Adds item to the grid on row and column. You can specify an optional alignment for item.
Returns the alignment for item.
See also setAlignment().
Returns the alignment for column.
See also setColumnAlignment().
Returns the number of columns in the grid layout. This is always one more than the index of the last column that is occupied by a layout item (empty columns are counted except for those at the end).
Returns the maximum width for column.
See also setColumnMaximumWidth().
Returns the minimum width for column.
See also setColumnMinimumWidth().
Returns the preferred width for column.
See also setColumnPreferredWidth().
Returns the column spacing for column.
See also setColumnSpacing().
Returns the stretch factor for column.
See also setColumnStretchFactor().
[override virtual]
int QGraphicsGridLayout::count() constReimplements: QGraphicsLayout::count() const.
Returns the number of layout items in this grid layout.
Returns the default horizontal spacing for the grid layout.
See also setHorizontalSpacing().
[override virtual]
void QGraphicsGridLayout::invalidate()Reimplements: QGraphicsLayout::invalidate().
Returns a pointer to the layout item at (row, column).
[override virtual]
QGraphicsLayoutItem *QGraphicsGridLayout::itemAt(int index) constReimplements: QGraphicsLayout::itemAt(int i) const.
Returns the layout item at index, or nullptr
if there is no layout item at this index.
[override virtual]
void QGraphicsGridLayout::removeAt(int index)Reimplements: QGraphicsLayout::removeAt(int index).
Removes the layout item at index without destroying it. Ownership of the item is transferred to the caller.
See also addItem().
Removes the layout item item without destroying it. Ownership of the item is transferred to the caller.
See also addItem().
Returns the alignment of row.
See also setRowAlignment().
Returns the number of rows in the grid layout. This is always one more than the index of the last row that is occupied by a layout item (empty rows are counted except for those at the end).
Returns the maximum height for row, row.
See also setRowMaximumHeight().
Returns the minimum height for row, row.
See also setRowMinimumHeight().
Returns the preferred height for row, row.
See also setRowPreferredHeight().
Returns the row spacing for row.
See also setRowSpacing().
Returns the stretch factor for row.
See also setRowStretchFactor().
Sets the alignment for item to alignment.
See also alignment().
Sets the alignment for column to alignment.
See also columnAlignment().
Sets the fixed width of column to width.
Sets the maximum width of column to width.
See also columnMaximumWidth().
Sets the minimum width for column to width.
See also columnMinimumWidth().
Sets the preferred width for column to width.
See also columnPreferredWidth().
Sets the spacing for column to spacing.
See also columnSpacing().
Sets the stretch factor for column to stretch.
See also columnStretchFactor().
[override virtual]
void QGraphicsGridLayout::setGeometry(const QRectF
&rect)Reimplements: QGraphicsLayoutItem::setGeometry(const QRectF &rect).
Sets the bounding geometry of the grid layout to rect.
Sets the default horizontal spacing for the grid layout to spacing.
See also horizontalSpacing().
Sets the alignment of row to alignment.
See also rowAlignment().
Sets the fixed height for row, row, to height.
Sets the maximum height for row, row, to height.
See also rowMaximumHeight().
Sets the minimum height for row, row, to height.
See also rowMinimumHeight().
Sets the preferred height for row, row, to height.
See also rowPreferredHeight().
Sets the spacing for row to spacing.
See also rowSpacing().
Sets the stretch factor for row to stretch.
See also rowStretchFactor().
Sets the grid layout's default spacing, both vertical and horizontal, to spacing.
See also rowSpacing() and columnSpacing().
Sets the default vertical spacing for the grid layout to spacing.
See also verticalSpacing().
[override virtual]
QSizeF QGraphicsGridLayout::sizeHint(Qt::SizeHint which, const QSizeF &constraint = QSizeF()) constReimplements: QGraphicsLayoutItem::sizeHint(Qt::SizeHint which, const QSizeF &constraint) const.
Returns the default vertical spacing for the grid layout.
See also setVerticalSpacing().