2018-10-29 18:30:28 +08:00
<?xml version="1.0" encoding="UTF-8" ?>
2020-03-31 00:22:57 +08:00
<class name= "EditorNode3DGizmoPlugin" inherits= "Resource" version= "4.0" >
2018-10-29 18:30:28 +08:00
<brief_description >
2020-03-31 00:22:57 +08:00
Used by the editor to define Node3D gizmo types.
2018-10-29 18:30:28 +08:00
</brief_description>
<description >
2020-03-31 00:22:57 +08:00
EditorNode3DGizmoPlugin allows you to define a new type of Gizmo. There are two main ways to do so: extending [EditorNode3DGizmoPlugin] for the simpler gizmos, or creating a new [EditorNode3DGizmo] type. See the tutorial in the documentation for more info.
2018-10-29 18:30:28 +08:00
</description>
<tutorials >
2020-08-05 20:43:40 +08:00
<link title= "Spatial gizmo plugins" > https://docs.godotengine.org/en/latest/tutorials/plugins/editor/spatial_gizmos.html</link>
2018-10-29 18:30:28 +08:00
</tutorials>
<methods >
<method name= "add_material" >
<return type= "void" >
</return>
<argument index= "0" name= "name" type= "String" >
</argument>
2020-02-12 16:59:06 +08:00
<argument index= "1" name= "material" type= "StandardMaterial3D" >
2018-10-29 18:30:28 +08:00
</argument>
<description >
2019-01-25 19:57:32 +08:00
Adds a new material to the internal material list for the plugin. It can then be accessed with [method get_material]. Should not be overridden.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "can_be_hidden" qualifiers= "virtual" >
<return type= "bool" >
</return>
<description >
2019-06-29 21:24:23 +08:00
Override this method to define whether the gizmo can be hidden or not. Returns [code]true[/code] if not overridden.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "commit_handle" qualifiers= "virtual" >
<return type= "void" >
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "gizmo" type= "EditorNode3DGizmo" >
2018-10-29 18:30:28 +08:00
</argument>
<argument index= "1" name= "index" type= "int" >
</argument>
<argument index= "2" name= "restore" type= "Variant" >
</argument>
<argument index= "3" name= "cancel" type= "bool" default= "false" >
</argument>
<description >
2019-01-25 19:57:32 +08:00
Override this method to commit gizmo handles. Called for this plugin's active gizmos.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "create_gizmo" qualifiers= "virtual" >
2020-03-31 00:22:57 +08:00
<return type= "EditorNode3DGizmo" >
2018-10-29 18:30:28 +08:00
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "spatial" type= "Node3D" >
2018-10-29 18:30:28 +08:00
</argument>
<description >
2020-03-31 00:22:57 +08:00
Override this method to return a custom [EditorNode3DGizmo] for the spatial nodes of your choice, return [code]null[/code] for the rest of nodes. See also [method has_gizmo].
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "create_handle_material" >
<return type= "void" >
</return>
<argument index= "0" name= "name" type= "String" >
</argument>
<argument index= "1" name= "billboard" type= "bool" default= "false" >
</argument>
2020-11-09 11:16:26 +08:00
<argument index= "2" name= "texture" type= "Texture2D" default= "null" >
</argument>
2018-10-29 18:30:28 +08:00
<description >
2020-03-31 00:22:57 +08:00
Creates a handle material with its variants (selected and/or editable) and adds them to the internal material list. They can then be accessed with [method get_material] and used in [method EditorNode3DGizmo.add_handles]. Should not be overridden.
2020-11-09 11:16:26 +08:00
You can optionally provide a texture to use instead of the default icon.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "create_icon_material" >
<return type= "void" >
</return>
<argument index= "0" name= "name" type= "String" >
</argument>
2020-02-12 16:59:06 +08:00
<argument index= "1" name= "texture" type= "Texture2D" >
2018-10-29 18:30:28 +08:00
</argument>
<argument index= "2" name= "on_top" type= "bool" default= "false" >
</argument>
<argument index= "3" name= "color" type= "Color" default= "Color( 1, 1, 1, 1 )" >
</argument>
<description >
2020-03-31 00:22:57 +08:00
Creates an icon material with its variants (selected and/or editable) and adds them to the internal material list. They can then be accessed with [method get_material] and used in [method EditorNode3DGizmo.add_unscaled_billboard]. Should not be overridden.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "create_material" >
<return type= "void" >
</return>
<argument index= "0" name= "name" type= "String" >
</argument>
<argument index= "1" name= "color" type= "Color" >
</argument>
<argument index= "2" name= "billboard" type= "bool" default= "false" >
</argument>
<argument index= "3" name= "on_top" type= "bool" default= "false" >
</argument>
<argument index= "4" name= "use_vertex_color" type= "bool" default= "false" >
</argument>
<description >
2020-03-31 00:22:57 +08:00
Creates an unshaded material with its variants (selected and/or editable) and adds them to the internal material list. They can then be accessed with [method get_material] and used in [method EditorNode3DGizmo.add_mesh] and [method EditorNode3DGizmo.add_lines]. Should not be overridden.
2018-10-29 18:30:28 +08:00
</description>
</method>
2021-03-10 17:54:21 +08:00
<method name= "get_gizmo_name" qualifiers= "virtual" >
<return type= "String" >
</return>
<description >
Override this method to provide the name that will appear in the gizmo visibility menu.
</description>
</method>
2018-10-29 18:30:28 +08:00
<method name= "get_handle_name" qualifiers= "virtual" >
<return type= "String" >
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "gizmo" type= "EditorNode3DGizmo" >
2018-10-29 18:30:28 +08:00
</argument>
<argument index= "1" name= "index" type= "int" >
</argument>
<description >
2019-01-25 19:57:32 +08:00
Override this method to provide gizmo's handle names. Called for this plugin's active gizmos.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "get_handle_value" qualifiers= "virtual" >
<return type= "Variant" >
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "gizmo" type= "EditorNode3DGizmo" >
2018-10-29 18:30:28 +08:00
</argument>
<argument index= "1" name= "index" type= "int" >
</argument>
<description >
2019-06-22 07:04:47 +08:00
Gets actual value of a handle from gizmo. Called for this plugin's active gizmos.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "get_material" >
2020-02-12 16:59:06 +08:00
<return type= "StandardMaterial3D" >
2018-10-29 18:30:28 +08:00
</return>
<argument index= "0" name= "name" type= "String" >
</argument>
2020-11-26 01:45:10 +08:00
<argument index= "1" name= "gizmo" type= "EditorNode3DGizmo" default= "null" >
2018-10-29 18:30:28 +08:00
</argument>
<description >
2020-03-31 00:22:57 +08:00
Gets material from the internal list of materials. If an [EditorNode3DGizmo] is provided, it will try to get the corresponding variant (selected and/or editable).
2018-10-29 18:30:28 +08:00
</description>
</method>
2019-03-13 00:03:35 +08:00
<method name= "get_priority" qualifiers= "virtual" >
2020-07-18 02:45:54 +08:00
<return type= "int" >
2019-03-13 00:03:35 +08:00
</return>
<description >
2020-07-18 23:17:00 +08:00
Override this method to set the gizmo's priority. Higher values correspond to higher priority. If a gizmo with higher priority conflicts with another gizmo, only the gizmo with higher priority will be used.
All built-in editor gizmos return a priority of [code]-1[/code]. If not overridden, this method will return [code]0[/code], which means custom gizmos will automatically override built-in gizmos.
2019-03-13 00:03:35 +08:00
</description>
</method>
2018-10-29 18:30:28 +08:00
<method name= "has_gizmo" qualifiers= "virtual" >
<return type= "bool" >
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "spatial" type= "Node3D" >
2018-10-29 18:30:28 +08:00
</argument>
<description >
2020-03-31 00:22:57 +08:00
Override this method to define which Node3D nodes have a gizmo from this plugin. Whenever a [Node3D] node is added to a scene this method is called, if it returns [code]true[/code] the node gets a generic [EditorNode3DGizmo] assigned and is added to this plugin's list of active gizmos.
2018-10-29 18:30:28 +08:00
</description>
</method>
2019-01-25 19:57:32 +08:00
<method name= "is_handle_highlighted" qualifiers= "virtual" >
2018-10-29 18:30:28 +08:00
<return type= "bool" >
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "gizmo" type= "EditorNode3DGizmo" >
2018-10-29 18:30:28 +08:00
</argument>
<argument index= "1" name= "index" type= "int" >
</argument>
<description >
2019-06-22 07:04:47 +08:00
Gets whether a handle is highlighted or not. Called for this plugin's active gizmos.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "is_selectable_when_hidden" qualifiers= "virtual" >
<return type= "bool" >
</return>
<description >
2021-03-18 19:04:28 +08:00
Override this method to define whether Node3D with this gizmo should be selectable even when the gizmo is hidden.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "redraw" qualifiers= "virtual" >
<return type= "void" >
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "gizmo" type= "EditorNode3DGizmo" >
2018-10-29 18:30:28 +08:00
</argument>
<description >
2019-01-25 19:57:32 +08:00
Callback to redraw the provided gizmo. Called for this plugin's active gizmos.
2018-10-29 18:30:28 +08:00
</description>
</method>
<method name= "set_handle" qualifiers= "virtual" >
<return type= "void" >
</return>
2020-03-31 00:22:57 +08:00
<argument index= "0" name= "gizmo" type= "EditorNode3DGizmo" >
2018-10-29 18:30:28 +08:00
</argument>
<argument index= "1" name= "index" type= "int" >
</argument>
2020-03-31 00:22:57 +08:00
<argument index= "2" name= "camera" type= "Camera3D" >
2018-10-29 18:30:28 +08:00
</argument>
<argument index= "3" name= "point" type= "Vector2" >
</argument>
<description >
2019-01-25 19:57:32 +08:00
Update the value of a handle after it has been updated. Called for this plugin's active gizmos.
2018-10-29 18:30:28 +08:00
</description>
</method>
</methods>
<constants >
</constants>
</class>