PySide6.QtWidgets.QLayout¶
- class QLayout¶
- The - QLayoutclass is the base class of geometry managers. More…- Inherited by: - QStackedLayout,- QGridLayout,- QFormLayout,- QBoxLayout,- QVBoxLayout,- QHBoxLayout- Synopsis¶- Properties¶
- sizeConstraintᅟ- The resize mode of the layout
- spacingᅟ- The spacing between widgets inside the layout
 - Methods¶- def - __init__()
- def - activate()
- def - addChildLayout()
- def - addChildWidget()
- def - addWidget()
- def - adoptLayout()
- def - alignmentRect()
- def - contentsRect()
- def - isEnabled()
- def - menuBar()
- def - parentWidget()
- def - removeItem()
- def - removeWidget()
- def - setAlignment()
- def - setEnabled()
- def - setMenuBar()
- def - sizeConstraint()
- def - totalSizeHint()
- def - update()
- def - widgetEvent()
 - Virtual methods¶- def - addItem()
- def - count()
- def - indexOf()
- def - itemAt()
- def - replaceWidget()
- def - setSpacing()
- def - spacing()
- def - takeAt()
 - Static functions¶- Note - This documentation may contain snippets that were automatically translated from C++ to Python. We always welcome contributions to the snippet translation. If you see an issue with the translation, you can also let us know by creating a ticket on https:/bugreports.qt.io/projects/PYSIDE - Detailed Description¶- This is an abstract base class inherited by the concrete classes - QBoxLayout,- QGridLayout,- QFormLayout, and- QStackedLayout.- For users of - QLayoutsubclasses or of- QMainWindowthere is seldom any need to use the basic functions provided by- QLayout, such as- setSizeConstraint()or- setMenuBar(). See Layout Management for more information.- To make your own layout manager, implement the functions - addItem(),- sizeHint(),- setGeometry(),- itemAt()and- takeAt(). You should also implement- minimumSize()to ensure your layout isn’t resized to zero size if there is too little space. To support children whose heights depend on their widths, implement- hasHeightForWidth()and- heightForWidth(). See the Flow Layout example for more information about implementing custom layout managers.- Geometry management stops when the layout manager is deleted. - See also - QLayoutItemLayout Management Basic Layouts Example Flow Layout Example- class SizeConstraint¶
- The possible values are: - Constant - Description - QLayout.SetDefaultConstraint - The main widget’s minimum size is set to - minimumSize(), unless the widget already has a minimum size.- QLayout.SetFixedSize - The main widget’s size is set to - sizeHint(); it cannot be resized at all.- QLayout.SetMinimumSize - The main widget’s minimum size is set to - minimumSize(); it cannot be smaller.- QLayout.SetMaximumSize - The main widget’s maximum size is set to - maximumSize(); it cannot be larger.- QLayout.SetMinAndMaxSize - The main widget’s minimum size is set to - minimumSize()and its maximum size is set to- maximumSize().- QLayout.SetNoConstraint - The widget is not constrained. - See also 
 - Note - Properties can be used directly when - from __feature__ import true_propertyis used or via accessor functions otherwise.- Access functions:
 - property sizeConstraintᅟ: QLayout.SizeConstraint¶
 - This property holds the resize mode of the layout. - The default mode is - SetDefaultConstraint.- Access functions:
 - property spacingᅟ: int¶
 - This property holds the spacing between widgets inside the layout. - If no value is explicitly set, the layout’s spacing is inherited from the parent layout, or from the style settings for the parent widget. - For - QGridLayoutand- QFormLayout, it is possible to set different horizontal and vertical spacings using- setHorizontalSpacing()and- setVerticalSpacing(). In that case, spacing() returns -1.- Access functions:
 - Constructs a new top-level - QLayout, with parent- parent.- The layout is set directly as the top-level layout for - parent. There can be only one top-level layout for a widget. It is returned by- layout().- If - parentis- None, then you must insert this layout into another layout, or set it as a widget’s layout using- setLayout().- See also - activate()¶
- Return type:
- bool 
 
 - Redoes the layout for - parentWidget()if necessary.- You should generally not need to call this because it is automatically called at the most appropriate times. It returns true if the layout was redone. - See also - This function is called from - addLayout()or- insertLayout()functions in subclasses to add layout- childLayoutas a sub-layout.- The only scenario in which you need to call it directly is if you implement a custom layout that supports nested layouts. - See also - This function is called from - addWidget()functions in subclasses to add- was a managed widget of a layout.- If - wis already managed by a layout, this function will produce a warning, and remove- wfrom that layout. This function must therefore be called before adding- wto the layout’s data structure.- abstract addItem(item)¶
- Parameters:
- item – - QLayoutItem
 
 - Implemented in subclasses to add an - item. How it is added is specific to each subclass.- This function is not usually called in application code. To add a widget to a layout, use the - addWidget()function; to add a child layout, use the addLayout() function provided by the relevant- QLayoutsubclass.- Note - The ownership of - itemis transferred to the layout, and it’s the layout’s responsibility to delete it.- See also - Adds widget - wto this layout in a manner specific to the layout. This function uses- addItem().- Returns the rectangle that should be covered when the geometry of this layout is set to - r, provided that this layout supports- setAlignment().- The result is derived from - sizeHint()and- expandingDirections(). It is never larger than- r.- Returns a size that satisfies all size constraints on - widget, including- heightForWidth()and that is as close as possible to- size.- Returns the margins used around the layout. - By default, - QLayoutuses the values provided by the style. On most platforms, the margin is 11 pixels in all directions.- See also - Getter of property - contentsMarginsᅟ.- Returns the layout’s - geometry()rectangle, but taking into account the contents margins.- See also - abstract count()¶
- Return type:
- int 
 
 - Must be implemented in subclasses to return the number of items in the layout. - See also - getContentsMargins()¶
- Return type:
- PyObject 
 
 - For each of - left,- top,- rightand- bottomthat is not- None, stores the size of the margin named in the location the pointer refers to.- By default, - QLayoutuses the values provided by the style. On most platforms, the margin is 11 pixels in all directions.- indexOf(layoutItem)¶
- Parameters:
- layoutItem – - QLayoutItem
- Return type:
- int 
 
 - Searches for layout item - layoutItemin this layout (not including child layouts).- Returns the index of - layoutItem, or -1 if- layoutItemis not found.- indexOf(widget)
- Parameters:
- widget – - QWidget
- Return type:
- int 
 
 - Searches for widget - widgetin this layout (not including child layouts).- Returns the index of - widget, or -1 if- widgetis not found.- The default implementation iterates over all items using - itemAt().- isEnabled()¶
- Return type:
- bool 
 
 - Returns - trueif the layout is enabled; otherwise returns- false.- See also - abstract itemAt(index)¶
- Parameters:
- index – int 
- Return type:
 
 - Warning - This section contains snippets that were automatically translated from C++ to Python and may contain errors. - Must be implemented in subclasses to return the layout item at - index. If there is no such item, the function must return- None. Items are numbered consecutively from 0. If an item is deleted, other items will be renumbered.- This function can be used to iterate over a layout. The following code will draw a rectangle for each layout item in the layout structure of the widget. - Return type:
 
 - Returns the menu bar set for this layout, or - Noneif no menu bar is set.- See also - Returns the parent widget of this layout, or - Noneif this layout is not installed on any widget.- If the layout is a sub-layout, this function returns the parent widget of the parent layout. - See also - removeItem(item)¶
- Parameters:
- item – - QLayoutItem
 
 - Removes the layout item - itemfrom the layout. It is the caller’s responsibility to delete the item.- Notice that - itemcan be a layout (since- QLayoutinherits- QLayoutItem).- See also - Removes the widget - widgetfrom the layout. After this call, it is the caller’s responsibility to give the widget a reasonable geometry or to put the widget back into a layout or to explicitly hide it if necessary.- Note - The ownership of - widgetremains the same as when it was added.- See also - replaceWidget(from, to[, options=Qt.FindChildrenRecursively])¶
- Parameters:
- from – - QWidget
- to – - QWidget
- options – Combination of - FindChildOption
 
- Return type:
 
 - Searches for widget - fromand replaces it with widget- toif found. Returns the layout item that contains the widget- fromon success. Otherwise- Noneis returned. If- optionscontains- Qt::FindChildrenRecursively(the default), sub-layouts are searched for doing the replacement. Any other flag in- optionsis ignored.- Notice that the returned item therefore might not belong to this layout, but to a sub-layout. - The returned layout item is no longer owned by the layout and should be either deleted or inserted to another layout. The widget - fromis no longer managed by the layout and may need to be deleted or hidden. The parent of widget- fromis left unchanged.- This function works for the built-in Qt layouts, but might not work for custom layouts. - See also - setAlignment(l, alignment)¶
- Parameters:
- l – - QLayout
- alignment – Combination of - AlignmentFlag
 
- Return type:
- bool 
 
 - This is an overloaded function. - Sets the alignment for the layout - lto- alignmentand returns- trueif- lis found in this layout (not including child layouts); otherwise returns- false.- setAlignment(w, alignment)
- Parameters:
- w – - QWidget
- alignment – Combination of - AlignmentFlag
 
- Return type:
- bool 
 
 - Sets the alignment for widget - wto- alignmentand returns true if- wis found in this layout (not including child layouts); otherwise returns- false.- Sets the - marginsto use around the layout.- By default, - QLayoutuses the values provided by the style. On most platforms, the margin is 11 pixels in all directions.- See also - Setter of property - contentsMarginsᅟ.- setContentsMargins(left, top, right, bottom)
- Parameters:
- left – int 
- top – int 
- right – int 
- bottom – int 
 
 
 - Sets the - left,- top,- right, and- bottommargins to use around the layout.- By default, - QLayoutuses the values provided by the style. On most platforms, the margin is 11 pixels in all directions.- setEnabled(enable)¶
- Parameters:
- enable – bool 
 
 - Enables this layout if - enableis true, otherwise disables it.- An enabled layout adjusts dynamically to changes; a disabled layout acts as if it did not exist. - By default all layouts are enabled. - See also - Tells the geometry manager to place the menu bar - widgetat the top of- parentWidget(), outside- contentsMargins(). All child widgets are placed below the bottom edge of the menu bar.- See also - setSizeConstraint(arg__1)¶
- Parameters:
- arg__1 – - SizeConstraint
 - See also 
 - Setter of property - sizeConstraintᅟ.- Setter of property - spacingᅟ.- sizeConstraint()¶
- Return type:
 - See also 
 - Getter of property - sizeConstraintᅟ.- spacing()¶
- Return type:
- int 
 - See also 
 - Getter of property - spacingᅟ.- abstract takeAt(index)¶
- Parameters:
- index – int 
- Return type:
 
 - Warning - This section contains snippets that were automatically translated from C++ to Python and may contain errors. - Must be implemented in subclasses to remove the layout item at - indexfrom the layout, and return the item. If there is no such item, the function must do nothing and return 0. Items are numbered consecutively from 0. If an item is removed, other items will be renumbered.- The following code fragment shows a safe way to remove all items from a layout: - totalHeightForWidth(w)¶
- Parameters:
- w – int 
- Return type:
- int 
 
 - totalMinimumHeightForWidth(w)¶
- Parameters:
- w – int 
- Return type:
- int 
 
 - unsetContentsMargins()¶
 - Unsets any user-defined margins around the layout. The layout will use the default values provided by the style. - See also - Reset function of property - contentsMarginsᅟ.- update()¶
 - Updates the layout for - parentWidget().- You should generally not need to call this because it is automatically called at the most appropriate times. - See also - activate()- invalidate()