:github_url: hide .. DO NOT EDIT THIS FILE!!! .. Generated automatically from Godot engine sources. .. Generator: https://github.com/godotengine/godot/tree/3.6/doc/tools/make_rst.py. .. XML source: https://github.com/godotengine/godot/tree/3.6/modules/visual_script/doc_classes/VisualScript.xml. .. _class_VisualScript: VisualScript ============ **Inherits:** :ref:`Script` **<** :ref:`Resource` **<** :ref:`Reference` **<** :ref:`Object` A script implemented in the Visual Script programming environment. .. rst-class:: classref-introduction-group Description ----------- A script implemented in the Visual Script programming environment. The script extends the functionality of all objects that instance it. \ :ref:`Object.set_script` extends an existing object, if that object's class matches one of the script's base classes. You are most likely to use this class via the Visual Script editor or when writing plugins for it. .. rst-class:: classref-introduction-group Tutorials --------- - :doc:`../tutorials/scripting/visual_script/index` .. rst-class:: classref-reftable-group Methods ------- .. table:: :widths: auto +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`add_custom_signal` **(** :ref:`String` name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`add_function` **(** :ref:`String` name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`add_node` **(** :ref:`String` func, :ref:`int` id, :ref:`VisualScriptNode` node, :ref:`Vector2` position=Vector2( 0, 0 ) **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`add_variable` **(** :ref:`String` name, :ref:`Variant` default_value=null, :ref:`bool` export=false **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`custom_signal_add_argument` **(** :ref:`String` name, :ref:`Variant.Type` type, :ref:`String` argname, :ref:`int` index=-1 **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`int` | :ref:`custom_signal_get_argument_count` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`String` | :ref:`custom_signal_get_argument_name` **(** :ref:`String` name, :ref:`int` argidx **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`Variant.Type` | :ref:`custom_signal_get_argument_type` **(** :ref:`String` name, :ref:`int` argidx **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`custom_signal_remove_argument` **(** :ref:`String` name, :ref:`int` argidx **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`custom_signal_set_argument_name` **(** :ref:`String` name, :ref:`int` argidx, :ref:`String` argname **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`custom_signal_set_argument_type` **(** :ref:`String` name, :ref:`int` argidx, :ref:`Variant.Type` type **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`custom_signal_swap_argument` **(** :ref:`String` name, :ref:`int` argidx, :ref:`int` withidx **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`data_connect` **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_port, :ref:`int` to_node, :ref:`int` to_port **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`data_disconnect` **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_port, :ref:`int` to_node, :ref:`int` to_port **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`int` | :ref:`get_function_node_id` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`Vector2` | :ref:`get_function_scroll` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`VisualScriptNode` | :ref:`get_node` **(** :ref:`String` func, :ref:`int` id **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`Vector2` | :ref:`get_node_position` **(** :ref:`String` func, :ref:`int` id **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`Variant` | :ref:`get_variable_default_value` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`bool` | :ref:`get_variable_export` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`Dictionary` | :ref:`get_variable_info` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`bool` | :ref:`has_custom_signal` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`bool` | :ref:`has_data_connection` **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_port, :ref:`int` to_node, :ref:`int` to_port **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`bool` | :ref:`has_function` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`bool` | :ref:`has_node` **(** :ref:`String` func, :ref:`int` id **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`bool` | :ref:`has_sequence_connection` **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_output, :ref:`int` to_node **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | :ref:`bool` | :ref:`has_variable` **(** :ref:`String` name **)** |const| | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`remove_custom_signal` **(** :ref:`String` name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`remove_function` **(** :ref:`String` name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`remove_node` **(** :ref:`String` func, :ref:`int` id **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`remove_variable` **(** :ref:`String` name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`rename_custom_signal` **(** :ref:`String` name, :ref:`String` new_name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`rename_function` **(** :ref:`String` name, :ref:`String` new_name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`rename_variable` **(** :ref:`String` name, :ref:`String` new_name **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`sequence_connect` **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_output, :ref:`int` to_node **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`sequence_disconnect` **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_output, :ref:`int` to_node **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`set_function_scroll` **(** :ref:`String` name, :ref:`Vector2` ofs **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`set_instance_base_type` **(** :ref:`String` type **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`set_node_position` **(** :ref:`String` func, :ref:`int` id, :ref:`Vector2` position **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`set_variable_default_value` **(** :ref:`String` name, :ref:`Variant` value **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`set_variable_export` **(** :ref:`String` name, :ref:`bool` enable **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ | void | :ref:`set_variable_info` **(** :ref:`String` name, :ref:`Dictionary` value **)** | +-----------------------------------------------------+---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+ .. rst-class:: classref-section-separator ---- .. rst-class:: classref-descriptions-group Signals ------- .. _class_VisualScript_signal_node_ports_changed: .. rst-class:: classref-signal **node_ports_changed** **(** :ref:`String` function, :ref:`int` id **)** Emitted when the ports of a node are changed. .. rst-class:: classref-section-separator ---- .. rst-class:: classref-descriptions-group Method Descriptions ------------------- .. _class_VisualScript_method_add_custom_signal: .. rst-class:: classref-method void **add_custom_signal** **(** :ref:`String` name **)** Add a custom signal with the specified name to the VisualScript. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_add_function: .. rst-class:: classref-method void **add_function** **(** :ref:`String` name **)** Add a function with the specified name to the VisualScript. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_add_node: .. rst-class:: classref-method void **add_node** **(** :ref:`String` func, :ref:`int` id, :ref:`VisualScriptNode` node, :ref:`Vector2` position=Vector2( 0, 0 ) **)** Add a node to a function of the VisualScript. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_add_variable: .. rst-class:: classref-method void **add_variable** **(** :ref:`String` name, :ref:`Variant` default_value=null, :ref:`bool` export=false **)** Add a variable to the VisualScript, optionally giving it a default value or marking it as exported. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_add_argument: .. rst-class:: classref-method void **custom_signal_add_argument** **(** :ref:`String` name, :ref:`Variant.Type` type, :ref:`String` argname, :ref:`int` index=-1 **)** Add an argument to a custom signal added with :ref:`add_custom_signal`. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_get_argument_count: .. rst-class:: classref-method :ref:`int` **custom_signal_get_argument_count** **(** :ref:`String` name **)** |const| Get the count of a custom signal's arguments. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_get_argument_name: .. rst-class:: classref-method :ref:`String` **custom_signal_get_argument_name** **(** :ref:`String` name, :ref:`int` argidx **)** |const| Get the name of a custom signal's argument. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_get_argument_type: .. rst-class:: classref-method :ref:`Variant.Type` **custom_signal_get_argument_type** **(** :ref:`String` name, :ref:`int` argidx **)** |const| Get the type of a custom signal's argument. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_remove_argument: .. rst-class:: classref-method void **custom_signal_remove_argument** **(** :ref:`String` name, :ref:`int` argidx **)** Remove a specific custom signal's argument. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_set_argument_name: .. rst-class:: classref-method void **custom_signal_set_argument_name** **(** :ref:`String` name, :ref:`int` argidx, :ref:`String` argname **)** Rename a custom signal's argument. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_set_argument_type: .. rst-class:: classref-method void **custom_signal_set_argument_type** **(** :ref:`String` name, :ref:`int` argidx, :ref:`Variant.Type` type **)** Change the type of a custom signal's argument. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_custom_signal_swap_argument: .. rst-class:: classref-method void **custom_signal_swap_argument** **(** :ref:`String` name, :ref:`int` argidx, :ref:`int` withidx **)** Swap two of the arguments of a custom signal. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_data_connect: .. rst-class:: classref-method void **data_connect** **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_port, :ref:`int` to_node, :ref:`int` to_port **)** Connect two data ports. The value of ``from_node``'s ``from_port`` would be fed into ``to_node``'s ``to_port``. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_data_disconnect: .. rst-class:: classref-method void **data_disconnect** **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_port, :ref:`int` to_node, :ref:`int` to_port **)** Disconnect two data ports previously connected with :ref:`data_connect`. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_get_function_node_id: .. rst-class:: classref-method :ref:`int` **get_function_node_id** **(** :ref:`String` name **)** |const| Returns the id of a function's entry point node. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_get_function_scroll: .. rst-class:: classref-method :ref:`Vector2` **get_function_scroll** **(** :ref:`String` name **)** |const| Returns the position of the center of the screen for a given function. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_get_node: .. rst-class:: classref-method :ref:`VisualScriptNode` **get_node** **(** :ref:`String` func, :ref:`int` id **)** |const| Returns a node given its id and its function. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_get_node_position: .. rst-class:: classref-method :ref:`Vector2` **get_node_position** **(** :ref:`String` func, :ref:`int` id **)** |const| Returns a node's position in pixels. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_get_variable_default_value: .. rst-class:: classref-method :ref:`Variant` **get_variable_default_value** **(** :ref:`String` name **)** |const| Returns the default (initial) value of a variable. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_get_variable_export: .. rst-class:: classref-method :ref:`bool` **get_variable_export** **(** :ref:`String` name **)** |const| Returns whether a variable is exported. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_get_variable_info: .. rst-class:: classref-method :ref:`Dictionary` **get_variable_info** **(** :ref:`String` name **)** |const| Returns the information for a given variable as a dictionary. The information includes its name, type, hint and usage. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_has_custom_signal: .. rst-class:: classref-method :ref:`bool` **has_custom_signal** **(** :ref:`String` name **)** |const| Returns whether a signal exists with the specified name. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_has_data_connection: .. rst-class:: classref-method :ref:`bool` **has_data_connection** **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_port, :ref:`int` to_node, :ref:`int` to_port **)** |const| Returns whether the specified data ports are connected. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_has_function: .. rst-class:: classref-method :ref:`bool` **has_function** **(** :ref:`String` name **)** |const| Returns whether a function exists with the specified name. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_has_node: .. rst-class:: classref-method :ref:`bool` **has_node** **(** :ref:`String` func, :ref:`int` id **)** |const| Returns whether a node exists with the given id. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_has_sequence_connection: .. rst-class:: classref-method :ref:`bool` **has_sequence_connection** **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_output, :ref:`int` to_node **)** |const| Returns whether the specified sequence ports are connected. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_has_variable: .. rst-class:: classref-method :ref:`bool` **has_variable** **(** :ref:`String` name **)** |const| Returns whether a variable exists with the specified name. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_remove_custom_signal: .. rst-class:: classref-method void **remove_custom_signal** **(** :ref:`String` name **)** Remove a custom signal with the given name. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_remove_function: .. rst-class:: classref-method void **remove_function** **(** :ref:`String` name **)** Remove a specific function and its nodes from the script. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_remove_node: .. rst-class:: classref-method void **remove_node** **(** :ref:`String` func, :ref:`int` id **)** Remove a specific node. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_remove_variable: .. rst-class:: classref-method void **remove_variable** **(** :ref:`String` name **)** Remove a variable with the given name. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_rename_custom_signal: .. rst-class:: classref-method void **rename_custom_signal** **(** :ref:`String` name, :ref:`String` new_name **)** Change the name of a custom signal. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_rename_function: .. rst-class:: classref-method void **rename_function** **(** :ref:`String` name, :ref:`String` new_name **)** Change the name of a function. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_rename_variable: .. rst-class:: classref-method void **rename_variable** **(** :ref:`String` name, :ref:`String` new_name **)** Change the name of a variable. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_sequence_connect: .. rst-class:: classref-method void **sequence_connect** **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_output, :ref:`int` to_node **)** Connect two sequence ports. The execution will flow from of ``from_node``'s ``from_output`` into ``to_node``. Unlike :ref:`data_connect`, there isn't a ``to_port``, since the target node can have only one sequence port. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_sequence_disconnect: .. rst-class:: classref-method void **sequence_disconnect** **(** :ref:`String` func, :ref:`int` from_node, :ref:`int` from_output, :ref:`int` to_node **)** Disconnect two sequence ports previously connected with :ref:`sequence_connect`. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_set_function_scroll: .. rst-class:: classref-method void **set_function_scroll** **(** :ref:`String` name, :ref:`Vector2` ofs **)** Position the center of the screen for a function. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_set_instance_base_type: .. rst-class:: classref-method void **set_instance_base_type** **(** :ref:`String` type **)** Set the base type of the script. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_set_node_position: .. rst-class:: classref-method void **set_node_position** **(** :ref:`String` func, :ref:`int` id, :ref:`Vector2` position **)** Position a node on the screen. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_set_variable_default_value: .. rst-class:: classref-method void **set_variable_default_value** **(** :ref:`String` name, :ref:`Variant` value **)** Change the default (initial) value of a variable. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_set_variable_export: .. rst-class:: classref-method void **set_variable_export** **(** :ref:`String` name, :ref:`bool` enable **)** Change whether a variable is exported. .. rst-class:: classref-item-separator ---- .. _class_VisualScript_method_set_variable_info: .. rst-class:: classref-method void **set_variable_info** **(** :ref:`String` name, :ref:`Dictionary` value **)** Set a variable's info, using the same format as :ref:`get_variable_info`. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)` .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)` .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)` .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`