2018-05-28 20:53:15 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2023-07-06 16:08:05 +08:00
<class name= "EditorInspectorPlugin" inherits= "RefCounted" xmlns:xsi= "http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation= "../class.xsd" >
2018-05-28 20:53:15 +08:00
<brief_description >
2022-10-27 22:24:10 +08:00
Plugin for adding custom property editors on the inspector.
2018-05-28 20:53:15 +08:00
</brief_description>
<description >
2021-10-15 20:30:58 +08:00
[EditorInspectorPlugin] allows adding custom property editors to [EditorInspector].
2021-05-16 05:48:59 +08:00
When an object is edited, the [method _can_handle] function is called and must return [code]true[/code] if the object type is supported.
If supported, the function [method _parse_begin] will be called, allowing to place custom controls at the beginning of the class.
Subsequently, the [method _parse_category] and [method _parse_property] are called for every category and property. They offer the ability to add custom controls to the inspector too.
Finally, [method _parse_end] will be called.
2019-04-24 13:49:38 +08:00
On each of these calls, the "add" functions can be called.
2021-10-15 20:30:58 +08:00
To use [EditorInspectorPlugin], register it using the [method EditorPlugin.add_inspector_plugin] method first.
2018-05-28 20:53:15 +08:00
</description>
<tutorials >
2021-11-15 17:43:07 +08:00
<link title= "Inspector plugins" > $DOCS_URL/tutorials/plugins/editor/inspector_plugins.html</link>
2018-05-28 20:53:15 +08:00
</tutorials>
<methods >
2021-08-22 09:52:44 +08:00
<method name= "_can_handle" qualifiers= "virtual const" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2022-09-20 00:39:35 +08:00
<param index= "0" name= "object" type= "Object" />
2018-05-28 20:53:15 +08:00
<description >
2021-05-16 05:48:59 +08:00
Returns [code]true[/code] if this object can be handled by this plugin.
2018-05-28 20:53:15 +08:00
</description>
</method>
2021-05-16 05:48:59 +08:00
<method name= "_parse_begin" qualifiers= "virtual" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "object" type= "Object" />
2018-05-28 20:53:15 +08:00
<description >
2022-08-13 00:07:53 +08:00
Called to allow adding controls at the beginning of the property list for [param object].
2018-05-28 20:53:15 +08:00
</description>
</method>
2021-05-16 05:48:59 +08:00
<method name= "_parse_category" qualifiers= "virtual" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "object" type= "Object" />
<param index= "1" name= "category" type= "String" />
2018-05-28 20:53:15 +08:00
<description >
2022-08-13 00:07:53 +08:00
Called to allow adding controls at the beginning of a category in the property list for [param object].
2018-05-28 20:53:15 +08:00
</description>
</method>
2021-05-16 05:48:59 +08:00
<method name= "_parse_end" qualifiers= "virtual" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "object" type= "Object" />
2021-11-10 22:49:19 +08:00
<description >
2022-08-13 00:07:53 +08:00
Called to allow adding controls at the end of the property list for [param object].
2021-11-10 22:49:19 +08:00
</description>
</method>
<method name= "_parse_group" qualifiers= "virtual" >
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "object" type= "Object" />
<param index= "1" name= "group" type= "String" />
2018-05-28 20:53:15 +08:00
<description >
2022-08-13 00:07:53 +08:00
Called to allow adding controls at the beginning of a group or a sub-group in the property list for [param object].
2018-05-28 20:53:15 +08:00
</description>
</method>
2021-05-16 05:48:59 +08:00
<method name= "_parse_property" qualifiers= "virtual" >
2021-07-30 21:28:05 +08:00
<return type= "bool" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "object" type= "Object" />
2023-02-01 02:08:46 +08:00
<param index= "1" name= "type" type= "int" enum= "Variant.Type" />
2022-08-07 02:11:48 +08:00
<param index= "2" name= "name" type= "String" />
2023-02-01 02:08:46 +08:00
<param index= "3" name= "hint_type" type= "int" enum= "PropertyHint" />
2022-08-07 02:11:48 +08:00
<param index= "4" name= "hint_string" type= "String" />
2023-06-15 22:06:22 +08:00
<param index= "5" name= "usage_flags" type= "int" enum= "PropertyUsageFlags" is_bitfield= "true" />
2022-08-07 02:11:48 +08:00
<param index= "6" name= "wide" type= "bool" />
2018-05-28 20:53:15 +08:00
<description >
2022-08-13 00:07:53 +08:00
Called to allow adding property-specific editors to the property list for [param object]. The added editor control must extend [EditorProperty]. Returning [code]true[/code] removes the built-in editor for this property, otherwise allows to insert a custom editor before the built-in one.
2018-05-28 20:53:15 +08:00
</description>
</method>
2021-05-16 05:48:59 +08:00
<method name= "add_custom_control" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "control" type= "Control" />
2018-05-28 20:53:15 +08:00
<description >
2021-08-07 02:01:00 +08:00
Adds a custom control, which is not necessarily a property editor.
2018-05-28 20:53:15 +08:00
</description>
</method>
2021-05-16 05:48:59 +08:00
<method name= "add_property_editor" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "property" type= "String" />
<param index= "1" name= "editor" type= "Control" />
<param index= "2" name= "add_to_end" type= "bool" default= "false" />
2024-05-25 00:18:24 +08:00
<param index= "3" name= "label" type= "String" default= """" />
2018-05-28 20:53:15 +08:00
<description >
2022-08-13 00:07:53 +08:00
Adds a property editor for an individual property. The [param editor] control must extend [EditorProperty].
2024-05-23 09:08:12 +08:00
There can be multiple property editors for a property. If [param add_to_end] is [code]true[/code], this newly added editor will be displayed after all the other editors of the property whose [param add_to_end] is [code]false[/code]. For example, the editor uses this parameter to add an "Edit Region" button for [member Sprite2D.region_rect] below the regular [Rect2] editor.
2024-05-25 00:18:24 +08:00
[param label] can be used to choose a custom label for the property editor in the inspector. If left empty, the label is computed from the name of the property instead.
2018-05-28 20:53:15 +08:00
</description>
</method>
2021-05-16 05:48:59 +08:00
<method name= "add_property_editor_for_multiple_properties" >
2021-07-30 21:28:05 +08:00
<return type= "void" />
2022-08-07 02:11:48 +08:00
<param index= "0" name= "label" type= "String" />
<param index= "1" name= "properties" type= "PackedStringArray" />
<param index= "2" name= "editor" type= "Control" />
2018-05-28 20:53:15 +08:00
<description >
2022-08-13 00:07:53 +08:00
Adds an editor that allows modifying multiple properties. The [param editor] control must extend [EditorProperty].
2018-05-28 20:53:15 +08:00
</description>
</method>
</methods>
</class>