Skip to content

Latest commit

 

History

History
199 lines (120 loc) · 18.8 KB

class_editorspatialgizmoplugin.rst

File metadata and controls

199 lines (120 loc) · 18.8 KB
github_url:hide

EditorSpatialGizmoPlugin

Inherits: :ref:`Resource<class_Resource>` < :ref:`Reference<class_Reference>` < :ref:`Object<class_Object>`

Used by the editor to define Spatial gizmo types.

Description

EditorSpatialGizmoPlugin allows you to define a new type of Gizmo. There are two main ways to do so: extending EditorSpatialGizmoPlugin for the simpler gizmos, or creating a new :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` type. See the tutorial in the documentation for more info.

Tutorials

Methods

void :ref:`add_material<class_EditorSpatialGizmoPlugin_method_add_material>` ( :ref:`String<class_String>` name, :ref:`StandardMaterial3D<class_StandardMaterial3D>` material )
:ref:`bool<class_bool>` :ref:`can_be_hidden<class_EditorSpatialGizmoPlugin_method_can_be_hidden>` ( ) virtual
void :ref:`commit_handle<class_EditorSpatialGizmoPlugin_method_commit_handle>` ( :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` gizmo, :ref:`int<class_int>` index, :ref:`Variant<class_Variant>` restore, :ref:`bool<class_bool>` cancel=false ) virtual
:ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` :ref:`create_gizmo<class_EditorSpatialGizmoPlugin_method_create_gizmo>` ( :ref:`Spatial<class_Spatial>` spatial ) virtual
void :ref:`create_handle_material<class_EditorSpatialGizmoPlugin_method_create_handle_material>` ( :ref:`String<class_String>` name, :ref:`bool<class_bool>` billboard=false )
void :ref:`create_icon_material<class_EditorSpatialGizmoPlugin_method_create_icon_material>` ( :ref:`String<class_String>` name, :ref:`Texture2D<class_Texture2D>` texture, :ref:`bool<class_bool>` on_top=false, :ref:`Color<class_Color>` color=Color( 1, 1, 1, 1 ) )
void :ref:`create_material<class_EditorSpatialGizmoPlugin_method_create_material>` ( :ref:`String<class_String>` name, :ref:`Color<class_Color>` color, :ref:`bool<class_bool>` billboard=false, :ref:`bool<class_bool>` on_top=false, :ref:`bool<class_bool>` use_vertex_color=false )
:ref:`String<class_String>` :ref:`get_handle_name<class_EditorSpatialGizmoPlugin_method_get_handle_name>` ( :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` gizmo, :ref:`int<class_int>` index ) virtual
:ref:`Variant<class_Variant>` :ref:`get_handle_value<class_EditorSpatialGizmoPlugin_method_get_handle_value>` ( :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` gizmo, :ref:`int<class_int>` index ) virtual
:ref:`StandardMaterial3D<class_StandardMaterial3D>` :ref:`get_material<class_EditorSpatialGizmoPlugin_method_get_material>` ( :ref:`String<class_String>` name, :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` gizmo )
:ref:`String<class_String>` :ref:`get_name<class_EditorSpatialGizmoPlugin_method_get_name>` ( ) virtual
:ref:`String<class_String>` :ref:`get_priority<class_EditorSpatialGizmoPlugin_method_get_priority>` ( ) virtual
:ref:`bool<class_bool>` :ref:`has_gizmo<class_EditorSpatialGizmoPlugin_method_has_gizmo>` ( :ref:`Spatial<class_Spatial>` spatial ) virtual
:ref:`bool<class_bool>` :ref:`is_handle_highlighted<class_EditorSpatialGizmoPlugin_method_is_handle_highlighted>` ( :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` gizmo, :ref:`int<class_int>` index ) virtual
:ref:`bool<class_bool>` :ref:`is_selectable_when_hidden<class_EditorSpatialGizmoPlugin_method_is_selectable_when_hidden>` ( ) virtual
void :ref:`redraw<class_EditorSpatialGizmoPlugin_method_redraw>` ( :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` gizmo ) virtual
void :ref:`set_handle<class_EditorSpatialGizmoPlugin_method_set_handle>` ( :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` gizmo, :ref:`int<class_int>` index, :ref:`Camera<class_Camera>` camera, :ref:`Vector2<class_Vector2>` point ) virtual

Method Descriptions

Adds a new material to the internal material list for the plugin. It can then be accessed with :ref:`get_material<class_EditorSpatialGizmoPlugin_method_get_material>`. Should not be overridden.


Override this method to define whether the gizmo can be hidden or not. Returns true if not overridden.


Override this method to commit gizmo handles. Called for this plugin's active gizmos.


Override this method to return a custom :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` for the spatial nodes of your choice, return null for the rest of nodes. See also :ref:`has_gizmo<class_EditorSpatialGizmoPlugin_method_has_gizmo>`.


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 :ref:`get_material<class_EditorSpatialGizmoPlugin_method_get_material>` and used in :ref:`EditorSpatialGizmo.add_handles<class_EditorSpatialGizmo_method_add_handles>`. Should not be overridden.


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 :ref:`get_material<class_EditorSpatialGizmoPlugin_method_get_material>` and used in :ref:`EditorSpatialGizmo.add_unscaled_billboard<class_EditorSpatialGizmo_method_add_unscaled_billboard>`. Should not be overridden.


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 :ref:`get_material<class_EditorSpatialGizmoPlugin_method_get_material>` and used in :ref:`EditorSpatialGizmo.add_mesh<class_EditorSpatialGizmo_method_add_mesh>` and :ref:`EditorSpatialGizmo.add_lines<class_EditorSpatialGizmo_method_add_lines>`. Should not be overridden.


Override this method to provide gizmo's handle names. Called for this plugin's active gizmos.


Gets actual value of a handle from gizmo. Called for this plugin's active gizmos.


Gets material from the internal list of materials. If an :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` is provided, it will try to get the corresponding variant (selected and/or editable).


Override this method to provide the name that will appear in the gizmo visibility menu.



Override this method to define which Spatial nodes have a gizmo from this plugin. Whenever a :ref:`Spatial<class_Spatial>` node is added to a scene this method is called, if it returns true the node gets a generic :ref:`EditorSpatialGizmo<class_EditorSpatialGizmo>` assigned and is added to this plugin's list of active gizmos.


Gets whether a handle is highlighted or not. Called for this plugin's active gizmos.


Override this method to define whether Spatial with this gizmo should be selecteble even when the gizmo is hidden.


Callback to redraw the provided gizmo. Called for this plugin's active gizmos.


Update the value of a handle after it has been updated. Called for this plugin's active gizmos.