2017-09-12 22:42:36 +02:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-07-05 22:07:03 +02:00
<class name= "Container" inherits= "Control" version= "4.2" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2017-09-12 22:42:36 +02:00
<brief_description >
2023-04-30 16:26:09 +02:00
Base class for all GUI containers.
2017-09-12 22:42:36 +02:00
</brief_description>
<description >
2023-04-30 16:26:09 +02:00
Base class for all GUI containers. A [Container] automatically arranges its child controls in a certain way. This class can be inherited to make custom container types.
2017-09-12 22:42:36 +02:00
</description>
<tutorials >
2023-04-30 16:26:09 +02:00
<link title= "Using Containers" > $DOCS_URL/tutorials/ui/gui_containers.html</link>
2017-09-12 22:42:36 +02:00
</tutorials>
<methods >
2021-11-08 21:53:41 +01:00
<method name= "_get_allowed_size_flags_horizontal" qualifiers= "virtual const" >
<return type= "PackedInt32Array" />
<description >
2022-10-27 16:24:10 +02:00
Implement to return a list of allowed horizontal [enum Control.SizeFlags] for child nodes. This doesn't technically prevent the usages of any other size flags, if your implementation requires that. This only limits the options available to the user in the Inspector dock.
2021-11-08 21:53:41 +01:00
[b]Note:[/b] Having no size flags is equal to having [constant Control.SIZE_SHRINK_BEGIN]. As such, this value is always implicitly allowed.
</description>
</method>
<method name= "_get_allowed_size_flags_vertical" qualifiers= "virtual const" >
<return type= "PackedInt32Array" />
<description >
2022-10-27 16:24:10 +02:00
Implement to return a list of allowed vertical [enum Control.SizeFlags] for child nodes. This doesn't technically prevent the usages of any other size flags, if your implementation requires that. This only limits the options available to the user in the Inspector dock.
2021-11-08 21:53:41 +01:00
[b]Note:[/b] Having no size flags is equal to having [constant Control.SIZE_SHRINK_BEGIN]. As such, this value is always implicitly allowed.
</description>
</method>
2017-09-12 22:42:36 +02:00
<method name= "fit_child_in_rect" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
2022-08-06 20:11:48 +02:00
<param index= "0" name= "child" type= "Control" />
<param index= "1" name= "rect" type= "Rect2" />
2017-09-12 22:42:36 +02:00
<description >
Fit a child control in a given rect. This is mainly a helper for creating custom container classes.
</description>
</method>
<method name= "queue_sort" >
2021-07-30 15:28:05 +02:00
<return type= "void" />
2017-09-12 22:42:36 +02:00
<description >
Queue resort of the contained children. This is called automatically anyway, but can be called upon request.
</description>
</method>
</methods>
2020-02-09 00:34:08 +01:00
<members >
2021-12-02 20:38:49 +01:00
<member name= "mouse_filter" type= "int" setter= "set_mouse_filter" getter= "get_mouse_filter" overrides= "Control" enum= "Control.MouseFilter" default= "1" />
2020-02-09 00:34:08 +01:00
</members>
2017-09-12 22:42:36 +02:00
<signals >
2021-10-05 22:09:01 +02:00
<signal name= "pre_sort_children" >
<description >
Emitted when children are going to be sorted.
</description>
</signal>
2017-09-12 22:42:36 +02:00
<signal name= "sort_children" >
<description >
Emitted when sorting the children is needed.
</description>
</signal>
</signals>
<constants >
2021-10-05 22:09:01 +02:00
<constant name= "NOTIFICATION_PRE_SORT_CHILDREN" value= "50" >
Notification just before children are going to be sorted, in case there's something to process beforehand.
</constant>
<constant name= "NOTIFICATION_SORT_CHILDREN" value= "51" >
2017-09-12 22:42:36 +02:00
Notification for when sorting the children, it must be obeyed immediately.
</constant>
</constants>
</class>