- class QLayout#
The
QLayout
class is the base class of geometry managers. More…Inherited by:
QStackedLayout
,QGridLayout
,QFormLayout
,QBoxLayout
,QVBoxLayout
,QHBoxLayout
Synopsis#
Properties#
sizeConstraintᅟ
- The resize mode of the layoutspacingᅟ
- 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
, andQStackedLayout
.For users of
QLayout
subclasses or ofQMainWindow
there is seldom any need to use the basic functions provided byQLayout
, such assetSizeConstraint()
orsetMenuBar()
. See Layout Management for more information.To make your own layout manager, implement the functions
addItem()
,sizeHint()
,setGeometry()
,itemAt()
andtakeAt()
. You should also implementminimumSize()
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, implementhasHeightForWidth()
andheightForWidth()
. See the Flow Layout example for more information about implementing custom layout managers.Geometry management stops when the layout manager is deleted.
See also
QLayoutItem
Layout 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 tomaximumSize()
.QLayout.SetNoConstraint
The widget is not constrained.
See also
Note
Properties can be used directly when
from __feature__ import true_property
is 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
QGridLayout
andQFormLayout
, it is possible to set different horizontal and vertical spacings usingsetHorizontalSpacing()
andsetVerticalSpacing()
. In that case, spacing() returns -1.- Access functions:
Constructs a new top-level
QLayout
, with parentparent
.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 bylayout()
.If
parent
isNone
, then you must insert this layout into another layout, or set it as a widget’s layout usingsetLayout()
.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()
orinsertLayout()
functions in subclasses to add layoutchildLayout
as 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 addw
as a managed widget of a layout.If
w
is already managed by a layout, this function will produce a warning, and removew
from that layout. This function must therefore be called before addingw
to the layout’s data structure.- abstract addItem(arg__1)#
- Parameters:
arg__1 –
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 relevantQLayout
subclass.Note
The ownership of
item
is transferred to the layout, and it’s the layout’s responsibility to delete it.See also
Adds widget
w
to this layout in a manner specific to the layout. This function usesaddItem()
.Returns the rectangle that should be covered when the geometry of this layout is set to
r
, provided that this layout supportssetAlignment()
.The result is derived from
sizeHint()
andexpandingDirections()
. It is never larger thanr
.Returns a size that satisfies all size constraints on
widget
, includingheightForWidth()
and that is as close as possible tosize
.Returns the margins used around the layout.
By default,
QLayout
uses 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
,right
andbottom
that is notNone
, stores the size of the margin named in the location the pointer refers to.By default,
QLayout
uses the values provided by the style. On most platforms, the margin is 11 pixels in all directions.- indexOf(arg__1)#
- Parameters:
arg__1 –
QLayoutItem
- Return type:
int
Searches for layout item
layoutItem
in this layout (not including child layouts).Returns the index of
layoutItem
, or -1 iflayoutItem
is not found.- indexOf(arg__1)
- Parameters:
arg__1 –
QWidget
- Return type:
int
Searches for widget
widget
in this layout (not including child layouts).Returns the index of
widget
, or -1 ifwidget
is not found.The default implementation iterates over all items using
itemAt()
.- isEnabled()#
- Return type:
bool
Returns
true
if the layout is enabled; otherwise returnsfalse
.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 returnNone
. 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
None
if no menu bar is set.See also
Returns the parent widget of this layout, or
None
if 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(arg__1)#
- Parameters:
arg__1 –
QLayoutItem
Removes the layout item
item
from the layout. It is the caller’s responsibility to delete the item.Notice that
item
can be a layout (sinceQLayout
inheritsQLayoutItem
).See also
Removes the widget
widget
from 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
widget
remains 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
from
and replaces it with widgetto
if found. Returns the layout item that contains the widgetfrom
on success. OtherwiseNone
is returned. Ifoptions
containsQt::FindChildrenRecursively
(the default), sub-layouts are searched for doing the replacement. Any other flag inoptions
is 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
from
is no longer managed by the layout and may need to be deleted or hidden. The parent of widgetfrom
is 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
l
toalignment
and returnstrue
ifl
is found in this layout (not including child layouts); otherwise returnsfalse
.- setAlignment(w, alignment)
- Parameters:
w –
QWidget
alignment – Combination of
AlignmentFlag
- Return type:
bool
Sets the alignment for widget
w
toalignment
and returns true ifw
is found in this layout (not including child layouts); otherwise returnsfalse
.Sets the
margins
to use around the layout.By default,
QLayout
uses 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
, andbottom
margins to use around the layout.By default,
QLayout
uses the values provided by the style. On most platforms, the margin is 11 pixels in all directions.- setEnabled(arg__1)#
- Parameters:
arg__1 – bool
Enables this layout if
enable
is 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
widget
at the top ofparentWidget()
, outsidecontentsMargins()
. 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
index
from 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()