2018-08-29 22:38:13 +02:00
/**************************************************************************/
/* visual_shader_editor_plugin.cpp */
/**************************************************************************/
/* This file is part of: */
/* GODOT ENGINE */
/* https://godotengine.org */
/**************************************************************************/
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
/* */
/* Permission is hereby granted, free of charge, to any person obtaining */
/* a copy of this software and associated documentation files (the */
/* "Software"), to deal in the Software without restriction, including */
/* without limitation the rights to use, copy, modify, merge, publish, */
/* distribute, sublicense, and/or sell copies of the Software, and to */
/* permit persons to whom the Software is furnished to do so, subject to */
/* the following conditions: */
/* */
/* The above copyright notice and this permission notice shall be */
/* included in all copies or substantial portions of the Software. */
/* */
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/**************************************************************************/
2018-07-14 23:15:42 +02:00
# include "visual_shader_editor_plugin.h"
2020-11-07 23:33:38 +01:00
# include "core/config/project_settings.h"
2018-07-14 23:15:42 +02:00
# include "core/io/resource_loader.h"
2019-05-19 15:27:00 +02:00
# include "core/math/math_defs.h"
2018-09-11 18:13:45 +02:00
# include "core/os/keyboard.h"
2022-02-12 02:46:22 +01:00
# include "editor/editor_node.h"
2018-07-14 23:15:42 +02:00
# include "editor/editor_properties.h"
2023-05-16 17:30:51 +02:00
# include "editor/editor_properties_vector.h"
2022-11-19 12:45:49 +01:00
# include "editor/editor_settings.h"
2023-08-13 02:33:39 +02:00
# include "editor/editor_string_names.h"
2022-03-25 18:06:46 +01:00
# include "editor/editor_undo_redo_manager.h"
2023-01-23 10:01:28 +01:00
# include "editor/filesystem_dock.h"
2022-11-19 12:45:49 +01:00
# include "editor/inspector_dock.h"
2022-08-01 20:01:48 +02:00
# include "editor/plugins/curve_editor_plugin.h"
2024-07-11 15:20:25 +02:00
# include "editor/plugins/material_editor_plugin.h"
2022-07-16 08:59:20 +02:00
# include "editor/plugins/shader_editor_plugin.h"
2024-01-15 13:14:55 +01:00
# include "editor/themes/editor_scale.h"
2024-05-07 16:48:03 +02:00
# include "scene/animation/tween.h"
2022-08-01 20:01:48 +02:00
# include "scene/gui/button.h"
2022-11-19 12:45:49 +01:00
# include "scene/gui/check_box.h"
2022-08-01 20:01:48 +02:00
# include "scene/gui/code_edit.h"
2024-02-07 02:37:26 +01:00
# include "scene/gui/color_picker.h"
2024-07-11 15:20:25 +02:00
# include "scene/gui/flow_container.h"
2022-08-01 20:01:48 +02:00
# include "scene/gui/graph_edit.h"
2018-07-14 23:15:42 +02:00
# include "scene/gui/menu_button.h"
2022-11-19 12:45:49 +01:00
# include "scene/gui/option_button.h"
2022-08-01 20:01:48 +02:00
# include "scene/gui/popup.h"
# include "scene/gui/rich_text_label.h"
2022-11-19 12:45:49 +01:00
# include "scene/gui/separator.h"
2024-07-11 15:20:25 +02:00
# include "scene/gui/split_container.h"
2022-08-01 20:01:48 +02:00
# include "scene/gui/tree.h"
2022-01-19 19:59:12 +01:00
# include "scene/gui/view_panner.h"
2020-03-04 02:51:12 +01:00
# include "scene/main/window.h"
2023-07-11 22:29:09 +02:00
# include "scene/resources/curve_texture.h"
2023-07-14 22:35:39 +02:00
# include "scene/resources/style_box_flat.h"
2019-02-22 18:38:58 +01:00
# include "scene/resources/visual_shader_nodes.h"
2020-09-15 09:57:40 +02:00
# include "scene/resources/visual_shader_particle_nodes.h"
2020-03-03 14:36:29 +01:00
# include "servers/display_server.h"
2023-09-23 21:25:47 +02:00
# include "servers/rendering/shader_preprocessor.h"
2020-03-27 19:21:27 +01:00
# include "servers/rendering/shader_types.h"
2018-07-14 23:15:42 +02:00
2020-10-01 10:10:51 +02:00
struct FloatConstantDef {
String name ;
2020-11-24 10:12:55 +01:00
float value = 0 ;
2020-10-01 10:10:51 +02:00
String desc ;
} ;
static FloatConstantDef float_constant_defs [ ] = {
{ " E " , Math_E , TTR ( " E constant (2.718282). Represents the base of the natural logarithm. " ) } ,
{ " Epsilon " , CMP_EPSILON , TTR ( " Epsilon constant (0.00001). Smallest possible scalar number. " ) } ,
{ " Phi " , 1.618034f , TTR ( " Phi constant (1.618034). Golden ratio. " ) } ,
{ " Pi/4 " , Math_PI / 4 , TTR ( " Pi/4 constant (0.785398) or 45 degrees. " ) } ,
{ " Pi/2 " , Math_PI / 2 , TTR ( " Pi/2 constant (1.570796) or 90 degrees. " ) } ,
{ " Pi " , Math_PI , TTR ( " Pi constant (3.141593) or 180 degrees. " ) } ,
{ " Tau " , Math_TAU , TTR ( " Tau constant (6.283185) or 360 degrees. " ) } ,
{ " Sqrt2 " , Math_SQRT2 , TTR ( " Sqrt2 constant (1.414214). Square root of 2. " ) }
} ;
const int MAX_FLOAT_CONST_DEFS = sizeof ( float_constant_defs ) / sizeof ( FloatConstantDef ) ;
///////////////////
2022-07-16 08:59:20 +02:00
void VisualShaderNodePlugin : : set_editor ( VisualShaderEditor * p_editor ) {
vseditor = p_editor ;
}
2019-08-05 16:13:02 +02:00
Control * VisualShaderNodePlugin : : create_editor ( const Ref < Resource > & p_parent_resource , const Ref < VisualShaderNode > & p_node ) {
2022-09-29 11:53:28 +02:00
Object * ret = nullptr ;
2022-10-18 18:47:44 +02:00
GDVIRTUAL_CALL ( _create_editor , p_parent_resource , p_node , ret ) ;
return Object : : cast_to < Control > ( ret ) ;
2018-07-14 23:15:42 +02:00
}
void VisualShaderNodePlugin : : _bind_methods ( ) {
2021-08-22 03:52:44 +02:00
GDVIRTUAL_BIND ( _create_editor , " parent_resource " , " visual_shader_node " ) ;
2018-07-14 23:15:42 +02:00
}
///////////////////
2024-05-07 16:48:03 +02:00
void VSGraphNode : : _draw_port ( int p_slot_index , Point2i p_pos , bool p_left , const Color & p_color , const Color & p_rim_color ) {
Ref < Texture2D > port_icon = p_left ? get_slot_custom_icon_left ( p_slot_index ) : get_slot_custom_icon_right ( p_slot_index ) ;
Point2 icon_offset ;
if ( ! port_icon . is_valid ( ) ) {
port_icon = get_theme_icon ( SNAME ( " port " ) , SNAME ( " GraphNode " ) ) ;
}
icon_offset = - port_icon - > get_size ( ) * 0.5 ;
// Draw "shadow"/outline in the connection rim color.
2024-08-17 11:31:05 +02:00
draw_texture_rect ( port_icon , Rect2 ( p_pos + ( icon_offset - Size2 ( 2 , 2 ) ) * EDSCALE , ( port_icon - > get_size ( ) + Size2 ( 4 , 4 ) ) * EDSCALE ) , false , p_rim_color ) ;
draw_texture_rect ( port_icon , Rect2 ( p_pos + icon_offset * EDSCALE , port_icon - > get_size ( ) * EDSCALE ) , false , p_color ) ;
2024-05-07 16:48:03 +02:00
}
void VSGraphNode : : draw_port ( int p_slot_index , Point2i p_pos , bool p_left , const Color & p_color ) {
Color rim_color = get_theme_color ( SNAME ( " connection_rim_color " ) , SNAME ( " GraphEdit " ) ) ;
_draw_port ( p_slot_index , p_pos , p_left , p_color , rim_color ) ;
}
///////////////////
void VSRerouteNode : : _notification ( int p_what ) {
switch ( p_what ) {
case NOTIFICATION_READY : {
2024-05-13 16:56:03 +02:00
connect ( SceneStringName ( mouse_entered ) , callable_mp ( this , & VSRerouteNode : : _on_mouse_entered ) ) ;
connect ( SceneStringName ( mouse_exited ) , callable_mp ( this , & VSRerouteNode : : _on_mouse_exited ) ) ;
2024-05-07 16:48:03 +02:00
} break ;
case NOTIFICATION_DRAW : {
2024-07-03 18:27:14 +02:00
Vector2 offset = Vector2 ( 0 , - 16 * EDSCALE ) ;
2024-05-07 16:48:03 +02:00
Color drag_bg_color = get_theme_color ( SNAME ( " drag_background " ) , SNAME ( " VSRerouteNode " ) ) ;
2024-07-03 18:27:14 +02:00
draw_circle ( get_size ( ) * 0.5 + offset , 16 * EDSCALE , Color ( drag_bg_color , selected ? 1 : icon_opacity ) , true , - 1 , true ) ;
2024-05-07 16:48:03 +02:00
2024-05-13 16:56:03 +02:00
Ref < Texture2D > icon = get_editor_theme_icon ( SNAME ( " ToolMove " ) ) ;
2024-05-07 16:48:03 +02:00
Point2 icon_offset = - icon - > get_size ( ) * 0.5 + get_size ( ) * 0.5 + offset ;
draw_texture ( icon , icon_offset , Color ( 1 , 1 , 1 , selected ? 1 : icon_opacity ) ) ;
} break ;
}
}
void VSRerouteNode : : draw_port ( int p_slot_index , Point2i p_pos , bool p_left , const Color & p_color ) {
Color rim_color = selected ? get_theme_color ( " selected_rim_color " , " VSRerouteNode " ) : get_theme_color ( " connection_rim_color " , " GraphEdit " ) ;
_draw_port ( p_slot_index , p_pos , p_left , p_color , rim_color ) ;
}
VSRerouteNode : : VSRerouteNode ( ) {
Label * title_lbl = Object : : cast_to < Label > ( get_titlebar_hbox ( ) - > get_child ( 0 ) ) ;
title_lbl - > hide ( ) ;
const Size2 size = Size2 ( 32 , 32 ) * EDSCALE ;
Control * slot_area = memnew ( Control ) ;
slot_area - > set_custom_minimum_size ( size ) ;
slot_area - > set_mouse_filter ( Control : : MOUSE_FILTER_IGNORE ) ;
add_child ( slot_area ) ;
// Lay the input and output ports on top of each other to create the illusion of a single port.
add_theme_constant_override ( " port_h_offset " , size . width / 2 ) ;
}
void VSRerouteNode : : set_icon_opacity ( float p_opacity ) {
icon_opacity = p_opacity ;
queue_redraw ( ) ;
}
void VSRerouteNode : : _on_mouse_entered ( ) {
Ref < Tween > tween = create_tween ( ) ;
tween - > tween_method ( callable_mp ( this , & VSRerouteNode : : set_icon_opacity ) , 0.0 , 1.0 , FADE_ANIMATION_LENGTH_SEC ) ;
}
void VSRerouteNode : : _on_mouse_exited ( ) {
Ref < Tween > tween = create_tween ( ) ;
tween - > tween_method ( callable_mp ( this , & VSRerouteNode : : set_icon_opacity ) , 1.0 , 0.0 , FADE_ANIMATION_LENGTH_SEC ) ;
}
///////////////////
2020-09-09 16:40:27 +02:00
VisualShaderGraphPlugin : : VisualShaderGraphPlugin ( ) {
2024-02-09 15:02:58 +01:00
vs_msdf_fonts_theme . instantiate ( ) ;
2020-09-09 16:40:27 +02:00
}
void VisualShaderGraphPlugin : : _bind_methods ( ) {
2020-09-10 07:31:07 +02:00
ClassDB : : bind_method ( " add_node " , & VisualShaderGraphPlugin : : add_node ) ;
ClassDB : : bind_method ( " remove_node " , & VisualShaderGraphPlugin : : remove_node ) ;
ClassDB : : bind_method ( " connect_nodes " , & VisualShaderGraphPlugin : : connect_nodes ) ;
ClassDB : : bind_method ( " disconnect_nodes " , & VisualShaderGraphPlugin : : disconnect_nodes ) ;
ClassDB : : bind_method ( " set_node_position " , & VisualShaderGraphPlugin : : set_node_position ) ;
2020-09-21 13:32:59 +02:00
ClassDB : : bind_method ( " update_node " , & VisualShaderGraphPlugin : : update_node ) ;
ClassDB : : bind_method ( " update_node_deferred " , & VisualShaderGraphPlugin : : update_node_deferred ) ;
2020-09-10 07:31:07 +02:00
ClassDB : : bind_method ( " set_input_port_default_value " , & VisualShaderGraphPlugin : : set_input_port_default_value ) ;
2022-08-27 11:22:43 +02:00
ClassDB : : bind_method ( " set_parameter_name " , & VisualShaderGraphPlugin : : set_parameter_name ) ;
2020-10-15 13:47:27 +02:00
ClassDB : : bind_method ( " set_expression " , & VisualShaderGraphPlugin : : set_expression ) ;
2020-10-04 11:11:58 +02:00
ClassDB : : bind_method ( " update_curve " , & VisualShaderGraphPlugin : : update_curve ) ;
2021-07-14 00:06:44 +02:00
ClassDB : : bind_method ( " update_curve_xyz " , & VisualShaderGraphPlugin : : update_curve_xyz ) ;
2024-02-07 02:37:26 +01:00
ClassDB : : bind_method ( D_METHOD ( " attach_node_to_frame " , " type " , " id " , " frame " ) , & VisualShaderGraphPlugin : : attach_node_to_frame ) ;
ClassDB : : bind_method ( D_METHOD ( " detach_node_from_frame " , " type " , " id " ) , & VisualShaderGraphPlugin : : detach_node_from_frame ) ;
ClassDB : : bind_method ( D_METHOD ( " set_frame_color_enabled " , " type " , " id " , " enabled " ) , & VisualShaderGraphPlugin : : set_frame_color_enabled ) ;
ClassDB : : bind_method ( D_METHOD ( " set_frame_color " , " type " , " id " , " color " ) , & VisualShaderGraphPlugin : : set_frame_color ) ;
ClassDB : : bind_method ( D_METHOD ( " set_frame_autoshrink_enabled " , " type " , " id " , " enabled " ) , & VisualShaderGraphPlugin : : set_frame_autoshrink_enabled ) ;
2020-09-09 16:40:27 +02:00
}
2022-07-16 08:59:20 +02:00
void VisualShaderGraphPlugin : : set_editor ( VisualShaderEditor * p_editor ) {
editor = p_editor ;
}
2020-09-09 16:40:27 +02:00
void VisualShaderGraphPlugin : : register_shader ( VisualShader * p_shader ) {
visual_shader = Ref < VisualShader > ( p_shader ) ;
}
2022-04-07 12:23:40 +02:00
void VisualShaderGraphPlugin : : set_connections ( const List < VisualShader : : Connection > & p_connections ) {
2020-09-10 07:31:07 +02:00
connections = p_connections ;
}
2023-02-03 13:09:51 +01:00
void VisualShaderGraphPlugin : : show_port_preview ( VisualShader : : Type p_type , int p_node_id , int p_port_id , bool p_is_valid ) {
2020-12-01 09:48:07 +01:00
if ( visual_shader - > get_shader_type ( ) = = p_type & & links . has ( p_node_id ) & & links [ p_node_id ] . output_ports . has ( p_port_id ) ) {
2023-01-14 11:05:49 +01:00
Link & link = links [ p_node_id ] ;
for ( const KeyValue < int , Port > & E : link . output_ports ) {
2021-08-09 22:13:42 +02:00
if ( E . value . preview_button ! = nullptr ) {
E . value . preview_button - > set_pressed ( false ) ;
2020-12-01 09:48:07 +01:00
}
2020-09-09 16:40:27 +02:00
}
2023-01-14 11:05:49 +01:00
bool is_dirty = link . preview_pos < 0 ;
if ( ! is_dirty & & link . preview_visible & & link . preview_box ! = nullptr ) {
2023-08-09 18:31:15 +02:00
link . graph_element - > remove_child ( link . preview_box ) ;
2023-01-14 11:05:49 +01:00
memdelete ( link . preview_box ) ;
link . preview_box = nullptr ;
2023-08-09 18:31:15 +02:00
link . graph_element - > reset_size ( ) ;
2023-01-14 11:05:49 +01:00
link . preview_visible = false ;
2020-09-09 16:40:27 +02:00
}
2023-01-14 11:05:49 +01:00
if ( p_port_id ! = - 1 & & link . output_ports [ p_port_id ] . preview_button ! = nullptr ) {
if ( is_dirty ) {
2023-08-09 18:31:15 +02:00
link . preview_pos = link . graph_element - > get_child_count ( ) ;
2020-09-09 16:40:27 +02:00
}
VBoxContainer * vbox = memnew ( VBoxContainer ) ;
2023-08-09 18:31:15 +02:00
link . graph_element - > add_child ( vbox ) ;
link . graph_element - > move_child ( vbox , link . preview_pos ) ;
GraphNode * graph_node = Object : : cast_to < GraphNode > ( link . graph_element ) ;
if ( graph_node ) {
graph_node - > set_slot_draw_stylebox ( vbox - > get_index ( false ) , false ) ;
}
2020-09-09 16:40:27 +02:00
Control * offset = memnew ( Control ) ;
offset - > set_custom_minimum_size ( Size2 ( 0 , 5 * EDSCALE ) ) ;
vbox - > add_child ( offset ) ;
VisualShaderNodePortPreview * port_preview = memnew ( VisualShaderNodePortPreview ) ;
2024-07-11 15:20:25 +02:00
port_preview - > setup ( visual_shader , editor - > preview_material , visual_shader - > get_shader_type ( ) , p_node_id , p_port_id , p_is_valid ) ;
2020-09-09 16:40:27 +02:00
port_preview - > set_h_size_flags ( Control : : SIZE_SHRINK_CENTER ) ;
vbox - > add_child ( port_preview ) ;
2023-01-14 11:05:49 +01:00
link . preview_visible = true ;
link . preview_box = vbox ;
link . output_ports [ p_port_id ] . preview_button - > set_pressed ( true ) ;
2020-09-09 16:40:27 +02:00
}
}
}
2020-09-21 13:32:59 +02:00
void VisualShaderGraphPlugin : : update_node_deferred ( VisualShader : : Type p_type , int p_node_id ) {
2023-12-18 15:46:56 +01:00
callable_mp ( this , & VisualShaderGraphPlugin : : update_node ) . call_deferred ( p_type , p_node_id ) ;
2020-09-10 07:31:07 +02:00
}
2020-09-21 13:32:59 +02:00
void VisualShaderGraphPlugin : : update_node ( VisualShader : : Type p_type , int p_node_id ) {
2020-09-10 07:31:07 +02:00
if ( p_type ! = visual_shader - > get_shader_type ( ) | | ! links . has ( p_node_id ) ) {
return ;
}
2023-01-12 12:19:55 +01:00
remove_node ( p_type , p_node_id , true ) ;
2024-02-07 02:37:26 +01:00
add_node ( p_type , p_node_id , true , true ) ;
// TODO: Restore focus here?
2020-09-10 07:31:07 +02:00
}
2024-02-15 17:25:58 +01:00
void VisualShaderGraphPlugin : : set_input_port_default_value ( VisualShader : : Type p_type , int p_node_id , int p_port_id , const Variant & p_value ) {
2020-09-10 07:31:07 +02:00
if ( p_type ! = visual_shader - > get_shader_type ( ) | | ! links . has ( p_node_id ) ) {
return ;
}
Button * button = links [ p_node_id ] . input_ports [ p_port_id ] . default_input_button ;
switch ( p_value . get_type ( ) ) {
case Variant : : COLOR : {
button - > set_custom_minimum_size ( Size2 ( 30 , 0 ) * EDSCALE ) ;
2022-01-07 08:59:15 +01:00
Callable ce = callable_mp ( editor , & VisualShaderEditor : : _draw_color_over_button ) ;
2024-05-13 16:56:03 +02:00
if ( ! button - > is_connected ( SceneStringName ( draw ) , ce ) ) {
button - > connect ( SceneStringName ( draw ) , ce . bind ( button , p_value ) ) ;
2020-09-10 07:31:07 +02:00
}
} break ;
case Variant : : BOOL : {
button - > set_text ( ( ( bool ) p_value ) ? " true " : " false " ) ;
} break ;
case Variant : : INT :
case Variant : : FLOAT : {
button - > set_text ( String : : num ( p_value , 4 ) ) ;
} break ;
2022-02-01 09:32:01 +01:00
case Variant : : VECTOR2 : {
Vector2 v = p_value ;
button - > set_text ( String : : num ( v . x , 3 ) + " , " + String : : num ( v . y , 3 ) ) ;
} break ;
2020-09-10 07:31:07 +02:00
case Variant : : VECTOR3 : {
Vector3 v = p_value ;
button - > set_text ( String : : num ( v . x , 3 ) + " , " + String : : num ( v . y , 3 ) + " , " + String : : num ( v . z , 3 ) ) ;
} break ;
2022-04-12 19:09:29 +02:00
case Variant : : QUATERNION : {
Quaternion v = p_value ;
button - > set_text ( String : : num ( v . x , 3 ) + " , " + String : : num ( v . y , 3 ) + " , " + String : : num ( v . z , 3 ) + " , " + String : : num ( v . w , 3 ) ) ;
} break ;
2020-09-10 07:31:07 +02:00
default : {
}
}
}
2022-08-27 11:22:43 +02:00
void VisualShaderGraphPlugin : : set_parameter_name ( VisualShader : : Type p_type , int p_node_id , const String & p_name ) {
if ( visual_shader - > get_shader_type ( ) = = p_type & & links . has ( p_node_id ) & & links [ p_node_id ] . parameter_name ! = nullptr ) {
links [ p_node_id ] . parameter_name - > set_text ( p_name ) ;
2020-09-21 13:32:59 +02:00
}
}
2020-10-04 11:11:58 +02:00
void VisualShaderGraphPlugin : : update_curve ( int p_node_id ) {
2021-07-04 10:56:21 +02:00
if ( links . has ( p_node_id ) & & links [ p_node_id ] . curve_editors [ 0 ] ) {
2021-10-22 16:31:52 +02:00
Ref < VisualShaderNodeCurveTexture > tex = Object : : cast_to < VisualShaderNodeCurveTexture > ( links [ p_node_id ] . visual_node ) ;
ERR_FAIL_COND ( ! tex . is_valid ( ) ) ;
if ( tex - > get_texture ( ) . is_valid ( ) ) {
links [ p_node_id ] . curve_editors [ 0 ] - > set_curve ( tex - > get_texture ( ) - > get_curve ( ) ) ;
2021-07-04 10:56:21 +02:00
}
2023-07-03 21:29:37 +02:00
tex - > emit_changed ( ) ;
2021-07-04 10:56:21 +02:00
}
}
2021-07-14 00:06:44 +02:00
void VisualShaderGraphPlugin : : update_curve_xyz ( int p_node_id ) {
2021-07-04 10:56:21 +02:00
if ( links . has ( p_node_id ) & & links [ p_node_id ] . curve_editors [ 0 ] & & links [ p_node_id ] . curve_editors [ 1 ] & & links [ p_node_id ] . curve_editors [ 2 ] ) {
2021-10-22 16:31:52 +02:00
Ref < VisualShaderNodeCurveXYZTexture > tex = Object : : cast_to < VisualShaderNodeCurveXYZTexture > ( links [ p_node_id ] . visual_node ) ;
ERR_FAIL_COND ( ! tex . is_valid ( ) ) ;
if ( tex - > get_texture ( ) . is_valid ( ) ) {
links [ p_node_id ] . curve_editors [ 0 ] - > set_curve ( tex - > get_texture ( ) - > get_curve_x ( ) ) ;
links [ p_node_id ] . curve_editors [ 1 ] - > set_curve ( tex - > get_texture ( ) - > get_curve_y ( ) ) ;
links [ p_node_id ] . curve_editors [ 2 ] - > set_curve ( tex - > get_texture ( ) - > get_curve_z ( ) ) ;
2020-10-04 11:11:58 +02:00
}
2023-07-03 21:29:37 +02:00
tex - > emit_changed ( ) ;
2020-10-04 11:11:58 +02:00
}
}
2020-10-01 10:10:51 +02:00
int VisualShaderGraphPlugin : : get_constant_index ( float p_constant ) const {
for ( int i = 0 ; i < MAX_FLOAT_CONST_DEFS ; i + + ) {
if ( Math : : is_equal_approx ( p_constant , float_constant_defs [ i ] . value ) ) {
return i + 1 ;
}
}
return 0 ;
}
2020-10-15 13:47:27 +02:00
void VisualShaderGraphPlugin : : set_expression ( VisualShader : : Type p_type , int p_node_id , const String & p_expression ) {
if ( p_type ! = visual_shader - > get_shader_type ( ) | | ! links . has ( p_node_id ) | | ! links [ p_node_id ] . expression_edit ) {
return ;
}
links [ p_node_id ] . expression_edit - > set_text ( p_expression ) ;
}
2024-02-07 02:37:26 +01:00
void VisualShaderGraphPlugin : : attach_node_to_frame ( VisualShader : : Type p_type , int p_node_id , int p_frame_id ) {
if ( p_type ! = visual_shader - > get_shader_type ( ) | | ! links . has ( p_node_id ) | | ! links . has ( p_frame_id ) ) {
return ;
}
GraphEdit * graph = editor - > graph ;
if ( ! graph ) {
return ;
}
// Get the hint label and hide it before attaching the node to prevent resizing issues with the frame.
GraphFrame * frame = Object : : cast_to < GraphFrame > ( links [ p_frame_id ] . graph_element ) ;
ERR_FAIL_COND_MSG ( ! frame , " VisualShader node to attach to is not a frame node. " ) ;
Label * frame_hint_label = Object : : cast_to < Label > ( frame - > get_child ( 0 , false ) ) ;
if ( frame_hint_label ) {
frame_hint_label - > hide ( ) ;
}
graph - > attach_graph_element_to_frame ( itos ( p_node_id ) , itos ( p_frame_id ) ) ;
}
void VisualShaderGraphPlugin : : detach_node_from_frame ( VisualShader : : Type p_type , int p_node_id ) {
GraphEdit * graph = editor - > graph ;
if ( ! graph ) {
return ;
}
const StringName node_name = itos ( p_node_id ) ;
GraphFrame * frame = graph - > get_element_frame ( node_name ) ;
if ( ! frame ) {
return ;
}
graph - > detach_graph_element_from_frame ( node_name ) ;
bool no_more_frames_attached = graph - > get_attached_nodes_of_frame ( frame - > get_name ( ) ) . is_empty ( ) ;
if ( no_more_frames_attached ) {
// Get the hint label and show it.
Label * frame_hint_label = Object : : cast_to < Label > ( frame - > get_child ( 0 , false ) ) ;
ERR_FAIL_COND_MSG ( ! frame_hint_label , " Frame node does not have a hint label. " ) ;
frame_hint_label - > show ( ) ;
}
}
void VisualShaderGraphPlugin : : set_frame_color_enabled ( VisualShader : : Type p_type , int p_node_id , bool p_enable ) {
GraphEdit * graph = editor - > graph ;
ERR_FAIL_COND ( ! graph ) ;
const NodePath node_name = itos ( p_node_id ) ;
GraphFrame * frame = Object : : cast_to < GraphFrame > ( graph - > get_node_or_null ( node_name ) ) ;
if ( ! frame ) {
return ;
}
frame - > set_tint_color_enabled ( p_enable ) ;
}
void VisualShaderGraphPlugin : : set_frame_color ( VisualShader : : Type p_type , int p_node_id , const Color & p_color ) {
GraphEdit * graph = editor - > graph ;
ERR_FAIL_COND ( ! graph ) ;
const NodePath node_name = itos ( p_node_id ) ;
GraphFrame * frame = Object : : cast_to < GraphFrame > ( graph - > get_node_or_null ( node_name ) ) ;
if ( ! frame ) {
return ;
}
frame - > set_tint_color ( p_color ) ;
}
void VisualShaderGraphPlugin : : set_frame_autoshrink_enabled ( VisualShader : : Type p_type , int p_node_id , bool p_enable ) {
GraphEdit * graph = editor - > graph ;
ERR_FAIL_COND ( ! graph ) ;
const NodePath node_name = itos ( p_node_id ) ;
GraphFrame * frame = Object : : cast_to < GraphFrame > ( graph - > get_node_or_null ( node_name ) ) ;
if ( ! frame ) {
return ;
}
frame - > set_autoshrink_enabled ( p_enable ) ;
}
2024-05-07 16:48:03 +02:00
void VisualShaderGraphPlugin : : update_reroute_nodes ( ) {
for ( const KeyValue < int , Link > & E : links ) {
Ref < VisualShaderNodeReroute > reroute_node = Object : : cast_to < VisualShaderNodeReroute > ( E . value . visual_node ) ;
if ( reroute_node . is_valid ( ) ) {
update_node ( visual_shader - > get_shader_type ( ) , E . key ) ;
}
}
}
2022-12-07 19:50:28 +01:00
Ref < Script > VisualShaderGraphPlugin : : get_node_script ( int p_node_id ) const {
if ( ! links . has ( p_node_id ) ) {
return Ref < Script > ( ) ;
}
Ref < VisualShaderNodeCustom > custom = Ref < VisualShaderNodeCustom > ( links [ p_node_id ] . visual_node ) ;
if ( custom . is_valid ( ) ) {
return custom - > get_script ( ) ;
}
return Ref < Script > ( ) ;
}
2020-09-10 07:31:07 +02:00
void VisualShaderGraphPlugin : : register_default_input_button ( int p_node_id , int p_port_id , Button * p_button ) {
links [ p_node_id ] . input_ports . insert ( p_port_id , { p_button } ) ;
}
2020-10-15 13:47:27 +02:00
void VisualShaderGraphPlugin : : register_expression_edit ( int p_node_id , CodeEdit * p_expression_edit ) {
links [ p_node_id ] . expression_edit = p_expression_edit ;
}
2021-07-04 10:56:21 +02:00
void VisualShaderGraphPlugin : : register_curve_editor ( int p_node_id , int p_index , CurveEditor * p_curve_editor ) {
links [ p_node_id ] . curve_editors [ p_index ] = p_curve_editor ;
2020-10-04 11:11:58 +02:00
}
2022-08-27 11:22:43 +02:00
void VisualShaderGraphPlugin : : update_parameter_refs ( ) {
2021-08-09 22:13:42 +02:00
for ( KeyValue < int , Link > & E : links ) {
2022-08-27 11:22:43 +02:00
VisualShaderNodeParameterRef * ref = Object : : cast_to < VisualShaderNodeParameterRef > ( E . value . visual_node ) ;
2020-09-21 13:32:59 +02:00
if ( ref ) {
2023-01-12 12:19:55 +01:00
remove_node ( E . value . type , E . key , true ) ;
2024-02-07 02:37:26 +01:00
add_node ( E . value . type , E . key , true , true ) ;
2020-09-21 13:32:59 +02:00
}
}
}
2020-09-10 07:31:07 +02:00
VisualShader : : Type VisualShaderGraphPlugin : : get_shader_type ( ) const {
return visual_shader - > get_shader_type ( ) ;
}
2024-02-07 02:37:26 +01:00
// Only updates the linked frames of the given node, not the node itself (in case it's a frame node).
void VisualShaderGraphPlugin : : update_frames ( VisualShader : : Type p_type , int p_node ) {
GraphEdit * graph = editor - > graph ;
if ( ! graph ) {
return ;
}
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( p_type , p_node ) ;
if ( ! vsnode . is_valid ( ) ) {
WARN_PRINT ( " Update linked frames: Node not found. " ) ;
return ;
}
int frame_vsnode_id = vsnode - > get_frame ( ) ;
if ( frame_vsnode_id = = - 1 ) {
return ;
}
Ref < VisualShaderNodeFrame > frame_node = visual_shader - > get_node ( p_type , frame_vsnode_id ) ;
if ( ! frame_node . is_valid ( ) | | ! links . has ( frame_vsnode_id ) ) {
return ;
}
GraphFrame * frame = Object : : cast_to < GraphFrame > ( links [ frame_vsnode_id ] . graph_element ) ;
if ( ! frame ) {
return ;
}
// Update the frame node recursively.
editor - > graph - > _update_graph_frame ( frame ) ;
}
2020-09-10 07:31:07 +02:00
void VisualShaderGraphPlugin : : set_node_position ( VisualShader : : Type p_type , int p_id , const Vector2 & p_position ) {
if ( visual_shader - > get_shader_type ( ) = = p_type & & links . has ( p_id ) ) {
2023-08-09 18:31:15 +02:00
links [ p_id ] . graph_element - > set_position_offset ( p_position ) ;
2020-09-10 07:31:07 +02:00
}
}
2020-09-09 16:40:27 +02:00
bool VisualShaderGraphPlugin : : is_preview_visible ( int p_id ) const {
return links [ p_id ] . preview_visible ;
}
void VisualShaderGraphPlugin : : clear_links ( ) {
links . clear ( ) ;
}
2023-08-09 18:31:15 +02:00
void VisualShaderGraphPlugin : : register_link ( VisualShader : : Type p_type , int p_id , VisualShaderNode * p_visual_node , GraphElement * p_graph_element ) {
links . insert ( p_id , { p_type , p_visual_node , p_graph_element , p_visual_node - > get_output_port_for_preview ( ) ! = - 1 , - 1 , HashMap < int , InputPort > ( ) , HashMap < int , Port > ( ) , nullptr , nullptr , nullptr , { nullptr , nullptr , nullptr } } ) ;
2020-09-09 16:40:27 +02:00
}
void VisualShaderGraphPlugin : : register_output_port ( int p_node_id , int p_port , TextureButton * p_button ) {
links [ p_node_id ] . output_ports . insert ( p_port , { p_button } ) ;
}
2022-08-27 11:22:43 +02:00
void VisualShaderGraphPlugin : : register_parameter_name ( int p_node_id , LineEdit * p_parameter_name ) {
links [ p_node_id ] . parameter_name = p_parameter_name ;
2020-09-21 13:32:59 +02:00
}
2020-12-20 16:45:53 +01:00
void VisualShaderGraphPlugin : : update_theme ( ) {
2023-08-13 02:33:39 +02:00
vector_expanded_color [ 0 ] = editor - > get_theme_color ( SNAME ( " axis_x_color " ) , EditorStringName ( Editor ) ) ; // red
vector_expanded_color [ 1 ] = editor - > get_theme_color ( SNAME ( " axis_y_color " ) , EditorStringName ( Editor ) ) ; // green
vector_expanded_color [ 2 ] = editor - > get_theme_color ( SNAME ( " axis_z_color " ) , EditorStringName ( Editor ) ) ; // blue
vector_expanded_color [ 3 ] = editor - > get_theme_color ( SNAME ( " axis_w_color " ) , EditorStringName ( Editor ) ) ; // alpha
2024-02-09 15:02:58 +01:00
Ref < Font > label_font = EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_font ( " main_msdf " , EditorStringName ( EditorFonts ) ) ;
Ref < Font > label_bold_font = EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_font ( " main_bold_msdf " , EditorStringName ( EditorFonts ) ) ;
2024-05-14 15:57:29 +02:00
vs_msdf_fonts_theme - > set_font ( SceneStringName ( font ) , " Label " , label_font ) ;
vs_msdf_fonts_theme - > set_font ( SceneStringName ( font ) , " GraphNodeTitleLabel " , label_bold_font ) ;
vs_msdf_fonts_theme - > set_font ( SceneStringName ( font ) , " LineEdit " , label_font ) ;
vs_msdf_fonts_theme - > set_font ( SceneStringName ( font ) , " Button " , label_font ) ;
2020-12-20 16:45:53 +01:00
}
2023-02-03 13:09:51 +01:00
bool VisualShaderGraphPlugin : : is_node_has_parameter_instances_relatively ( VisualShader : : Type p_type , int p_node ) const {
bool result = false ;
Ref < VisualShaderNodeParameter > parameter_node = Object : : cast_to < VisualShaderNodeParameter > ( visual_shader - > get_node_unchecked ( p_type , p_node ) . ptr ( ) ) ;
if ( parameter_node . is_valid ( ) ) {
if ( parameter_node - > get_qualifier ( ) = = VisualShaderNodeParameter : : QUAL_INSTANCE ) {
return true ;
}
}
2023-05-06 20:16:55 +02:00
const LocalVector < int > & prev_connected_nodes = visual_shader - > get_prev_connected_nodes ( p_type , p_node ) ;
2023-02-03 13:09:51 +01:00
for ( const int & E : prev_connected_nodes ) {
result = is_node_has_parameter_instances_relatively ( p_type , E ) ;
if ( result ) {
break ;
}
}
return result ;
}
2024-02-07 02:37:26 +01:00
void VisualShaderGraphPlugin : : add_node ( VisualShader : : Type p_type , int p_id , bool p_just_update , bool p_update_frames ) {
2022-01-07 08:59:15 +01:00
if ( ! visual_shader . is_valid ( ) | | p_type ! = visual_shader - > get_shader_type ( ) ) {
return ;
}
GraphEdit * graph = editor - > graph ;
if ( ! graph ) {
return ;
}
VisualShaderGraphPlugin * graph_plugin = editor - > get_graph_plugin ( ) ;
if ( ! graph_plugin ) {
2020-09-10 07:31:07 +02:00
return ;
}
2022-01-22 09:09:16 +01:00
Shader : : Mode mode = visual_shader - > get_mode ( ) ;
2020-09-10 07:31:07 +02:00
Control * offset ;
2024-02-09 15:02:58 +01:00
const Color type_color [ ] = {
EDITOR_GET ( " editors/visual_editors/connection_colors/scalar_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/scalar_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/scalar_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/vector2_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/vector3_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/vector4_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/boolean_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/transform_color " ) ,
EDITOR_GET ( " editors/visual_editors/connection_colors/sampler_color " ) ,
2020-09-10 07:31:07 +02:00
} ;
2024-02-09 15:02:58 +01:00
// Keep in sync with VisualShaderNode::Category.
const Color category_color [ VisualShaderNode : : Category : : CATEGORY_MAX ] = {
Color ( 0.0 , 0.0 , 0.0 ) , // None (default, not used)
EDITOR_GET ( " editors/visual_editors/category_colors/output_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/color_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/conditional_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/input_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/scalar_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/textures_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/transform_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/utility_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/vector_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/special_color " ) ,
EDITOR_GET ( " editors/visual_editors/category_colors/particle_color " ) ,
2020-12-20 16:45:53 +01:00
} ;
2024-02-09 15:02:58 +01:00
static const String vector_expanded_name [ 4 ] = { " red " , " green " , " blue " , " alpha " } ;
2022-04-30 03:56:57 +02:00
2020-09-10 07:31:07 +02:00
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( p_type , p_id ) ;
2024-02-07 02:37:26 +01:00
ERR_FAIL_COND ( vsnode . is_null ( ) ) ;
2020-09-10 07:31:07 +02:00
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNodeResizableBase > resizable_node = vsnode ;
bool is_resizable = resizable_node . is_valid ( ) ;
2020-10-04 11:11:58 +02:00
Size2 size = Size2 ( 0 , 0 ) ;
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNodeGroupBase > group_node = vsnode ;
bool is_group = group_node . is_valid ( ) ;
2020-09-10 07:31:07 +02:00
2024-02-07 02:37:26 +01:00
Ref < VisualShaderNodeFrame > frame_node = vsnode ;
bool is_frame = frame_node . is_valid ( ) ;
2021-05-19 10:57:11 +02:00
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNodeExpression > expression_node = group_node ;
bool is_expression = expression_node . is_valid ( ) ;
2020-09-10 07:31:07 +02:00
String expression = " " ;
2024-05-07 16:48:03 +02:00
Ref < VisualShaderNodeReroute > reroute_node = vsnode ;
bool is_reroute = reroute_node . is_valid ( ) ;
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNodeCustom > custom_node = vsnode ;
if ( custom_node . is_valid ( ) ) {
2021-04-12 12:47:37 +02:00
custom_node - > _set_initialized ( true ) ;
}
2024-02-07 02:37:26 +01:00
GraphElement * node ;
if ( is_frame ) {
GraphFrame * frame = memnew ( GraphFrame ) ;
frame - > set_title ( vsnode - > get_caption ( ) ) ;
node = frame ;
2024-05-07 16:48:03 +02:00
} else if ( is_reroute ) {
VSRerouteNode * reroute_gnode = memnew ( VSRerouteNode ) ;
reroute_gnode - > set_ignore_invalid_connection_type ( true ) ;
node = reroute_gnode ;
2024-02-07 02:37:26 +01:00
} else {
2024-05-07 16:48:03 +02:00
VSGraphNode * gnode = memnew ( VSGraphNode ) ;
2024-02-07 02:37:26 +01:00
gnode - > set_title ( vsnode - > get_caption ( ) ) ;
node = gnode ;
}
node - > set_name ( itos ( p_id ) ) ;
2023-08-09 18:31:15 +02:00
// All nodes are closable except the output node.
if ( p_id > = 2 ) {
2024-02-07 02:37:26 +01:00
vsnode - > set_deletable ( true ) ;
2023-09-26 16:41:39 +02:00
node - > connect ( " delete_request " , callable_mp ( editor , & VisualShaderEditor : : _delete_node_request ) . bind ( p_type , p_id ) , CONNECT_DEFERRED ) ;
2023-08-09 18:31:15 +02:00
}
2022-01-07 08:59:15 +01:00
graph - > add_child ( node ) ;
2024-02-09 15:02:58 +01:00
node - > set_theme ( vs_msdf_fonts_theme ) ;
// Set the node's titlebar color based on its category.
2024-05-07 16:48:03 +02:00
if ( vsnode - > get_category ( ) ! = VisualShaderNode : : CATEGORY_NONE & & ! is_frame & & ! is_reroute ) {
2024-02-09 15:02:58 +01:00
Ref < StyleBoxFlat > sb_colored = editor - > get_theme_stylebox ( " titlebar " , " GraphNode " ) - > duplicate ( ) ;
sb_colored - > set_bg_color ( category_color [ vsnode - > get_category ( ) ] ) ;
node - > add_theme_style_override ( " titlebar " , sb_colored ) ;
Ref < StyleBoxFlat > sb_colored_selected = editor - > get_theme_stylebox ( " titlebar_selected " , " GraphNode " ) - > duplicate ( ) ;
sb_colored_selected - > set_bg_color ( category_color [ vsnode - > get_category ( ) ] . lightened ( 0.2 ) ) ;
node - > add_theme_style_override ( " titlebar_selected " , sb_colored_selected ) ;
}
2023-01-12 12:19:55 +01:00
if ( p_just_update ) {
2023-01-14 11:05:49 +01:00
Link & link = links [ p_id ] ;
2024-03-08 19:28:05 +01:00
link . visual_node = vsnode . ptr ( ) ;
2023-08-09 18:31:15 +02:00
link . graph_element = node ;
2023-01-14 11:05:49 +01:00
link . preview_box = nullptr ;
link . preview_pos = - 1 ;
link . output_ports . clear ( ) ;
link . input_ports . clear ( ) ;
2023-01-12 12:19:55 +01:00
} else {
register_link ( p_type , p_id , vsnode . ptr ( ) , node ) ;
}
2020-09-10 07:31:07 +02:00
2020-10-04 11:11:58 +02:00
if ( is_resizable ) {
size = resizable_node - > get_size ( ) ;
2020-09-10 07:31:07 +02:00
node - > set_resizable ( true ) ;
2024-02-07 02:37:26 +01:00
node - > connect ( " resize_end " , callable_mp ( editor , & VisualShaderEditor : : _node_resized ) . bind ( ( int ) p_type , p_id ) ) ;
node - > set_size ( size ) ;
// node->call_deferred(SNAME("set_size"), size);
// editor->call_deferred(SNAME("_set_node_size"), (int)p_type, p_id, size);
2020-09-10 07:31:07 +02:00
}
2024-02-07 02:37:26 +01:00
2020-09-10 07:31:07 +02:00
if ( is_expression ) {
expression = expression_node - > get_expression ( ) ;
}
2020-12-22 17:24:29 +01:00
node - > set_position_offset ( visual_shader - > get_node_position ( p_type , p_id ) ) ;
2020-09-10 07:31:07 +02:00
2022-07-28 22:56:41 +02:00
node - > connect ( " dragged " , callable_mp ( editor , & VisualShaderEditor : : _node_dragged ) . bind ( p_id ) ) ;
2020-09-10 07:31:07 +02:00
Control * custom_editor = nullptr ;
2021-08-09 13:06:23 +02:00
int port_offset = 1 ;
2024-02-07 02:37:26 +01:00
if ( p_update_frames ) {
if ( vsnode - > get_frame ( ) > - 1 ) {
graph - > attach_graph_element_to_frame ( itos ( p_id ) , itos ( vsnode - > get_frame ( ) ) ) ;
} else {
graph - > detach_graph_element_from_frame ( itos ( p_id ) ) ;
}
}
if ( is_frame ) {
GraphFrame * graph_frame = Object : : cast_to < GraphFrame > ( node ) ;
ERR_FAIL_NULL ( graph_frame ) ;
graph_frame - > set_tint_color_enabled ( frame_node - > is_tint_color_enabled ( ) ) ;
graph_frame - > set_tint_color ( frame_node - > get_tint_color ( ) ) ;
// Add hint label.
Label * frame_hint_label = memnew ( Label ) ;
node - > add_child ( frame_hint_label ) ;
frame_hint_label - > set_horizontal_alignment ( HorizontalAlignment : : HORIZONTAL_ALIGNMENT_CENTER ) ;
frame_hint_label - > set_vertical_alignment ( VerticalAlignment : : VERTICAL_ALIGNMENT_CENTER ) ;
frame_hint_label - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
frame_hint_label - > set_v_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
frame_hint_label - > set_text ( TTR ( " Drag and drop nodes here to attach them. " ) ) ;
frame_hint_label - > set_modulate ( Color ( 1.0 , 1.0 , 1.0 , 0.3 ) ) ;
graph_frame - > set_autoshrink_enabled ( frame_node - > is_autoshrink_enabled ( ) ) ;
if ( frame_node - > get_attached_nodes ( ) . is_empty ( ) ) {
frame_hint_label - > show ( ) ;
} else {
frame_hint_label - > hide ( ) ;
}
// Attach all nodes.
if ( p_update_frames & & frame_node - > get_attached_nodes ( ) . size ( ) > 0 ) {
for ( const int & id : frame_node - > get_attached_nodes ( ) ) {
graph - > attach_graph_element_to_frame ( itos ( id ) , node - > get_name ( ) ) ;
}
}
// We should be done here.
return ;
2023-08-09 18:31:15 +02:00
}
2024-05-07 16:48:03 +02:00
if ( ! is_reroute ) {
Control * content_offset = memnew ( Control ) ;
content_offset - > set_custom_minimum_size ( Size2 ( 0 , 5 * EDSCALE ) ) ;
node - > add_child ( content_offset ) ;
}
2020-09-10 07:31:07 +02:00
if ( is_group ) {
2021-08-09 13:06:23 +02:00
port_offset + = 1 ;
2020-09-10 07:31:07 +02:00
}
2024-02-09 15:02:58 +01:00
// Set the minimum width of a node based on the preview size to avoid a resize when toggling the preview.
2024-05-14 15:50:53 +02:00
Ref < StyleBoxFlat > graph_node_stylebox = graph - > get_theme_stylebox ( SceneStringName ( panel ) , " GraphNode " ) ;
2024-02-09 15:02:58 +01:00
int port_preview_size = EDITOR_GET ( " editors/visual_editors/visual_shader/port_preview_size " ) ;
2024-05-07 16:48:03 +02:00
if ( ! is_frame & & ! is_reroute ) {
node - > set_custom_minimum_size ( Size2 ( ( Math : : ceil ( graph_node_stylebox - > get_minimum_size ( ) . width ) + port_preview_size ) * EDSCALE , 0 ) ) ;
}
2024-02-09 15:02:58 +01:00
2020-09-15 09:57:40 +02:00
Ref < VisualShaderNodeParticleEmit > emit = vsnode ;
if ( emit . is_valid ( ) ) {
node - > set_custom_minimum_size ( Size2 ( 200 * EDSCALE , 0 ) ) ;
}
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameterRef > parameter_ref = vsnode ;
if ( parameter_ref . is_valid ( ) ) {
parameter_ref - > set_shader_rid ( visual_shader - > get_rid ( ) ) ;
parameter_ref - > update_parameter_type ( ) ;
2022-07-16 08:59:20 +02:00
}
2024-06-16 09:16:52 +02:00
Ref < VisualShaderNodeVarying > varying = vsnode ;
if ( varying . is_valid ( ) ) {
varying - > set_shader_rid ( visual_shader - > get_rid ( ) ) ;
}
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameter > parameter = vsnode ;
2022-01-07 08:59:15 +01:00
HBoxContainer * hb = nullptr ;
2020-09-10 07:31:07 +02:00
2022-08-27 11:22:43 +02:00
if ( parameter . is_valid ( ) ) {
LineEdit * parameter_name = memnew ( LineEdit ) ;
register_parameter_name ( p_id , parameter_name ) ;
parameter_name - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
parameter_name - > set_text ( parameter - > get_parameter_name ( ) ) ;
parameter_name - > connect ( " text_submitted " , callable_mp ( editor , & VisualShaderEditor : : _parameter_line_edit_changed ) . bind ( p_id ) ) ;
2024-05-13 16:56:03 +02:00
parameter_name - > connect ( SceneStringName ( focus_exited ) , callable_mp ( editor , & VisualShaderEditor : : _parameter_line_edit_focus_out ) . bind ( parameter_name , p_id ) ) ;
2022-01-07 08:59:15 +01:00
if ( vsnode - > get_output_port_count ( ) = = 1 & & vsnode - > get_output_port_name ( 0 ) = = " " ) {
hb = memnew ( HBoxContainer ) ;
2022-08-27 11:22:43 +02:00
hb - > add_child ( parameter_name ) ;
2022-01-07 08:59:15 +01:00
node - > add_child ( hb ) ;
} else {
2022-08-27 11:22:43 +02:00
node - > add_child ( parameter_name ) ;
2020-09-10 07:31:07 +02:00
}
port_offset + + ;
}
2022-01-07 08:59:15 +01:00
for ( int i = 0 ; i < editor - > plugins . size ( ) ; i + + ) {
2020-09-10 07:31:07 +02:00
vsnode - > set_meta ( " id " , p_id ) ;
vsnode - > set_meta ( " shader_type " , ( int ) p_type ) ;
2022-01-07 08:59:15 +01:00
custom_editor = editor - > plugins . write [ i ] - > create_editor ( visual_shader , vsnode ) ;
2020-09-10 07:31:07 +02:00
vsnode - > remove_meta ( " id " ) ;
vsnode - > remove_meta ( " shader_type " ) ;
if ( custom_editor ) {
2020-09-21 13:32:59 +02:00
if ( vsnode - > is_show_prop_names ( ) ) {
2021-07-17 23:22:52 +02:00
custom_editor - > call_deferred ( SNAME ( " _show_prop_names " ) , true ) ;
2020-09-21 13:32:59 +02:00
}
2020-09-10 07:31:07 +02:00
break ;
}
}
2023-09-15 12:27:12 +02:00
if ( custom_node . is_valid ( ) ) {
bool first = true ;
VBoxContainer * vbox = nullptr ;
2024-04-15 15:18:34 +02:00
int i = 0 ;
for ( List < VisualShaderNodeCustom : : DropDownListProperty > : : ConstIterator itr = custom_node - > dp_props . begin ( ) ; itr ! = custom_node - > dp_props . end ( ) ; + + itr , + + i ) {
const VisualShaderNodeCustom : : DropDownListProperty & dp = * itr ;
2023-09-15 12:27:12 +02:00
if ( first ) {
first = false ;
vbox = memnew ( VBoxContainer ) ;
node - > add_child ( vbox ) ;
port_offset + + ;
}
HBoxContainer * hbox = memnew ( HBoxContainer ) ;
vbox - > add_child ( hbox ) ;
hbox - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
String prop_name = dp . name . strip_edges ( ) ;
if ( ! prop_name . is_empty ( ) ) {
Label * label = memnew ( Label ) ;
2024-01-23 22:29:45 +01:00
label - > set_auto_translate_mode ( Node : : AUTO_TRANSLATE_MODE_DISABLED ) ; // TODO: Implement proper translation switch.
2023-09-15 12:27:12 +02:00
label - > set_text ( prop_name + " : " ) ;
hbox - > add_child ( label ) ;
}
OptionButton * op = memnew ( OptionButton ) ;
hbox - > add_child ( op ) ;
op - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
2024-05-14 14:21:31 +02:00
op - > connect ( SceneStringName ( item_selected ) , callable_mp ( editor , & VisualShaderEditor : : _set_custom_node_option ) . bind ( p_id , i ) , CONNECT_DEFERRED ) ;
2023-09-15 12:27:12 +02:00
for ( const String & s : dp . options ) {
op - > add_item ( s ) ;
}
if ( custom_node - > dp_selected_cache . has ( i ) ) {
op - > select ( custom_node - > dp_selected_cache [ i ] ) ;
} else {
op - > select ( 0 ) ;
}
}
}
2020-10-04 11:11:58 +02:00
Ref < VisualShaderNodeCurveTexture > curve = vsnode ;
2021-07-14 00:06:44 +02:00
Ref < VisualShaderNodeCurveXYZTexture > curve_xyz = vsnode ;
2021-07-04 10:56:21 +02:00
2022-01-07 08:59:15 +01:00
bool is_curve = curve . is_valid ( ) | | curve_xyz . is_valid ( ) ;
if ( is_curve ) {
hb = memnew ( HBoxContainer ) ;
node - > add_child ( hb ) ;
2021-07-04 10:56:21 +02:00
}
2022-01-07 08:59:15 +01:00
if ( curve . is_valid ( ) ) {
custom_editor - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
2020-10-04 11:11:58 +02:00
2023-07-03 21:29:37 +02:00
if ( curve - > get_texture ( ) . is_valid ( ) ) {
curve - > get_texture ( ) - > connect_changed ( callable_mp ( graph_plugin , & VisualShaderGraphPlugin : : update_curve ) . bind ( p_id ) ) ;
2021-07-04 10:56:21 +02:00
}
2022-01-07 08:59:15 +01:00
CurveEditor * curve_editor = memnew ( CurveEditor ) ;
node - > add_child ( curve_editor ) ;
register_curve_editor ( p_id , 0 , curve_editor ) ;
curve_editor - > set_custom_minimum_size ( Size2 ( 300 , 0 ) ) ;
curve_editor - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
if ( curve - > get_texture ( ) . is_valid ( ) ) {
curve_editor - > set_curve ( curve - > get_texture ( ) - > get_curve ( ) ) ;
2021-07-04 10:56:21 +02:00
}
2022-01-07 08:59:15 +01:00
}
2021-07-04 10:56:21 +02:00
2022-01-07 08:59:15 +01:00
if ( curve_xyz . is_valid ( ) ) {
custom_editor - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
2021-07-04 10:56:21 +02:00
2023-07-03 21:29:37 +02:00
if ( curve_xyz - > get_texture ( ) . is_valid ( ) ) {
curve_xyz - > get_texture ( ) - > connect_changed ( callable_mp ( graph_plugin , & VisualShaderGraphPlugin : : update_curve_xyz ) . bind ( p_id ) ) ;
2021-07-04 10:56:21 +02:00
}
2022-01-07 08:59:15 +01:00
CurveEditor * curve_editor_x = memnew ( CurveEditor ) ;
node - > add_child ( curve_editor_x ) ;
register_curve_editor ( p_id , 0 , curve_editor_x ) ;
curve_editor_x - > set_custom_minimum_size ( Size2 ( 300 , 0 ) ) ;
curve_editor_x - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
if ( curve_xyz - > get_texture ( ) . is_valid ( ) ) {
curve_editor_x - > set_curve ( curve_xyz - > get_texture ( ) - > get_curve_x ( ) ) ;
}
2020-10-04 11:11:58 +02:00
2022-01-07 08:59:15 +01:00
CurveEditor * curve_editor_y = memnew ( CurveEditor ) ;
node - > add_child ( curve_editor_y ) ;
register_curve_editor ( p_id , 1 , curve_editor_y ) ;
curve_editor_y - > set_custom_minimum_size ( Size2 ( 300 , 0 ) ) ;
curve_editor_y - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
if ( curve_xyz - > get_texture ( ) . is_valid ( ) ) {
curve_editor_y - > set_curve ( curve_xyz - > get_texture ( ) - > get_curve_y ( ) ) ;
2020-10-04 11:11:58 +02:00
}
2021-07-04 10:56:21 +02:00
2022-01-07 08:59:15 +01:00
CurveEditor * curve_editor_z = memnew ( CurveEditor ) ;
node - > add_child ( curve_editor_z ) ;
register_curve_editor ( p_id , 2 , curve_editor_z ) ;
curve_editor_z - > set_custom_minimum_size ( Size2 ( 300 , 0 ) ) ;
curve_editor_z - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
if ( curve_xyz - > get_texture ( ) . is_valid ( ) ) {
curve_editor_z - > set_curve ( curve_xyz - > get_texture ( ) - > get_curve_z ( ) ) ;
}
}
2021-08-12 15:55:14 +02:00
2022-01-07 08:59:15 +01:00
if ( custom_editor ) {
2022-01-09 15:02:13 +01:00
if ( is_curve | | ( hb = = nullptr & & ! vsnode - > is_use_prop_slots ( ) & & ( vsnode - > get_output_port_count ( ) = = 0 | | vsnode - > get_output_port_name ( 0 ) = = " " ) & & ( vsnode - > get_input_port_count ( ) = = 0 | | vsnode - > get_input_port_name ( 0 ) = = " " ) ) ) {
2023-08-09 18:31:15 +02:00
// Will be embedded in first port.
2022-01-07 08:59:15 +01:00
} else {
port_offset + + ;
node - > add_child ( custom_editor ) ;
custom_editor = nullptr ;
2020-09-10 07:31:07 +02:00
}
}
if ( is_group ) {
if ( group_node - > is_editable ( ) ) {
HBoxContainer * hb2 = memnew ( HBoxContainer ) ;
2020-12-02 10:49:46 +01:00
String input_port_name = " input " + itos ( group_node - > get_free_input_port_id ( ) ) ;
String output_port_name = " output " + itos ( group_node - > get_free_output_port_id ( ) ) ;
for ( int i = 0 ; i < MAX ( vsnode - > get_input_port_count ( ) , vsnode - > get_output_port_count ( ) ) ; i + + ) {
if ( i < vsnode - > get_input_port_count ( ) ) {
if ( input_port_name = = vsnode - > get_input_port_name ( i ) ) {
input_port_name = " _ " + input_port_name ;
}
}
if ( i < vsnode - > get_output_port_count ( ) ) {
if ( output_port_name = = vsnode - > get_output_port_name ( i ) ) {
output_port_name = " _ " + output_port_name ;
}
}
}
2020-09-10 07:31:07 +02:00
Button * add_input_btn = memnew ( Button ) ;
add_input_btn - > set_text ( TTR ( " Add Input " ) ) ;
2024-05-14 09:40:21 +02:00
add_input_btn - > connect ( SceneStringName ( pressed ) , callable_mp ( editor , & VisualShaderEditor : : _add_input_port ) . bind ( p_id , group_node - > get_free_input_port_id ( ) , VisualShaderNode : : PORT_TYPE_VECTOR_3D , input_port_name ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
hb2 - > add_child ( add_input_btn ) ;
hb2 - > add_spacer ( ) ;
Button * add_output_btn = memnew ( Button ) ;
add_output_btn - > set_text ( TTR ( " Add Output " ) ) ;
2024-05-14 09:40:21 +02:00
add_output_btn - > connect ( SceneStringName ( pressed ) , callable_mp ( editor , & VisualShaderEditor : : _add_output_port ) . bind ( p_id , group_node - > get_free_output_port_id ( ) , VisualShaderNode : : PORT_TYPE_VECTOR_3D , output_port_name ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
hb2 - > add_child ( add_output_btn ) ;
node - > add_child ( hb2 ) ;
}
}
2020-12-20 16:45:53 +01:00
int output_port_count = 0 ;
for ( int i = 0 ; i < vsnode - > get_output_port_count ( ) ; i + + ) {
if ( vsnode - > _is_output_port_expanded ( i ) ) {
2022-02-01 09:32:01 +01:00
switch ( vsnode - > get_output_port_type ( i ) ) {
case VisualShaderNode : : PORT_TYPE_VECTOR_2D : {
output_port_count + = 2 ;
} break ;
2022-02-06 18:15:28 +01:00
case VisualShaderNode : : PORT_TYPE_VECTOR_3D : {
2022-02-01 09:32:01 +01:00
output_port_count + = 3 ;
} break ;
2022-04-12 19:09:29 +02:00
case VisualShaderNode : : PORT_TYPE_VECTOR_4D : {
output_port_count + = 4 ;
} break ;
2022-02-01 09:32:01 +01:00
default :
break ;
2020-12-20 16:45:53 +01:00
}
}
output_port_count + + ;
}
int max_ports = MAX ( vsnode - > get_input_port_count ( ) , output_port_count ) ;
VisualShaderNode : : PortType expanded_type = VisualShaderNode : : PORT_TYPE_SCALAR ;
int expanded_port_counter = 0 ;
for ( int i = 0 , j = 0 ; i < max_ports ; i + + , j + + ) {
2022-02-01 09:32:01 +01:00
switch ( expanded_type ) {
case VisualShaderNode : : PORT_TYPE_VECTOR_2D : {
if ( expanded_port_counter > = 2 ) {
expanded_type = VisualShaderNode : : PORT_TYPE_SCALAR ;
expanded_port_counter = 0 ;
i - = 2 ;
}
} break ;
2022-02-06 18:15:28 +01:00
case VisualShaderNode : : PORT_TYPE_VECTOR_3D : {
2022-02-01 09:32:01 +01:00
if ( expanded_port_counter > = 3 ) {
expanded_type = VisualShaderNode : : PORT_TYPE_SCALAR ;
expanded_port_counter = 0 ;
i - = 3 ;
}
} break ;
2022-04-12 19:09:29 +02:00
case VisualShaderNode : : PORT_TYPE_VECTOR_4D : {
if ( expanded_port_counter > = 4 ) {
expanded_type = VisualShaderNode : : PORT_TYPE_SCALAR ;
expanded_port_counter = 0 ;
i - = 4 ;
}
} break ;
2022-02-01 09:32:01 +01:00
default :
break ;
2020-12-20 16:45:53 +01:00
}
2020-09-10 07:31:07 +02:00
if ( vsnode - > is_port_separator ( i ) ) {
node - > add_child ( memnew ( HSeparator ) ) ;
port_offset + + ;
}
2020-12-20 16:45:53 +01:00
bool valid_left = j < vsnode - > get_input_port_count ( ) ;
2020-09-10 07:31:07 +02:00
VisualShaderNode : : PortType port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
bool port_left_used = false ;
String name_left ;
if ( valid_left ) {
2024-04-17 12:36:40 +02:00
name_left = vsnode - > get_input_port_name ( j ) ;
port_left = vsnode - > get_input_port_type ( j ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : connections ) {
2021-07-16 05:45:57 +02:00
if ( E . to_node = = p_id & & E . to_port = = j ) {
2020-09-10 07:31:07 +02:00
port_left_used = true ;
2021-10-13 14:25:12 +02:00
break ;
2020-09-10 07:31:07 +02:00
}
}
}
2020-12-20 16:45:53 +01:00
bool valid_right = true ;
2020-09-10 07:31:07 +02:00
VisualShaderNode : : PortType port_right = VisualShaderNode : : PORT_TYPE_SCALAR ;
String name_right ;
2020-12-20 16:45:53 +01:00
if ( expanded_type = = VisualShaderNode : : PORT_TYPE_SCALAR ) {
valid_right = i < vsnode - > get_output_port_count ( ) ;
if ( valid_right ) {
name_right = vsnode - > get_output_port_name ( i ) ;
port_right = vsnode - > get_output_port_type ( i ) ;
}
} else {
name_right = vector_expanded_name [ expanded_port_counter + + ] ;
2020-09-10 07:31:07 +02:00
}
2022-01-07 08:59:15 +01:00
bool is_first_hbox = false ;
if ( i = = 0 & & hb ! = nullptr ) {
is_first_hbox = true ;
} else {
hb = memnew ( HBoxContainer ) ;
}
2022-02-08 10:14:58 +01:00
hb - > add_theme_constant_override ( " separation " , 7 * EDSCALE ) ;
2020-09-10 07:31:07 +02:00
2024-03-05 13:27:33 +01:00
// Default value button/property editor.
2020-09-10 07:31:07 +02:00
Variant default_value ;
if ( valid_left & & ! port_left_used ) {
2024-04-17 12:36:40 +02:00
default_value = vsnode - > get_input_port_default_value ( j ) ;
2020-09-10 07:31:07 +02:00
}
2024-08-02 13:26:49 +02:00
Button * default_input_btn = memnew ( Button ) ;
hb - > add_child ( default_input_btn ) ;
register_default_input_button ( p_id , j , default_input_btn ) ;
default_input_btn - > connect ( SceneStringName ( pressed ) , callable_mp ( editor , & VisualShaderEditor : : _edit_port_default_input ) . bind ( default_input_btn , p_id , j ) ) ;
2020-09-10 07:31:07 +02:00
if ( default_value . get_type ( ) ! = Variant : : NIL ) { // only a label
2024-04-17 12:36:40 +02:00
set_input_port_default_value ( p_type , p_id , j , default_value ) ;
2020-09-13 18:59:01 +02:00
} else {
2024-08-02 13:26:49 +02:00
default_input_btn - > hide ( ) ;
2020-09-10 07:31:07 +02:00
}
2024-04-19 10:49:10 +02:00
if ( j = = 0 & & custom_editor ) {
2020-09-10 07:31:07 +02:00
hb - > add_child ( custom_editor ) ;
custom_editor - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
} else {
if ( valid_left ) {
if ( is_group ) {
OptionButton * type_box = memnew ( OptionButton ) ;
hb - > add_child ( type_box ) ;
type_box - > add_item ( TTR ( " Float " ) ) ;
type_box - > add_item ( TTR ( " Int " ) ) ;
2022-12-27 18:49:11 +01:00
type_box - > add_item ( TTR ( " UInt " ) ) ;
2022-02-01 09:32:01 +01:00
type_box - > add_item ( TTR ( " Vector2 " ) ) ;
type_box - > add_item ( TTR ( " Vector3 " ) ) ;
2022-04-12 19:09:29 +02:00
type_box - > add_item ( TTR ( " Vector4 " ) ) ;
2020-09-10 07:31:07 +02:00
type_box - > add_item ( TTR ( " Boolean " ) ) ;
type_box - > add_item ( TTR ( " Transform " ) ) ;
type_box - > add_item ( TTR ( " Sampler " ) ) ;
2024-04-19 10:49:10 +02:00
type_box - > select ( group_node - > get_input_port_type ( j ) ) ;
2020-09-10 07:31:07 +02:00
type_box - > set_custom_minimum_size ( Size2 ( 100 * EDSCALE , 0 ) ) ;
2024-05-14 14:21:31 +02:00
type_box - > connect ( SceneStringName ( item_selected ) , callable_mp ( editor , & VisualShaderEditor : : _change_input_port_type ) . bind ( p_id , j ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
LineEdit * name_box = memnew ( LineEdit ) ;
hb - > add_child ( name_box ) ;
name_box - > set_custom_minimum_size ( Size2 ( 65 * EDSCALE , 0 ) ) ;
name_box - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
name_box - > set_text ( name_left ) ;
2024-04-19 10:49:10 +02:00
name_box - > connect ( " text_submitted " , callable_mp ( editor , & VisualShaderEditor : : _change_input_port_name ) . bind ( name_box , p_id , j ) , CONNECT_DEFERRED ) ;
2024-05-13 16:56:03 +02:00
name_box - > connect ( SceneStringName ( focus_exited ) , callable_mp ( editor , & VisualShaderEditor : : _port_name_focus_out ) . bind ( name_box , p_id , j , false ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
Button * remove_btn = memnew ( Button ) ;
2023-09-13 13:14:07 +02:00
remove_btn - > set_icon ( EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Remove " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-08-25 12:42:17 +02:00
remove_btn - > set_tooltip_text ( TTR ( " Remove " ) + " " + name_left ) ;
2024-05-14 09:40:21 +02:00
remove_btn - > connect ( SceneStringName ( pressed ) , callable_mp ( editor , & VisualShaderEditor : : _remove_input_port ) . bind ( p_id , j ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
hb - > add_child ( remove_btn ) ;
} else {
Label * label = memnew ( Label ) ;
2024-01-23 22:29:45 +01:00
label - > set_auto_translate_mode ( Node : : AUTO_TRANSLATE_MODE_DISABLED ) ; // TODO: Implement proper translation switch.
2020-09-10 07:31:07 +02:00
label - > set_text ( name_left ) ;
2024-08-02 13:26:49 +02:00
label - > add_theme_style_override ( CoreStringName ( normal ) , editor - > get_theme_stylebox ( SNAME ( " label_style " ) , SNAME ( " VShaderEditor " ) ) ) ;
2020-09-10 07:31:07 +02:00
hb - > add_child ( label ) ;
2024-04-19 10:49:10 +02:00
if ( vsnode - > is_input_port_default ( j , mode ) & & ! port_left_used ) {
2020-09-10 07:31:07 +02:00
Label * hint_label = memnew ( Label ) ;
2022-01-22 09:09:16 +01:00
hint_label - > set_text ( TTR ( " [default] " ) ) ;
2024-05-14 15:57:29 +02:00
hint_label - > add_theme_color_override ( SceneStringName ( font_color ) , editor - > get_theme_color ( SNAME ( " font_readonly_color " ) , SNAME ( " TextEdit " ) ) ) ;
2024-05-14 14:41:39 +02:00
hint_label - > add_theme_style_override ( CoreStringName ( normal ) , editor - > get_theme_stylebox ( SNAME ( " label_style " ) , SNAME ( " VShaderEditor " ) ) ) ;
2020-09-10 07:31:07 +02:00
hb - > add_child ( hint_label ) ;
}
}
}
2022-01-07 08:59:15 +01:00
if ( ! is_group & & ! is_first_hbox ) {
2020-09-10 07:31:07 +02:00
hb - > add_spacer ( ) ;
}
if ( valid_right ) {
if ( is_group ) {
Button * remove_btn = memnew ( Button ) ;
2023-09-13 13:14:07 +02:00
remove_btn - > set_icon ( EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Remove " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-08-25 12:42:17 +02:00
remove_btn - > set_tooltip_text ( TTR ( " Remove " ) + " " + name_left ) ;
2024-05-14 09:40:21 +02:00
remove_btn - > connect ( SceneStringName ( pressed ) , callable_mp ( editor , & VisualShaderEditor : : _remove_output_port ) . bind ( p_id , i ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
hb - > add_child ( remove_btn ) ;
LineEdit * name_box = memnew ( LineEdit ) ;
hb - > add_child ( name_box ) ;
name_box - > set_custom_minimum_size ( Size2 ( 65 * EDSCALE , 0 ) ) ;
name_box - > set_h_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
name_box - > set_text ( name_right ) ;
2022-07-28 22:56:41 +02:00
name_box - > connect ( " text_submitted " , callable_mp ( editor , & VisualShaderEditor : : _change_output_port_name ) . bind ( name_box , p_id , i ) , CONNECT_DEFERRED ) ;
2024-05-13 16:56:03 +02:00
name_box - > connect ( SceneStringName ( focus_exited ) , callable_mp ( editor , & VisualShaderEditor : : _port_name_focus_out ) . bind ( name_box , p_id , i , true ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
OptionButton * type_box = memnew ( OptionButton ) ;
hb - > add_child ( type_box ) ;
type_box - > add_item ( TTR ( " Float " ) ) ;
type_box - > add_item ( TTR ( " Int " ) ) ;
2022-12-27 18:49:11 +01:00
type_box - > add_item ( TTR ( " UInt " ) ) ;
2022-02-01 09:32:01 +01:00
type_box - > add_item ( TTR ( " Vector2 " ) ) ;
type_box - > add_item ( TTR ( " Vector3 " ) ) ;
2022-04-12 19:09:29 +02:00
type_box - > add_item ( TTR ( " Vector4 " ) ) ;
2020-09-10 07:31:07 +02:00
type_box - > add_item ( TTR ( " Boolean " ) ) ;
type_box - > add_item ( TTR ( " Transform " ) ) ;
type_box - > select ( group_node - > get_output_port_type ( i ) ) ;
type_box - > set_custom_minimum_size ( Size2 ( 100 * EDSCALE , 0 ) ) ;
2024-05-14 14:21:31 +02:00
type_box - > connect ( SceneStringName ( item_selected ) , callable_mp ( editor , & VisualShaderEditor : : _change_output_port_type ) . bind ( p_id , i ) , CONNECT_DEFERRED ) ;
2020-09-10 07:31:07 +02:00
} else {
Label * label = memnew ( Label ) ;
2024-01-23 22:29:45 +01:00
label - > set_auto_translate_mode ( Node : : AUTO_TRANSLATE_MODE_DISABLED ) ; // TODO: Implement proper translation switch.
2020-09-10 07:31:07 +02:00
label - > set_text ( name_right ) ;
2024-05-14 14:41:39 +02:00
label - > add_theme_style_override ( CoreStringName ( normal ) , editor - > get_theme_stylebox ( SNAME ( " label_style " ) , SNAME ( " VShaderEditor " ) ) ) ; //more compact
2020-09-10 07:31:07 +02:00
hb - > add_child ( label ) ;
}
}
}
2020-12-20 16:45:53 +01:00
if ( valid_right ) {
2023-02-10 15:10:38 +01:00
if ( expanded_port_counter = = 0 & & vsnode - > is_output_port_expandable ( i ) ) {
2020-12-20 16:45:53 +01:00
TextureButton * expand = memnew ( TextureButton ) ;
expand - > set_toggle_mode ( true ) ;
2023-02-10 15:10:38 +01:00
expand - > set_texture_normal ( editor - > get_editor_theme_icon ( SNAME ( " GuiTreeArrowRight " ) ) ) ;
expand - > set_texture_pressed ( editor - > get_editor_theme_icon ( SNAME ( " GuiTreeArrowDown " ) ) ) ;
2020-12-20 16:45:53 +01:00
expand - > set_v_size_flags ( Control : : SIZE_SHRINK_CENTER ) ;
expand - > set_pressed ( vsnode - > _is_output_port_expanded ( i ) ) ;
2024-05-14 09:40:21 +02:00
expand - > connect ( SceneStringName ( pressed ) , callable_mp ( editor , & VisualShaderEditor : : _expand_output_port ) . bind ( p_id , i , ! vsnode - > _is_output_port_expanded ( i ) ) , CONNECT_DEFERRED ) ;
2020-12-20 16:45:53 +01:00
hb - > add_child ( expand ) ;
}
2021-10-08 21:55:07 +02:00
if ( vsnode - > has_output_port_preview ( i ) & & port_right ! = VisualShaderNode : : PORT_TYPE_TRANSFORM & & port_right ! = VisualShaderNode : : PORT_TYPE_SAMPLER ) {
2020-12-20 16:45:53 +01:00
TextureButton * preview = memnew ( TextureButton ) ;
preview - > set_toggle_mode ( true ) ;
2023-08-13 02:33:39 +02:00
preview - > set_texture_normal ( editor - > get_editor_theme_icon ( SNAME ( " GuiVisibilityHidden " ) ) ) ;
preview - > set_texture_pressed ( editor - > get_editor_theme_icon ( SNAME ( " GuiVisibilityVisible " ) ) ) ;
2020-12-20 16:45:53 +01:00
preview - > set_v_size_flags ( Control : : SIZE_SHRINK_CENTER ) ;
2020-09-10 07:31:07 +02:00
2020-12-20 16:45:53 +01:00
register_output_port ( p_id , j , preview ) ;
2020-09-10 07:31:07 +02:00
2024-05-14 09:40:21 +02:00
preview - > connect ( SceneStringName ( pressed ) , callable_mp ( editor , & VisualShaderEditor : : _preview_select_port ) . bind ( p_id , j ) , CONNECT_DEFERRED ) ;
2020-12-20 16:45:53 +01:00
hb - > add_child ( preview ) ;
}
2020-09-10 07:31:07 +02:00
}
if ( is_group ) {
offset = memnew ( Control ) ;
offset - > set_custom_minimum_size ( Size2 ( 0 , 5 * EDSCALE ) ) ;
node - > add_child ( offset ) ;
port_offset + + ;
}
2024-05-07 16:48:03 +02:00
if ( ! is_first_hbox & & ! is_reroute ) {
2022-01-07 08:59:15 +01:00
node - > add_child ( hb ) ;
2023-02-10 15:10:38 +01:00
if ( curve_xyz . is_valid ( ) ) {
node - > move_child ( hb , 1 + expanded_port_counter ) ;
}
2022-01-07 08:59:15 +01:00
}
2020-09-10 07:31:07 +02:00
2020-12-20 16:45:53 +01:00
if ( expanded_type ! = VisualShaderNode : : PORT_TYPE_SCALAR ) {
continue ;
}
2024-05-07 16:48:03 +02:00
int idx = is_first_hbox ? 1 : i + port_offset ;
if ( is_reroute ) {
idx = 0 ;
2022-01-07 08:59:15 +01:00
}
2024-02-07 02:37:26 +01:00
if ( ! is_frame ) {
2023-08-09 18:31:15 +02:00
GraphNode * graph_node = Object : : cast_to < GraphNode > ( node ) ;
2020-12-20 16:45:53 +01:00
2023-08-09 18:31:15 +02:00
graph_node - > set_slot ( idx , valid_left , port_left , type_color [ port_left ] , valid_right , port_right , type_color [ port_right ] ) ;
2020-12-20 16:45:53 +01:00
2023-08-09 18:31:15 +02:00
if ( vsnode - > _is_output_port_expanded ( i ) ) {
switch ( vsnode - > get_output_port_type ( i ) ) {
case VisualShaderNode : : PORT_TYPE_VECTOR_2D : {
port_offset + + ;
valid_left = ( i + 1 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 1 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 0 ] ) ;
port_offset + + ;
2020-12-20 16:45:53 +01:00
2023-08-09 18:31:15 +02:00
valid_left = ( i + 2 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 2 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 1 ] ) ;
expanded_type = VisualShaderNode : : PORT_TYPE_VECTOR_2D ;
} break ;
case VisualShaderNode : : PORT_TYPE_VECTOR_3D : {
port_offset + + ;
valid_left = ( i + 1 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 1 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 0 ] ) ;
port_offset + + ;
2022-02-01 09:32:01 +01:00
2023-08-09 18:31:15 +02:00
valid_left = ( i + 2 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 2 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 1 ] ) ;
port_offset + + ;
2022-02-01 09:32:01 +01:00
2023-08-09 18:31:15 +02:00
valid_left = ( i + 3 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 3 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 2 ] ) ;
expanded_type = VisualShaderNode : : PORT_TYPE_VECTOR_3D ;
} break ;
case VisualShaderNode : : PORT_TYPE_VECTOR_4D : {
port_offset + + ;
valid_left = ( i + 1 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 1 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 0 ] ) ;
port_offset + + ;
2022-04-12 19:09:29 +02:00
2023-08-09 18:31:15 +02:00
valid_left = ( i + 2 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 2 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 1 ] ) ;
port_offset + + ;
2022-04-12 19:09:29 +02:00
2023-08-09 18:31:15 +02:00
valid_left = ( i + 3 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 3 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 2 ] ) ;
port_offset + + ;
2022-04-12 19:09:29 +02:00
2023-08-09 18:31:15 +02:00
valid_left = ( i + 4 ) < vsnode - > get_input_port_count ( ) ;
port_left = VisualShaderNode : : PORT_TYPE_SCALAR ;
if ( valid_left ) {
port_left = vsnode - > get_input_port_type ( i + 4 ) ;
}
graph_node - > set_slot ( i + port_offset , valid_left , port_left , type_color [ port_left ] , true , VisualShaderNode : : PORT_TYPE_SCALAR , vector_expanded_color [ 3 ] ) ;
2022-04-12 19:09:29 +02:00
2023-08-09 18:31:15 +02:00
expanded_type = VisualShaderNode : : PORT_TYPE_VECTOR_4D ;
} break ;
default :
break ;
}
2020-12-20 16:45:53 +01:00
}
}
2020-09-10 07:31:07 +02:00
}
2023-02-03 13:09:51 +01:00
bool has_relative_parameter_instances = false ;
2020-09-10 07:31:07 +02:00
if ( vsnode - > get_output_port_for_preview ( ) > = 0 ) {
2023-02-03 13:09:51 +01:00
has_relative_parameter_instances = is_node_has_parameter_instances_relatively ( p_type , p_id ) ;
show_port_preview ( p_type , p_id , vsnode - > get_output_port_for_preview ( ) , ! has_relative_parameter_instances ) ;
2024-05-07 16:48:03 +02:00
} else if ( ! is_reroute ) {
2022-04-30 03:56:57 +02:00
offset = memnew ( Control ) ;
offset - > set_custom_minimum_size ( Size2 ( 0 , 4 * EDSCALE ) ) ;
node - > add_child ( offset ) ;
2020-09-10 07:31:07 +02:00
}
2022-01-22 09:09:16 +01:00
String error = vsnode - > get_warning ( mode , p_type ) ;
2023-02-03 13:09:51 +01:00
if ( has_relative_parameter_instances ) {
error + = " \n " + TTR ( " The 2D preview cannot correctly show the result retrieved from instance parameter. " ) ;
}
2021-12-09 10:42:46 +01:00
if ( ! error . is_empty ( ) ) {
2020-09-10 07:31:07 +02:00
Label * error_label = memnew ( Label ) ;
2024-05-14 15:57:29 +02:00
error_label - > add_theme_color_override ( SceneStringName ( font_color ) , editor - > get_theme_color ( SNAME ( " error_color " ) , EditorStringName ( Editor ) ) ) ;
2020-09-10 07:31:07 +02:00
error_label - > set_text ( error ) ;
2023-08-09 18:31:15 +02:00
error_label - > set_autowrap_mode ( TextServer : : AUTOWRAP_WORD ) ;
2020-09-10 07:31:07 +02:00
node - > add_child ( error_label ) ;
}
if ( is_expression ) {
CodeEdit * expression_box = memnew ( CodeEdit ) ;
Ref < CodeHighlighter > expression_syntax_highlighter ;
2021-06-18 00:03:09 +02:00
expression_syntax_highlighter . instantiate ( ) ;
2021-04-24 22:33:50 +02:00
expression_node - > set_ctrl_pressed ( expression_box , 0 ) ;
2024-02-07 02:37:26 +01:00
expression_box - > set_v_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
2020-09-10 07:31:07 +02:00
node - > add_child ( expression_box ) ;
2020-10-15 13:47:27 +02:00
register_expression_edit ( p_id , expression_box ) ;
2020-09-10 07:31:07 +02:00
2021-08-15 19:14:46 +02:00
Color background_color = EDITOR_GET ( " text_editor/theme/highlighting/background_color " ) ;
Color text_color = EDITOR_GET ( " text_editor/theme/highlighting/text_color " ) ;
Color keyword_color = EDITOR_GET ( " text_editor/theme/highlighting/keyword_color " ) ;
Color control_flow_keyword_color = EDITOR_GET ( " text_editor/theme/highlighting/control_flow_keyword_color " ) ;
Color comment_color = EDITOR_GET ( " text_editor/theme/highlighting/comment_color " ) ;
Color symbol_color = EDITOR_GET ( " text_editor/theme/highlighting/symbol_color " ) ;
Color function_color = EDITOR_GET ( " text_editor/theme/highlighting/function_color " ) ;
Color number_color = EDITOR_GET ( " text_editor/theme/highlighting/number_color " ) ;
Color members_color = EDITOR_GET ( " text_editor/theme/highlighting/member_variable_color " ) ;
2020-09-10 07:31:07 +02:00
expression_box - > set_syntax_highlighter ( expression_syntax_highlighter ) ;
2022-02-08 10:14:58 +01:00
expression_box - > add_theme_color_override ( " background_color " , background_color ) ;
2020-09-10 07:31:07 +02:00
2022-01-07 08:59:15 +01:00
for ( const String & E : editor - > keyword_list ) {
2021-07-16 05:45:57 +02:00
if ( ShaderLanguage : : is_control_flow_keyword ( E ) ) {
expression_syntax_highlighter - > add_keyword_color ( E , control_flow_keyword_color ) ;
2021-04-08 16:12:22 +02:00
} else {
2021-07-16 05:45:57 +02:00
expression_syntax_highlighter - > add_keyword_color ( E , keyword_color ) ;
2021-04-08 16:12:22 +02:00
}
2020-09-10 07:31:07 +02:00
}
2023-10-19 18:05:19 +02:00
expression_box - > begin_bulk_theme_override ( ) ;
2024-05-14 15:57:29 +02:00
expression_box - > add_theme_font_override ( SceneStringName ( font ) , editor - > get_theme_font ( SNAME ( " expression " ) , EditorStringName ( EditorFonts ) ) ) ;
expression_box - > add_theme_font_size_override ( SceneStringName ( font_size ) , editor - > get_theme_font_size ( SNAME ( " expression_size " ) , EditorStringName ( EditorFonts ) ) ) ;
expression_box - > add_theme_color_override ( SceneStringName ( font_color ) , text_color ) ;
2023-10-19 18:05:19 +02:00
expression_box - > end_bulk_theme_override ( ) ;
2020-09-10 07:31:07 +02:00
expression_syntax_highlighter - > set_number_color ( number_color ) ;
expression_syntax_highlighter - > set_symbol_color ( symbol_color ) ;
expression_syntax_highlighter - > set_function_color ( function_color ) ;
expression_syntax_highlighter - > set_member_variable_color ( members_color ) ;
expression_syntax_highlighter - > add_color_region ( " /* " , " */ " , comment_color , false ) ;
expression_syntax_highlighter - > add_color_region ( " // " , " " , comment_color , true ) ;
2020-09-10 22:25:40 +02:00
expression_box - > clear_comment_delimiters ( ) ;
expression_box - > add_comment_delimiter ( " /* " , " */ " , false ) ;
expression_box - > add_comment_delimiter ( " // " , " " , true ) ;
2021-06-28 18:14:44 +02:00
if ( ! expression_box - > has_auto_brace_completion_open_key ( " /* " ) ) {
expression_box - > add_auto_brace_completion_pair ( " /* " , " */ " ) ;
}
2020-09-10 07:31:07 +02:00
expression_box - > set_text ( expression ) ;
expression_box - > set_context_menu_enabled ( false ) ;
expression_box - > set_draw_line_numbers ( true ) ;
2024-05-13 16:56:03 +02:00
expression_box - > connect ( SceneStringName ( focus_exited ) , callable_mp ( editor , & VisualShaderEditor : : _expression_focus_out ) . bind ( expression_box , p_id ) ) ;
2020-09-10 07:31:07 +02:00
}
}
2023-01-12 12:19:55 +01:00
void VisualShaderGraphPlugin : : remove_node ( VisualShader : : Type p_type , int p_id , bool p_just_update ) {
2020-09-10 07:31:07 +02:00
if ( visual_shader - > get_shader_type ( ) = = p_type & & links . has ( p_id ) ) {
2024-02-07 02:37:26 +01:00
GraphEdit * graph_edit = editor - > graph ;
if ( ! graph_edit ) {
return ;
}
graph_edit - > remove_child ( links [ p_id ] . graph_element ) ;
2023-08-09 18:31:15 +02:00
memdelete ( links [ p_id ] . graph_element ) ;
2023-01-12 12:19:55 +01:00
if ( ! p_just_update ) {
links . erase ( p_id ) ;
}
2020-09-10 07:31:07 +02:00
}
}
void VisualShaderGraphPlugin : : connect_nodes ( VisualShader : : Type p_type , int p_from_node , int p_from_port , int p_to_node , int p_to_port ) {
2022-01-07 08:59:15 +01:00
GraphEdit * graph = editor - > graph ;
if ( ! graph ) {
return ;
}
if ( visual_shader . is_valid ( ) & & visual_shader - > get_shader_type ( ) = = p_type ) {
2024-05-07 16:48:03 +02:00
// Update reroute nodes since their port type might have changed.
Ref < VisualShaderNodeReroute > reroute_to = visual_shader - > get_node ( p_type , p_to_node ) ;
Ref < VisualShaderNodeReroute > reroute_from = visual_shader - > get_node ( p_type , p_from_node ) ;
if ( reroute_to . is_valid ( ) | | reroute_from . is_valid ( ) ) {
update_reroute_nodes ( ) ;
}
2022-01-07 08:59:15 +01:00
graph - > connect_node ( itos ( p_from_node ) , p_from_port , itos ( p_to_node ) , p_to_port ) ;
2021-07-07 19:41:04 +02:00
connections . push_back ( { p_from_node , p_from_port , p_to_node , p_to_port } ) ;
2020-09-13 18:59:01 +02:00
if ( links [ p_to_node ] . input_ports . has ( p_to_port ) & & links [ p_to_node ] . input_ports [ p_to_port ] . default_input_button ! = nullptr ) {
links [ p_to_node ] . input_ports [ p_to_port ] . default_input_button - > hide ( ) ;
}
2020-09-10 07:31:07 +02:00
}
}
void VisualShaderGraphPlugin : : disconnect_nodes ( VisualShader : : Type p_type , int p_from_node , int p_from_port , int p_to_node , int p_to_port ) {
2022-01-07 08:59:15 +01:00
GraphEdit * graph = editor - > graph ;
if ( ! graph ) {
return ;
}
if ( visual_shader . is_valid ( ) & & visual_shader - > get_shader_type ( ) = = p_type ) {
graph - > disconnect_node ( itos ( p_from_node ) , p_from_port , itos ( p_to_node ) , p_to_port ) ;
2021-07-16 05:45:57 +02:00
for ( const List < VisualShader : : Connection > : : Element * E = connections . front ( ) ; E ; E = E - > next ( ) ) {
2021-07-07 19:41:04 +02:00
if ( E - > get ( ) . from_node = = p_from_node & & E - > get ( ) . from_port = = p_from_port & & E - > get ( ) . to_node = = p_to_node & & E - > get ( ) . to_port = = p_to_port ) {
connections . erase ( E ) ;
break ;
}
}
2020-09-13 22:48:59 +02:00
if ( links [ p_to_node ] . input_ports . has ( p_to_port ) & & links [ p_to_node ] . input_ports [ p_to_port ] . default_input_button ! = nullptr & & links [ p_to_node ] . visual_node - > get_input_port_default_value ( p_to_port ) . get_type ( ) ! = Variant : : NIL ) {
2020-09-13 18:59:01 +02:00
links [ p_to_node ] . input_ports [ p_to_port ] . default_input_button - > show ( ) ;
set_input_port_default_value ( p_type , p_to_node , p_to_port , links [ p_to_node ] . visual_node - > get_input_port_default_value ( p_to_port ) ) ;
}
2020-09-10 07:31:07 +02:00
}
}
2020-09-09 16:40:27 +02:00
VisualShaderGraphPlugin : : ~ VisualShaderGraphPlugin ( ) {
}
/////////////////
2022-08-01 20:01:48 +02:00
void VisualShaderEditedProperty : : _bind_methods ( ) {
ClassDB : : bind_method ( D_METHOD ( " set_edited_property " , " value " ) , & VisualShaderEditedProperty : : set_edited_property ) ;
ClassDB : : bind_method ( D_METHOD ( " get_edited_property " ) , & VisualShaderEditedProperty : : get_edited_property ) ;
ADD_PROPERTY ( PropertyInfo ( Variant : : NIL , " edited_property " , PROPERTY_HINT_NONE , " " , PROPERTY_USAGE_NIL_IS_VARIANT ) , " set_edited_property " , " get_edited_property " ) ;
}
2024-02-15 17:25:58 +01:00
void VisualShaderEditedProperty : : set_edited_property ( const Variant & p_variant ) {
2022-08-01 20:01:48 +02:00
edited_property = p_variant ;
}
Variant VisualShaderEditedProperty : : get_edited_property ( ) const {
return edited_property ;
}
/////////////////
2022-07-16 08:59:20 +02:00
Vector2 VisualShaderEditor : : selection_center ;
List < VisualShaderEditor : : CopyItem > VisualShaderEditor : : copy_items_buffer ;
List < VisualShader : : Connection > VisualShaderEditor : : copy_connections_buffer ;
2024-07-12 20:56:49 +02:00
void VisualShaderEditor : : edit_shader ( const Ref < Shader > & p_shader ) {
2019-05-03 10:10:08 +02:00
bool changed = false ;
2024-07-12 20:56:49 +02:00
VisualShader * visual_shader_ptr = Object : : cast_to < VisualShader > ( p_shader . ptr ( ) ) ;
if ( visual_shader_ptr ) {
2019-05-03 10:10:08 +02:00
if ( visual_shader . is_null ( ) ) {
changed = true ;
} else {
2024-07-12 20:56:49 +02:00
if ( visual_shader . ptr ( ) ! = visual_shader_ptr ) {
2019-05-03 10:10:08 +02:00
changed = true ;
}
}
2024-07-12 20:56:49 +02:00
visual_shader = p_shader ;
2020-09-09 16:40:27 +02:00
graph_plugin - > register_shader ( visual_shader . ptr ( ) ) ;
2022-01-07 08:59:15 +01:00
2023-07-03 21:29:37 +02:00
visual_shader - > connect_changed ( callable_mp ( this , & VisualShaderEditor : : _update_preview ) ) ;
2023-07-10 17:26:02 +02:00
visual_shader - > set_graph_offset ( graph - > get_scroll_offset ( ) / EDSCALE ) ;
2020-09-12 10:01:48 +02:00
_set_mode ( visual_shader - > get_mode ( ) ) ;
2022-11-24 18:58:16 +01:00
2024-07-11 15:20:25 +02:00
preview_material - > set_shader ( visual_shader ) ;
2022-11-24 18:58:16 +01:00
_update_nodes ( ) ;
2018-07-14 23:15:42 +02:00
} else {
2019-08-18 11:29:22 +02:00
if ( visual_shader . is_valid ( ) ) {
2023-07-03 21:29:37 +02:00
visual_shader - > disconnect_changed ( callable_mp ( this , & VisualShaderEditor : : _update_preview ) ) ;
2019-08-18 11:29:22 +02:00
}
2018-07-14 23:15:42 +02:00
visual_shader . unref ( ) ;
}
if ( visual_shader . is_null ( ) ) {
hide ( ) ;
} else {
2019-05-03 10:10:08 +02:00
if ( changed ) { // to avoid tree collapse
2022-01-09 15:02:13 +01:00
_update_varying_tree ( ) ;
2019-05-01 16:04:39 +02:00
_update_options_menu ( ) ;
2019-08-18 11:29:22 +02:00
_update_preview ( ) ;
2020-09-10 07:31:07 +02:00
_update_graph ( ) ;
2019-05-01 16:04:39 +02:00
}
2018-07-14 23:15:42 +02:00
}
}
2024-07-12 20:56:49 +02:00
void VisualShaderEditor : : apply_shaders ( ) {
// Stub. TODO: Implement apply_shaders in visual shaders for parity with text shaders.
}
bool VisualShaderEditor : : is_unsaved ( ) const {
// Stub. TODO: Implement is_unsaved in visual shaders for parity with text shaders.
return false ;
}
void VisualShaderEditor : : save_external_data ( const String & p_str ) {
ResourceSaver : : save ( visual_shader , visual_shader - > get_path ( ) ) ;
}
2024-06-20 12:37:16 +02:00
void VisualShaderEditor : : validate_script ( ) {
if ( visual_shader . is_valid ( ) ) {
_update_nodes ( ) ;
}
}
2018-07-14 23:15:42 +02:00
void VisualShaderEditor : : add_plugin ( const Ref < VisualShaderNodePlugin > & p_plugin ) {
2022-02-01 19:19:13 +01:00
if ( plugins . has ( p_plugin ) ) {
2018-07-14 23:15:42 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
plugins . push_back ( p_plugin ) ;
}
void VisualShaderEditor : : remove_plugin ( const Ref < VisualShaderNodePlugin > & p_plugin ) {
plugins . erase ( p_plugin ) ;
}
2019-08-09 21:51:48 +02:00
void VisualShaderEditor : : clear_custom_types ( ) {
2018-07-14 23:15:42 +02:00
for ( int i = 0 ; i < add_options . size ( ) ; i + + ) {
2019-08-09 21:51:48 +02:00
if ( add_options [ i ] . is_custom ) {
2021-07-04 00:17:03 +02:00
add_options . remove_at ( i ) ;
2019-11-02 09:53:22 +01:00
i - - ;
2019-08-09 21:51:48 +02:00
}
2018-07-14 23:15:42 +02:00
}
}
2023-01-04 12:30:20 +01:00
void VisualShaderEditor : : add_custom_type ( const String & p_name , const String & p_type , const Ref < Script > & p_script , const String & p_description , int p_return_icon_type , const String & p_category , bool p_highend ) {
2024-08-23 08:30:51 +02:00
ERR_FAIL_COND ( ! p_name . is_valid_ascii_identifier ( ) ) ;
2023-01-04 12:30:20 +01:00
ERR_FAIL_COND ( p_type . is_empty ( ) & & ! p_script . is_valid ( ) ) ;
2018-07-14 23:15:42 +02:00
for ( int i = 0 ; i < add_options . size ( ) ; i + + ) {
2023-01-04 12:30:20 +01:00
const AddOption & op = add_options [ i ] ;
if ( op . is_custom ) {
if ( ! p_type . is_empty ( ) ) {
if ( op . type = = p_type ) {
return ;
}
} else if ( op . script = = p_script ) {
2019-08-09 21:51:48 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
}
}
2019-08-09 21:51:48 +02:00
AddOption ao ;
ao . name = p_name ;
2023-01-04 12:30:20 +01:00
ao . type = p_type ;
2019-08-09 21:51:48 +02:00
ao . script = p_script ;
ao . return_type = p_return_icon_type ;
ao . description = p_description ;
ao . category = p_category ;
2020-02-13 07:43:43 +01:00
ao . highend = p_highend ;
2019-08-09 21:51:48 +02:00
ao . is_custom = true ;
2023-01-04 12:30:20 +01:00
ao . is_native = ! p_type . is_empty ( ) ;
2019-08-09 21:51:48 +02:00
2019-11-02 09:53:22 +01:00
bool begin = false ;
2020-02-14 13:11:55 +01:00
String root = p_category . split ( " / " ) [ 0 ] ;
2019-11-02 09:53:22 +01:00
for ( int i = 0 ; i < add_options . size ( ) ; i + + ) {
if ( add_options [ i ] . is_custom ) {
2020-02-14 13:11:55 +01:00
if ( add_options [ i ] . category = = root ) {
2019-11-02 09:53:22 +01:00
if ( ! begin ) {
begin = true ;
}
} else {
if ( begin ) {
add_options . insert ( i , ao ) ;
return ;
}
}
}
}
2019-08-09 21:51:48 +02:00
add_options . push_back ( ao ) ;
2018-07-14 23:15:42 +02:00
}
2022-12-07 19:50:28 +01:00
Dictionary VisualShaderEditor : : get_custom_node_data ( Ref < VisualShaderNodeCustom > & p_custom_node ) {
Dictionary dict ;
dict [ " script " ] = p_custom_node - > get_script ( ) ;
2023-01-04 12:30:20 +01:00
dict [ " name " ] = p_custom_node - > _get_name ( ) ;
dict [ " description " ] = p_custom_node - > _get_description ( ) ;
dict [ " return_icon_type " ] = p_custom_node - > _get_return_icon_type ( ) ;
dict [ " highend " ] = p_custom_node - > _is_highend ( ) ;
2022-12-07 19:50:28 +01:00
2023-01-04 12:30:20 +01:00
String category = p_custom_node - > _get_category ( ) ;
2022-12-07 19:50:28 +01:00
category = category . rstrip ( " / " ) ;
category = category . lstrip ( " / " ) ;
category = " Addons/ " + category ;
if ( p_custom_node - > has_method ( " _get_subcategory " ) ) {
2023-01-04 12:30:20 +01:00
String subcategory = ( String ) p_custom_node - > call ( " _get_subcategory " ) ;
if ( ! subcategory . is_empty ( ) ) {
category + = " / " + subcategory ;
}
2022-12-07 19:50:28 +01:00
}
dict [ " category " ] = category ;
return dict ;
}
2023-01-23 10:01:28 +01:00
void VisualShaderEditor : : _get_current_mode_limits ( int & r_begin_type , int & r_end_type ) const {
switch ( visual_shader - > get_mode ( ) ) {
case Shader : : MODE_CANVAS_ITEM :
case Shader : : MODE_SPATIAL : {
r_begin_type = 0 ;
r_end_type = 3 ;
} break ;
case Shader : : MODE_PARTICLES : {
r_begin_type = 3 ;
r_end_type = 5 + r_begin_type ;
} break ;
case Shader : : MODE_SKY : {
r_begin_type = 8 ;
r_end_type = 1 + r_begin_type ;
} break ;
case Shader : : MODE_FOG : {
r_begin_type = 9 ;
r_end_type = 1 + r_begin_type ;
} break ;
default : {
} break ;
}
}
void VisualShaderEditor : : _script_created ( const Ref < Script > & p_script ) {
if ( p_script . is_null ( ) | | p_script - > get_instance_base_type ( ) ! = " VisualShaderNodeCustom " ) {
return ;
}
Ref < VisualShaderNodeCustom > ref ;
ref . instantiate ( ) ;
ref - > set_script ( p_script ) ;
Dictionary dict = get_custom_node_data ( ref ) ;
2023-01-04 12:30:20 +01:00
add_custom_type ( dict [ " name " ] , String ( ) , dict [ " script " ] , dict [ " description " ] , dict [ " return_icon_type " ] , dict [ " category " ] , dict [ " highend " ] ) ;
2023-01-23 10:01:28 +01:00
_update_options_menu ( ) ;
}
void VisualShaderEditor : : _update_custom_script ( const Ref < Script > & p_script ) {
if ( p_script . is_null ( ) | | p_script - > get_instance_base_type ( ) ! = " VisualShaderNodeCustom " ) {
2022-12-07 19:50:28 +01:00
return ;
}
Ref < VisualShaderNodeCustom > ref ;
ref . instantiate ( ) ;
2023-01-23 10:01:28 +01:00
ref - > set_script ( p_script ) ;
2022-12-07 19:50:28 +01:00
if ( ! ref - > is_available ( visual_shader - > get_mode ( ) , visual_shader - > get_shader_type ( ) ) ) {
for ( int i = 0 ; i < add_options . size ( ) ; i + + ) {
2023-01-23 10:01:28 +01:00
if ( add_options [ i ] . is_custom & & add_options [ i ] . script = = p_script ) {
2022-12-07 19:50:28 +01:00
add_options . remove_at ( i ) ;
_update_options_menu ( ) ;
// TODO: Make indication for the existed custom nodes with that script on graph to be disabled.
break ;
}
}
return ;
}
Dictionary dict = get_custom_node_data ( ref ) ;
bool found_type = false ;
bool need_rebuild = false ;
2023-01-23 10:01:28 +01:00
for ( int i = custom_node_option_idx ; i < add_options . size ( ) ; i + + ) {
if ( add_options [ i ] . script = = p_script ) {
2022-12-07 19:50:28 +01:00
found_type = true ;
add_options . write [ i ] . name = dict [ " name " ] ;
add_options . write [ i ] . return_type = dict [ " return_icon_type " ] ;
add_options . write [ i ] . description = dict [ " description " ] ;
add_options . write [ i ] . category = dict [ " category " ] ;
add_options . write [ i ] . highend = dict [ " highend " ] ;
2023-01-23 10:01:28 +01:00
int begin_type = 0 ;
int end_type = 0 ;
_get_current_mode_limits ( begin_type , end_type ) ;
2022-12-07 19:50:28 +01:00
2023-01-23 10:01:28 +01:00
for ( int t = begin_type ; t < end_type ; t + + ) {
2022-12-07 19:50:28 +01:00
VisualShader : : Type type = ( VisualShader : : Type ) t ;
Vector < int > nodes = visual_shader - > get_node_list ( type ) ;
List < VisualShader : : Connection > node_connections ;
visual_shader - > get_node_connections ( type , & node_connections ) ;
List < VisualShader : : Connection > custom_node_input_connections ;
List < VisualShader : : Connection > custom_node_output_connections ;
2023-01-23 10:01:28 +01:00
2022-12-07 19:50:28 +01:00
for ( const VisualShader : : Connection & E : node_connections ) {
int from = E . from_node ;
2023-01-23 10:01:28 +01:00
int from_port = E . from_port ;
2022-12-07 19:50:28 +01:00
int to = E . to_node ;
2023-01-23 10:01:28 +01:00
int to_port = E . to_port ;
2022-12-07 19:50:28 +01:00
2023-01-23 10:01:28 +01:00
if ( graph_plugin - > get_node_script ( from ) = = p_script ) {
custom_node_output_connections . push_back ( { from , from_port , to , to_port } ) ;
} else if ( graph_plugin - > get_node_script ( to ) = = p_script ) {
custom_node_input_connections . push_back ( { from , from_port , to , to_port } ) ;
2022-12-07 19:50:28 +01:00
}
}
2023-01-23 10:01:28 +01:00
for ( int node_id : nodes ) {
2022-12-07 19:50:28 +01:00
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , node_id ) ;
if ( vsnode . is_null ( ) ) {
continue ;
}
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNodeCustom > custom_node = vsnode ;
2023-01-23 10:01:28 +01:00
if ( custom_node . is_null ( ) | | custom_node - > get_script ( ) ! = p_script ) {
2022-12-07 19:50:28 +01:00
continue ;
}
need_rebuild = true ;
// Removes invalid connections.
{
int prev_input_port_count = custom_node - > get_input_port_count ( ) ;
int prev_output_port_count = custom_node - > get_output_port_count ( ) ;
custom_node - > update_ports ( ) ;
int input_port_count = custom_node - > get_input_port_count ( ) ;
int output_port_count = custom_node - > get_output_port_count ( ) ;
if ( output_port_count ! = prev_output_port_count ) {
for ( const VisualShader : : Connection & E : custom_node_output_connections ) {
int from = E . from_node ;
int from_idx = E . from_port ;
int to = E . to_node ;
int to_idx = E . to_port ;
if ( from_idx > = output_port_count ) {
visual_shader - > disconnect_nodes ( type , from , from_idx , to , to_idx ) ;
graph_plugin - > disconnect_nodes ( type , from , from_idx , to , to_idx ) ;
}
}
}
if ( input_port_count ! = prev_input_port_count ) {
for ( const VisualShader : : Connection & E : custom_node_input_connections ) {
int from = E . from_node ;
int from_idx = E . from_port ;
int to = E . to_node ;
int to_idx = E . to_port ;
if ( to_idx > = input_port_count ) {
visual_shader - > disconnect_nodes ( type , from , from_idx , to , to_idx ) ;
graph_plugin - > disconnect_nodes ( type , from , from_idx , to , to_idx ) ;
}
}
}
}
graph_plugin - > update_node ( type , node_id ) ;
}
}
break ;
}
}
if ( ! found_type ) {
2023-01-04 12:30:20 +01:00
add_custom_type ( dict [ " name " ] , String ( ) , dict [ " script " ] , dict [ " description " ] , dict [ " return_icon_type " ] , dict [ " category " ] , dict [ " highend " ] ) ;
2022-12-07 19:50:28 +01:00
}
// To prevent updating options multiple times when multiple scripts are saved.
if ( ! _block_update_options_menu ) {
_block_update_options_menu = true ;
2023-12-18 15:46:56 +01:00
callable_mp ( this , & VisualShaderEditor : : _update_options_menu_deferred ) ;
2022-12-07 19:50:28 +01:00
}
// To prevent rebuilding the shader multiple times when multiple scripts are saved.
if ( need_rebuild & & ! _block_rebuild_shader ) {
_block_rebuild_shader = true ;
2023-12-18 15:46:56 +01:00
callable_mp ( this , & VisualShaderEditor : : _rebuild_shader_deferred ) ;
2022-12-07 19:50:28 +01:00
}
}
2023-01-23 10:01:28 +01:00
void VisualShaderEditor : : _resource_saved ( const Ref < Resource > & p_resource ) {
_update_custom_script ( Ref < Script > ( p_resource . ptr ( ) ) ) ;
}
void VisualShaderEditor : : _resources_removed ( ) {
bool has_any_instance = false ;
for ( const Ref < Script > & scr : custom_scripts_to_delete ) {
for ( int i = custom_node_option_idx ; i < add_options . size ( ) ; i + + ) {
if ( add_options [ i ] . script = = scr ) {
add_options . remove_at ( i ) ;
// Removes all node instances using that script from the graph.
{
int begin_type = 0 ;
int end_type = 0 ;
_get_current_mode_limits ( begin_type , end_type ) ;
for ( int t = begin_type ; t < end_type ; t + + ) {
VisualShader : : Type type = ( VisualShader : : Type ) t ;
List < VisualShader : : Connection > node_connections ;
visual_shader - > get_node_connections ( type , & node_connections ) ;
for ( const VisualShader : : Connection & E : node_connections ) {
int from = E . from_node ;
int from_port = E . from_port ;
int to = E . to_node ;
int to_port = E . to_port ;
if ( graph_plugin - > get_node_script ( from ) = = scr | | graph_plugin - > get_node_script ( to ) = = scr ) {
visual_shader - > disconnect_nodes ( type , from , from_port , to , to_port ) ;
graph_plugin - > disconnect_nodes ( type , from , from_port , to , to_port ) ;
}
}
Vector < int > nodes = visual_shader - > get_node_list ( type ) ;
for ( int node_id : nodes ) {
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , node_id ) ;
if ( vsnode . is_null ( ) ) {
continue ;
}
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNodeCustom > custom_node = vsnode ;
2023-01-23 10:01:28 +01:00
if ( custom_node . is_null ( ) | | custom_node - > get_script ( ) ! = scr ) {
continue ;
}
visual_shader - > remove_node ( type , node_id ) ;
graph_plugin - > remove_node ( type , node_id , false ) ;
has_any_instance = true ;
}
}
}
break ;
}
}
}
if ( has_any_instance ) {
EditorUndoRedoManager : : get_singleton ( ) - > clear_history ( ) ; // Need to clear undo history, otherwise it may lead to hard-detected errors and crashes (since the script was removed).
ResourceSaver : : save ( visual_shader , visual_shader - > get_path ( ) ) ;
}
_update_options_menu ( ) ;
custom_scripts_to_delete . clear ( ) ;
pending_custom_scripts_to_delete = false ;
}
void VisualShaderEditor : : _resource_removed ( const Ref < Resource > & p_resource ) {
Ref < Script > scr = Ref < Script > ( p_resource . ptr ( ) ) ;
if ( scr . is_null ( ) | | scr - > get_instance_base_type ( ) ! = " VisualShaderNodeCustom " ) {
return ;
}
custom_scripts_to_delete . push_back ( scr ) ;
if ( ! pending_custom_scripts_to_delete ) {
pending_custom_scripts_to_delete = true ;
2023-12-18 15:46:56 +01:00
callable_mp ( this , & VisualShaderEditor : : _resources_removed ) . call_deferred ( ) ;
2023-01-23 10:01:28 +01:00
}
}
2022-12-07 19:50:28 +01:00
void VisualShaderEditor : : _update_options_menu_deferred ( ) {
_update_options_menu ( ) ;
_block_update_options_menu = false ;
}
void VisualShaderEditor : : _rebuild_shader_deferred ( ) {
if ( visual_shader . is_valid ( ) ) {
visual_shader - > rebuild ( ) ;
}
_block_rebuild_shader = false ;
}
2019-02-22 18:38:58 +01:00
bool VisualShaderEditor : : _is_available ( int p_mode ) {
int current_mode = edit_type - > get_selected ( ) ;
if ( p_mode ! = - 1 ) {
switch ( current_mode ) {
2020-09-15 09:57:40 +02:00
case 0 : // Vertex / Emit
2019-02-22 18:38:58 +01:00
current_mode = 1 ;
break ;
2020-09-15 09:57:40 +02:00
case 1 : // Fragment / Process
2019-02-22 18:38:58 +01:00
current_mode = 2 ;
break ;
2020-09-15 09:57:40 +02:00
case 2 : // Light / Collide
2019-02-22 18:38:58 +01:00
current_mode = 4 ;
break ;
default :
break ;
}
}
2019-06-26 15:08:25 +02:00
return ( p_mode = = - 1 | | ( p_mode & current_mode ) ! = 0 ) ;
2019-02-22 18:38:58 +01:00
}
2024-07-11 15:20:25 +02:00
bool VisualShaderEditor : : _update_preview_parameter_tree ( ) {
bool found = false ;
bool use_filter = ! param_filter_name . is_empty ( ) ;
parameters - > clear ( ) ;
TreeItem * root = parameters - > create_item ( ) ;
for ( const KeyValue < String , PropertyInfo > & prop : parameter_props ) {
String param_name = prop . value . name ;
if ( use_filter & & ! param_name . containsn ( param_filter_name ) ) {
continue ;
}
TreeItem * item = parameters - > create_item ( root ) ;
item - > set_text ( 0 , param_name ) ;
item - > set_meta ( " id " , param_name ) ;
if ( param_name = = selected_param_id ) {
parameters - > set_selected ( item ) ;
found = true ;
}
if ( prop . value . type = = Variant : : OBJECT ) {
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " ImageTexture " ) ) ) ;
} else {
item - > set_icon ( 0 , get_editor_theme_icon ( Variant : : get_type_name ( prop . value . type ) ) ) ;
}
}
return found ;
}
void VisualShaderEditor : : _clear_preview_param ( ) {
selected_param_id = " " ;
current_prop = nullptr ;
if ( param_vbox2 - > get_child_count ( ) > 0 ) {
param_vbox2 - > remove_child ( param_vbox2 - > get_child ( 0 ) ) ;
}
param_vbox - > hide ( ) ;
}
void VisualShaderEditor : : _update_preview_parameter_list ( ) {
material_editor - > edit ( preview_material . ptr ( ) , env ) ;
List < PropertyInfo > properties ;
RenderingServer : : get_singleton ( ) - > get_shader_parameter_list ( visual_shader - > get_rid ( ) , & properties ) ;
HashSet < String > params_to_remove ;
for ( const KeyValue < String , PropertyInfo > & E : parameter_props ) {
params_to_remove . insert ( E . key ) ;
}
parameter_props . clear ( ) ;
for ( const PropertyInfo & prop : properties ) {
String param_name = prop . name ;
if ( visual_shader - > _has_preview_shader_parameter ( param_name ) ) {
preview_material - > set_shader_parameter ( param_name , visual_shader - > _get_preview_shader_parameter ( param_name ) ) ;
} else {
preview_material - > set_shader_parameter ( param_name , RenderingServer : : get_singleton ( ) - > shader_get_parameter_default ( visual_shader - > get_rid ( ) , param_name ) ) ;
}
parameter_props . insert ( param_name , prop ) ;
params_to_remove . erase ( param_name ) ;
if ( param_name = = selected_param_id ) {
current_prop - > update_property ( ) ;
current_prop - > update_editor_property_status ( ) ;
current_prop - > update_cache ( ) ;
}
}
_update_preview_parameter_tree ( ) ;
// Removes invalid parameters.
for ( const String & param_name : params_to_remove ) {
preview_material - > set_shader_parameter ( param_name , Variant ( ) ) ;
if ( visual_shader - > _has_preview_shader_parameter ( param_name ) ) {
visual_shader - > _set_preview_shader_parameter ( param_name , Variant ( ) ) ;
}
if ( param_name = = selected_param_id ) {
_clear_preview_param ( ) ;
}
}
}
2022-02-07 20:58:37 +01:00
void VisualShaderEditor : : _update_nodes ( ) {
2019-08-09 21:51:48 +02:00
clear_custom_types ( ) ;
2019-11-02 09:53:22 +01:00
Dictionary added ;
2023-01-04 12:30:20 +01:00
// Add GDScript classes.
{
List < StringName > class_list ;
ScriptServer : : get_global_class_list ( & class_list ) ;
2024-04-15 15:18:34 +02:00
for ( const StringName & E : class_list ) {
if ( ScriptServer : : get_global_class_native_base ( E ) = = " VisualShaderNodeCustom " ) {
String script_path = ScriptServer : : get_global_class_path ( E ) ;
2023-01-04 12:30:20 +01:00
Ref < Resource > res = ResourceLoader : : load ( script_path ) ;
ERR_CONTINUE ( res . is_null ( ) ) ;
ERR_CONTINUE ( ! res - > is_class ( " Script " ) ) ;
Ref < Script > scr = Ref < Script > ( res ) ;
Ref < VisualShaderNodeCustom > ref ;
ref . instantiate ( ) ;
ref - > set_script ( scr ) ;
if ( ! ref - > is_available ( visual_shader - > get_mode ( ) , visual_shader - > get_shader_type ( ) ) ) {
continue ;
}
Dictionary dict = get_custom_node_data ( ref ) ;
dict [ " type " ] = String ( ) ;
String key ;
key = String ( dict [ " category " ] ) + " / " + String ( dict [ " name " ] ) ;
added [ key ] = dict ;
2022-02-07 20:58:37 +01:00
}
2023-01-04 12:30:20 +01:00
}
}
2019-11-02 09:53:22 +01:00
2023-01-04 12:30:20 +01:00
// Add GDExtension classes.
{
List < StringName > class_list ;
ClassDB : : get_class_list ( & class_list ) ;
2024-04-15 15:18:34 +02:00
for ( const StringName & E : class_list ) {
if ( ClassDB : : get_parent_class ( E ) = = " VisualShaderNodeCustom " ) {
Object * instance = ClassDB : : instantiate ( E ) ;
2023-01-04 12:30:20 +01:00
Ref < VisualShaderNodeCustom > ref = Object : : cast_to < VisualShaderNodeCustom > ( instance ) ;
ERR_CONTINUE ( ref . is_null ( ) ) ;
if ( ! ref - > is_available ( visual_shader - > get_mode ( ) , visual_shader - > get_shader_type ( ) ) ) {
continue ;
}
Dictionary dict = get_custom_node_data ( ref ) ;
2024-04-15 15:18:34 +02:00
dict [ " type " ] = E ;
2023-01-04 12:30:20 +01:00
dict [ " script " ] = Ref < Script > ( ) ;
2019-08-09 21:51:48 +02:00
2023-01-04 12:30:20 +01:00
String key ;
key = String ( dict [ " category " ] ) + " / " + String ( dict [ " name " ] ) ;
added [ key ] = dict ;
}
2019-08-09 21:51:48 +02:00
}
}
2019-11-02 09:53:22 +01:00
2022-02-07 20:58:37 +01:00
// Disables not-supported copied items.
{
for ( CopyItem & item : copy_items_buffer ) {
Ref < VisualShaderNodeCustom > custom = Object : : cast_to < VisualShaderNodeCustom > ( item . node . ptr ( ) ) ;
if ( custom . is_valid ( ) ) {
if ( ! custom - > is_available ( visual_shader - > get_mode ( ) , visual_shader - > get_shader_type ( ) ) ) {
item . disabled = true ;
} else {
item . disabled = false ;
}
} else {
for ( int i = 0 ; i < add_options . size ( ) ; i + + ) {
if ( add_options [ i ] . type = = item . node - > get_class_name ( ) ) {
if ( ( add_options [ i ] . func ! = visual_shader - > get_mode ( ) & & add_options [ i ] . func ! = - 1 ) | | ! _is_available ( add_options [ i ] . mode ) ) {
item . disabled = true ;
} else {
item . disabled = false ;
}
break ;
}
}
}
}
}
2019-11-02 09:53:22 +01:00
Array keys = added . keys ( ) ;
keys . sort ( ) ;
for ( int i = 0 ; i < keys . size ( ) ; i + + ) {
const Variant & key = keys . get ( i ) ;
const Dictionary & value = ( Dictionary ) added [ key ] ;
2023-01-04 12:30:20 +01:00
add_custom_type ( value [ " name " ] , value [ " type " ] , value [ " script " ] , value [ " description " ] , value [ " return_icon_type " ] , value [ " category " ] , value [ " highend " ] ) ;
2019-11-02 09:53:22 +01:00
}
2019-10-02 22:26:56 +02:00
_update_options_menu ( ) ;
2019-08-09 21:51:48 +02:00
}
2019-08-25 12:06:16 +02:00
String VisualShaderEditor : : _get_description ( int p_idx ) {
2020-02-12 16:39:19 +01:00
return add_options [ p_idx ] . description ;
2019-08-25 09:33:18 +02:00
}
2018-07-14 23:15:42 +02:00
void VisualShaderEditor : : _update_options_menu ( ) {
2019-02-22 18:38:58 +01:00
node_desc - > set_text ( " " ) ;
2024-08-31 19:23:34 +02:00
highend_label - > set_visible ( false ) ;
2020-12-14 19:37:30 +01:00
members_dialog - > get_ok_button ( ) - > set_disabled ( true ) ;
2019-02-22 18:38:58 +01:00
members - > clear ( ) ;
TreeItem * root = members - > create_item ( ) ;
String filter = node_filter - > get_text ( ) . strip_edges ( ) ;
2020-12-15 13:04:21 +01:00
bool use_filter = ! filter . is_empty ( ) ;
2019-02-22 18:38:58 +01:00
2019-04-14 23:23:22 +02:00
bool is_first_item = true ;
2019-02-22 18:38:58 +01:00
2023-08-13 02:33:39 +02:00
Color unsupported_color = get_theme_color ( SNAME ( " error_color " ) , EditorStringName ( Editor ) ) ;
Color supported_color = get_theme_color ( SNAME ( " warning_color " ) , EditorStringName ( Editor ) ) ;
2019-07-12 16:36:23 +02:00
2022-10-18 16:43:37 +02:00
static bool low_driver = GLOBAL_GET ( " rendering/renderer/rendering_method " ) = = " gl_compatibility " ;
2019-07-12 16:36:23 +02:00
2022-05-13 15:04:37 +02:00
HashMap < String , TreeItem * > folders ;
2020-02-14 13:11:55 +01:00
2019-05-01 16:04:39 +02:00
int current_func = - 1 ;
if ( ! visual_shader . is_null ( ) ) {
current_func = visual_shader - > get_mode ( ) ;
}
2020-02-14 13:11:55 +01:00
Vector < AddOption > custom_options ;
Vector < AddOption > embedded_options ;
2019-02-22 18:38:58 +01:00
2021-07-13 07:52:52 +02:00
static Vector < String > type_filter_exceptions ;
if ( type_filter_exceptions . is_empty ( ) ) {
type_filter_exceptions . append ( " VisualShaderNodeExpression " ) ;
2024-05-07 16:48:03 +02:00
type_filter_exceptions . append ( " VisualShaderNodeReroute " ) ;
2021-07-13 07:52:52 +02:00
}
2020-02-14 13:11:55 +01:00
for ( int i = 0 ; i < add_options . size ( ) ; i + + ) {
2024-05-06 10:26:10 +02:00
if ( ! use_filter | | add_options [ i ] . name . containsn ( filter ) ) {
2021-07-13 07:52:52 +02:00
// port type filtering
if ( members_output_port_type ! = VisualShaderNode : : PORT_TYPE_MAX | | members_input_port_type ! = VisualShaderNode : : PORT_TYPE_MAX ) {
Ref < VisualShaderNode > vsn ;
int check_result = 0 ;
if ( ! add_options [ i ] . is_custom ) {
vsn = Ref < VisualShaderNode > ( Object : : cast_to < VisualShaderNode > ( ClassDB : : instantiate ( add_options [ i ] . type ) ) ) ;
if ( ! vsn . is_valid ( ) ) {
continue ;
}
if ( type_filter_exceptions . has ( add_options [ i ] . type ) ) {
check_result = 1 ;
}
Ref < VisualShaderNodeInput > input = Object : : cast_to < VisualShaderNodeInput > ( vsn . ptr ( ) ) ;
if ( input . is_valid ( ) ) {
input - > set_shader_mode ( visual_shader - > get_mode ( ) ) ;
input - > set_shader_type ( visual_shader - > get_shader_type ( ) ) ;
2023-12-28 23:44:23 +01:00
if ( ! add_options [ i ] . ops . is_empty ( ) & & add_options [ i ] . ops [ 0 ] . is_string ( ) ) {
2022-01-28 12:36:35 +01:00
input - > set_input_name ( ( String ) add_options [ i ] . ops [ 0 ] ) ;
}
2021-07-13 07:52:52 +02:00
}
Ref < VisualShaderNodeExpression > expression = Object : : cast_to < VisualShaderNodeExpression > ( vsn . ptr ( ) ) ;
if ( expression . is_valid ( ) ) {
if ( members_input_port_type = = VisualShaderNode : : PORT_TYPE_SAMPLER ) {
check_result = - 1 ; // expressions creates a port with required type automatically (except for sampler output)
}
}
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameterRef > parameter_ref = Object : : cast_to < VisualShaderNodeParameterRef > ( vsn . ptr ( ) ) ;
2024-01-19 05:32:44 +01:00
if ( parameter_ref . is_valid ( ) & & parameter_ref - > is_shader_valid ( ) ) {
2021-07-13 07:52:52 +02:00
check_result = - 1 ;
if ( members_input_port_type ! = VisualShaderNode : : PORT_TYPE_MAX ) {
2022-08-27 11:22:43 +02:00
for ( int j = 0 ; j < parameter_ref - > get_parameters_count ( ) ; j + + ) {
if ( visual_shader - > is_port_types_compatible ( parameter_ref - > get_port_type_by_index ( j ) , members_input_port_type ) ) {
2021-07-13 07:52:52 +02:00
check_result = 1 ;
break ;
}
}
}
}
} else {
check_result = 1 ;
}
if ( members_output_port_type ! = VisualShaderNode : : PORT_TYPE_MAX ) {
if ( check_result = = 0 ) {
for ( int j = 0 ; j < vsn - > get_input_port_count ( ) ; j + + ) {
if ( visual_shader - > is_port_types_compatible ( vsn - > get_input_port_type ( j ) , members_output_port_type ) ) {
check_result = 1 ;
break ;
}
}
}
if ( check_result ! = 1 ) {
continue ;
}
}
if ( members_input_port_type ! = VisualShaderNode : : PORT_TYPE_MAX ) {
if ( check_result = = 0 ) {
for ( int j = 0 ; j < vsn - > get_output_port_count ( ) ; j + + ) {
if ( visual_shader - > is_port_types_compatible ( vsn - > get_output_port_type ( j ) , members_input_port_type ) ) {
check_result = 1 ;
break ;
}
}
}
if ( check_result ! = 1 ) {
continue ;
}
}
}
2020-02-14 13:11:55 +01:00
if ( ( add_options [ i ] . func ! = current_func & & add_options [ i ] . func ! = - 1 ) | | ! _is_available ( add_options [ i ] . mode ) ) {
2019-08-08 20:42:53 +02:00
continue ;
2019-02-22 18:38:58 +01:00
}
2020-02-14 13:11:55 +01:00
const_cast < AddOption & > ( add_options [ i ] ) . temp_idx = i ; // save valid id
if ( add_options [ i ] . is_custom ) {
custom_options . push_back ( add_options [ i ] ) ;
2019-02-22 18:38:58 +01:00
} else {
2020-02-14 13:11:55 +01:00
embedded_options . push_back ( add_options [ i ] ) ;
2019-08-08 20:42:53 +02:00
}
2020-02-14 13:11:55 +01:00
}
}
Vector < AddOption > options ;
SortArray < AddOption , _OptionComparator > sorter ;
sorter . sort ( custom_options . ptrw ( ) , custom_options . size ( ) ) ;
options . append_array ( custom_options ) ;
options . append_array ( embedded_options ) ;
for ( int i = 0 ; i < options . size ( ) ; i + + ) {
String path = options [ i ] . category ;
Vector < String > subfolders = path . split ( " / " ) ;
2020-04-02 01:20:12 +02:00
TreeItem * category = nullptr ;
2020-02-14 13:11:55 +01:00
if ( ! folders . has ( path ) ) {
category = root ;
String path_temp = " " ;
for ( int j = 0 ; j < subfolders . size ( ) ; j + + ) {
path_temp + = subfolders [ j ] ;
if ( ! folders . has ( path_temp ) ) {
category = members - > create_item ( category ) ;
category - > set_selectable ( 0 , false ) ;
category - > set_collapsed ( ! use_filter ) ;
category - > set_text ( 0 , subfolders [ j ] ) ;
folders . insert ( path_temp , category ) ;
} else {
category = folders [ path_temp ] ;
2019-08-08 20:42:53 +02:00
}
2019-02-22 18:38:58 +01:00
}
2020-02-14 13:11:55 +01:00
} else {
category = folders [ path ] ;
}
2019-02-22 18:38:58 +01:00
2020-02-14 13:11:55 +01:00
TreeItem * item = members - > create_item ( category ) ;
2020-05-14 16:41:43 +02:00
if ( options [ i ] . highend & & low_driver ) {
2020-02-14 13:11:55 +01:00
item - > set_custom_color ( 0 , unsupported_color ) ;
2020-05-14 16:41:43 +02:00
} else if ( options [ i ] . highend ) {
2020-02-14 13:11:55 +01:00
item - > set_custom_color ( 0 , supported_color ) ;
2020-05-14 16:41:43 +02:00
}
2020-02-14 13:11:55 +01:00
item - > set_text ( 0 , options [ i ] . name ) ;
if ( is_first_item & & use_filter ) {
item - > select ( 0 ) ;
node_desc - > set_text ( options [ i ] . description ) ;
is_first_item = false ;
2024-08-31 19:23:34 +02:00
members_dialog - > get_ok_button ( ) - > set_disabled ( false ) ;
2020-02-14 13:11:55 +01:00
}
switch ( options [ i ] . return_type ) {
case VisualShaderNode : : PORT_TYPE_SCALAR :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " float " ) ) ) ;
2020-02-14 13:11:55 +01:00
break ;
2020-02-25 15:50:49 +01:00
case VisualShaderNode : : PORT_TYPE_SCALAR_INT :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " int " ) ) ) ;
2020-02-25 15:50:49 +01:00
break ;
2022-12-27 18:49:11 +01:00
case VisualShaderNode : : PORT_TYPE_SCALAR_UINT :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " uint " ) ) ) ;
2022-12-27 18:49:11 +01:00
break ;
2022-02-01 09:32:01 +01:00
case VisualShaderNode : : PORT_TYPE_VECTOR_2D :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " Vector2 " ) ) ) ;
2022-02-01 09:32:01 +01:00
break ;
2022-02-06 18:15:28 +01:00
case VisualShaderNode : : PORT_TYPE_VECTOR_3D :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " Vector3 " ) ) ) ;
2020-02-14 13:11:55 +01:00
break ;
2022-04-12 19:09:29 +02:00
case VisualShaderNode : : PORT_TYPE_VECTOR_4D :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " Vector4 " ) ) ) ;
2022-04-12 19:09:29 +02:00
break ;
2020-02-14 13:11:55 +01:00
case VisualShaderNode : : PORT_TYPE_BOOLEAN :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " bool " ) ) ) ;
2020-02-14 13:11:55 +01:00
break ;
case VisualShaderNode : : PORT_TYPE_TRANSFORM :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " Transform3D " ) ) ) ;
2020-02-14 13:11:55 +01:00
break ;
case VisualShaderNode : : PORT_TYPE_SAMPLER :
2023-08-13 02:33:39 +02:00
item - > set_icon ( 0 , get_editor_theme_icon ( SNAME ( " ImageTexture " ) ) ) ;
2020-02-14 13:11:55 +01:00
break ;
default :
break ;
2018-07-14 23:15:42 +02:00
}
2020-02-14 13:11:55 +01:00
item - > set_meta ( " id " , options [ i ] . temp_idx ) ;
2018-07-14 23:15:42 +02:00
}
}
2020-09-12 10:01:48 +02:00
void VisualShaderEditor : : _set_mode ( int p_which ) {
2021-04-17 19:16:03 +02:00
if ( p_which = = VisualShader : : MODE_SKY ) {
2020-09-15 09:57:40 +02:00
edit_type_standard - > set_visible ( false ) ;
2021-04-17 19:16:03 +02:00
edit_type_particles - > set_visible ( false ) ;
edit_type_sky - > set_visible ( true ) ;
2021-10-29 15:42:33 +02:00
edit_type_fog - > set_visible ( false ) ;
2021-04-17 19:16:03 +02:00
edit_type = edit_type_sky ;
2020-09-15 09:57:40 +02:00
custom_mode_box - > set_visible ( false ) ;
2022-01-09 15:02:13 +01:00
varying_button - > hide ( ) ;
2021-04-17 19:16:03 +02:00
mode = MODE_FLAGS_SKY ;
2021-10-29 15:42:33 +02:00
} else if ( p_which = = VisualShader : : MODE_FOG ) {
edit_type_standard - > set_visible ( false ) ;
edit_type_particles - > set_visible ( false ) ;
edit_type_sky - > set_visible ( false ) ;
edit_type_fog - > set_visible ( true ) ;
edit_type = edit_type_fog ;
custom_mode_box - > set_visible ( false ) ;
2022-01-09 15:02:13 +01:00
varying_button - > hide ( ) ;
2021-10-29 15:42:33 +02:00
mode = MODE_FLAGS_FOG ;
2021-04-17 19:16:03 +02:00
} else if ( p_which = = VisualShader : : MODE_PARTICLES ) {
2020-09-15 09:57:40 +02:00
edit_type_standard - > set_visible ( false ) ;
2020-09-12 10:01:48 +02:00
edit_type_particles - > set_visible ( true ) ;
2021-04-17 19:16:03 +02:00
edit_type_sky - > set_visible ( false ) ;
2021-10-29 15:42:33 +02:00
edit_type_fog - > set_visible ( false ) ;
2020-09-12 10:01:48 +02:00
edit_type = edit_type_particles ;
2020-09-15 09:57:40 +02:00
if ( ( edit_type - > get_selected ( ) + 3 ) > VisualShader : : TYPE_PROCESS ) {
custom_mode_box - > set_visible ( false ) ;
} else {
custom_mode_box - > set_visible ( true ) ;
}
2022-01-09 15:02:13 +01:00
varying_button - > hide ( ) ;
2021-04-17 19:16:03 +02:00
mode = MODE_FLAGS_PARTICLES ;
2020-09-12 10:01:48 +02:00
} else {
edit_type_particles - > set_visible ( false ) ;
2020-09-15 09:57:40 +02:00
edit_type_standard - > set_visible ( true ) ;
2021-04-17 19:16:03 +02:00
edit_type_sky - > set_visible ( false ) ;
2021-10-29 15:42:33 +02:00
edit_type_fog - > set_visible ( false ) ;
2020-09-15 09:57:40 +02:00
edit_type = edit_type_standard ;
custom_mode_box - > set_visible ( false ) ;
2022-01-09 15:02:13 +01:00
varying_button - > show ( ) ;
2021-04-17 19:16:03 +02:00
mode = MODE_FLAGS_SPATIAL_CANVASITEM ;
2020-09-12 10:01:48 +02:00
}
visual_shader - > set_shader_type ( get_current_shader_type ( ) ) ;
}
2018-07-14 23:15:42 +02:00
Size2 VisualShaderEditor : : get_minimum_size ( ) const {
return Size2 ( 10 , 200 ) ;
}
2023-08-09 18:31:15 +02:00
void VisualShaderEditor : : _draw_color_over_button ( Object * p_obj , Color p_color ) {
Button * button = Object : : cast_to < Button > ( p_obj ) ;
2020-05-14 16:41:43 +02:00
if ( ! button ) {
2018-07-14 23:15:42 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
2024-05-13 16:56:03 +02:00
Ref < StyleBox > normal = get_theme_stylebox ( CoreStringName ( normal ) , SNAME ( " Button " ) ) ;
2018-07-14 23:15:42 +02:00
button - > draw_rect ( Rect2 ( normal - > get_offset ( ) , button - > get_size ( ) - normal - > get_minimum_size ( ) ) , p_color ) ;
}
2022-08-27 11:22:43 +02:00
void VisualShaderEditor : : _update_parameters ( bool p_update_refs ) {
VisualShaderNodeParameterRef : : clear_parameters ( visual_shader - > get_rid ( ) ) ;
2020-07-28 10:02:57 +02:00
for ( int t = 0 ; t < VisualShader : : TYPE_MAX ; t + + ) {
Vector < int > tnodes = visual_shader - > get_node_list ( ( VisualShader : : Type ) t ) ;
for ( int i = 0 ; i < tnodes . size ( ) ; i + + ) {
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( ( VisualShader : : Type ) t , tnodes [ i ] ) ;
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameter > parameter = vsnode ;
if ( parameter . is_valid ( ) ) {
Ref < VisualShaderNodeFloatParameter > float_parameter = vsnode ;
Ref < VisualShaderNodeIntParameter > int_parameter = vsnode ;
2022-12-27 18:49:11 +01:00
Ref < VisualShaderNodeUIntParameter > uint_parameter = vsnode ;
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeVec2Parameter > vec2_parameter = vsnode ;
Ref < VisualShaderNodeVec3Parameter > vec3_parameter = vsnode ;
Ref < VisualShaderNodeVec4Parameter > vec4_parameter = vsnode ;
Ref < VisualShaderNodeColorParameter > color_parameter = vsnode ;
Ref < VisualShaderNodeBooleanParameter > boolean_parameter = vsnode ;
Ref < VisualShaderNodeTransformParameter > transform_parameter = vsnode ;
VisualShaderNodeParameterRef : : ParameterType parameter_type ;
if ( float_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_FLOAT ;
} else if ( int_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_INT ;
2022-12-27 18:49:11 +01:00
} else if ( uint_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_UINT ;
2022-08-27 11:22:43 +02:00
} else if ( boolean_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_BOOLEAN ;
} else if ( vec2_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_VECTOR2 ;
} else if ( vec3_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_VECTOR3 ;
} else if ( vec4_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_VECTOR4 ;
} else if ( transform_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_TRANSFORM ;
} else if ( color_parameter . is_valid ( ) ) {
parameter_type = VisualShaderNodeParameterRef : : PARAMETER_TYPE_COLOR ;
2020-07-28 10:02:57 +02:00
} else {
2022-08-27 11:22:43 +02:00
parameter_type = VisualShaderNodeParameterRef : : UNIFORM_TYPE_SAMPLER ;
2020-07-28 10:02:57 +02:00
}
2022-08-27 11:22:43 +02:00
VisualShaderNodeParameterRef : : add_parameter ( visual_shader - > get_rid ( ) , parameter - > get_parameter_name ( ) , parameter_type ) ;
2020-07-28 10:02:57 +02:00
}
}
}
2020-09-21 13:32:59 +02:00
if ( p_update_refs ) {
2022-08-27 11:22:43 +02:00
graph_plugin - > update_parameter_refs ( ) ;
2020-09-21 13:32:59 +02:00
}
}
2022-08-27 11:22:43 +02:00
void VisualShaderEditor : : _update_parameter_refs ( HashSet < String > & p_deleted_names ) {
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-09-21 13:32:59 +02:00
for ( int i = 0 ; i < VisualShader : : TYPE_MAX ; i + + ) {
VisualShader : : Type type = VisualShader : : Type ( i ) ;
Vector < int > nodes = visual_shader - > get_node_list ( type ) ;
for ( int j = 0 ; j < nodes . size ( ) ; j + + ) {
if ( j > 0 ) {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameterRef > ref = visual_shader - > get_node ( type , nodes [ j ] ) ;
2020-09-21 13:32:59 +02:00
if ( ref . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
if ( p_deleted_names . has ( ref - > get_parameter_name ( ) ) ) {
undo_redo - > add_do_method ( ref . ptr ( ) , " set_parameter_name " , " [None] " ) ;
undo_redo - > add_undo_method ( ref . ptr ( ) , " set_parameter_name " , ref - > get_parameter_name ( ) ) ;
2020-09-21 13:32:59 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , VisualShader : : Type ( i ) , nodes [ j ] ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , VisualShader : : Type ( i ) , nodes [ j ] ) ;
}
}
}
}
}
2020-09-10 07:31:07 +02:00
}
2020-07-28 10:02:57 +02:00
2020-09-10 07:31:07 +02:00
void VisualShaderEditor : : _update_graph ( ) {
if ( updating ) {
return ;
}
2018-07-14 23:15:42 +02:00
2020-09-10 07:31:07 +02:00
if ( visual_shader . is_null ( ) ) {
return ;
}
2018-07-14 23:15:42 +02:00
2023-07-10 17:26:02 +02:00
graph - > set_scroll_offset ( visual_shader - > get_graph_offset ( ) * EDSCALE ) ;
2018-07-14 23:15:42 +02:00
2020-09-10 07:31:07 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
2020-09-10 07:31:07 +02:00
graph - > clear_connections ( ) ;
2023-08-09 18:31:15 +02:00
// Remove all nodes.
2020-09-10 07:31:07 +02:00
for ( int i = 0 ; i < graph - > get_child_count ( ) ; i + + ) {
2023-08-09 18:31:15 +02:00
if ( Object : : cast_to < GraphElement > ( graph - > get_child ( i ) ) ) {
2020-09-10 07:31:07 +02:00
Node * node = graph - > get_child ( i ) ;
graph - > remove_child ( node ) ;
memdelete ( node ) ;
i - - ;
2018-07-14 23:15:42 +02:00
}
2020-09-10 07:31:07 +02:00
}
2019-04-24 10:23:01 +02:00
2022-09-29 11:53:28 +02:00
List < VisualShader : : Connection > node_connections ;
visual_shader - > get_node_connections ( type , & node_connections ) ;
graph_plugin - > set_connections ( node_connections ) ;
2019-05-12 14:09:39 +02:00
2020-09-10 07:31:07 +02:00
Vector < int > nodes = visual_shader - > get_node_list ( type ) ;
2019-05-12 14:09:39 +02:00
2022-08-27 11:22:43 +02:00
_update_parameters ( false ) ;
2022-01-09 15:02:13 +01:00
_update_varyings ( ) ;
2019-05-12 14:09:39 +02:00
2020-09-10 07:31:07 +02:00
graph_plugin - > clear_links ( ) ;
2022-08-29 11:04:31 +02:00
graph_plugin - > update_theme ( ) ;
2019-05-12 14:09:39 +02:00
2020-09-10 07:31:07 +02:00
for ( int n_i = 0 ; n_i < nodes . size ( ) ; n_i + + ) {
2024-02-07 02:37:26 +01:00
// Update frame related stuff later since we need to have all nodes in the graph.
graph_plugin - > add_node ( type , nodes [ n_i ] , false , false ) ;
2018-07-14 23:15:42 +02:00
}
2022-09-29 11:53:28 +02:00
for ( const VisualShader : : Connection & E : node_connections ) {
2021-07-16 05:45:57 +02:00
int from = E . from_node ;
int from_idx = E . from_port ;
int to = E . to_node ;
int to_idx = E . to_port ;
2018-07-14 23:15:42 +02:00
graph - > connect_node ( itos ( from ) , from_idx , itos ( to ) , to_idx ) ;
}
2021-01-25 15:37:05 +01:00
2024-02-07 02:37:26 +01:00
// Attach nodes to frames.
for ( int node_id : nodes ) {
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , node_id ) ;
ERR_CONTINUE_MSG ( vsnode . is_null ( ) , " Node is null. " ) ;
if ( vsnode - > get_frame ( ) ! = - 1 ) {
int frame_name = vsnode - > get_frame ( ) ;
graph - > attach_graph_element_to_frame ( itos ( node_id ) , itos ( frame_name ) ) ;
}
}
2022-10-18 16:43:37 +02:00
float graph_minimap_opacity = EDITOR_GET ( " editors/visual_editors/minimap_opacity " ) ;
2021-01-25 15:37:05 +01:00
graph - > set_minimap_opacity ( graph_minimap_opacity ) ;
2022-10-18 16:43:37 +02:00
float graph_lines_curvature = EDITOR_GET ( " editors/visual_editors/lines_curvature " ) ;
2022-05-30 15:38:13 +02:00
graph - > set_connection_lines_curvature ( graph_lines_curvature ) ;
2018-07-14 23:15:42 +02:00
}
2020-09-07 09:28:13 +02:00
VisualShader : : Type VisualShaderEditor : : get_current_shader_type ( ) const {
VisualShader : : Type type ;
2021-04-17 19:16:03 +02:00
if ( mode & MODE_FLAGS_PARTICLES ) {
2020-09-15 09:57:40 +02:00
type = VisualShader : : Type ( edit_type - > get_selected ( ) + 3 + ( custom_mode_enabled ? 3 : 0 ) ) ;
2021-04-17 19:16:03 +02:00
} else if ( mode & MODE_FLAGS_SKY ) {
2020-09-15 09:57:40 +02:00
type = VisualShader : : Type ( edit_type - > get_selected ( ) + 8 ) ;
2021-10-29 15:42:33 +02:00
} else if ( mode & MODE_FLAGS_FOG ) {
type = VisualShader : : Type ( edit_type - > get_selected ( ) + 9 ) ;
2020-09-07 09:28:13 +02:00
} else {
type = VisualShader : : Type ( edit_type - > get_selected ( ) ) ;
}
return type ;
}
2019-05-12 14:09:39 +02:00
void VisualShaderEditor : : _add_input_port ( int p_node , int p_port , int p_port_type , const String & p_name ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeExpression > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Add Input Port " ) ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > add_do_method ( node . ptr ( ) , " add_input_port " , p_port , p_port_type , p_name ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " remove_input_port " , p_port ) ;
2020-09-22 21:54:30 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _add_output_port ( int p_node , int p_port , int p_port_type , const String & p_name ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Add Output Port " ) ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > add_do_method ( node . ptr ( ) , " add_output_port " , p_port , p_port_type , p_name ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " remove_output_port " , p_port ) ;
2020-09-22 21:54:30 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _change_input_port_type ( int p_type , int p_node , int p_port ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Change Input Port Type " ) ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > add_do_method ( node . ptr ( ) , " set_input_port_type " , p_port , p_type ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_input_port_type " , p_port , node - > get_input_port_type ( p_port ) ) ;
2020-09-22 21:54:30 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _change_output_port_type ( int p_type , int p_node , int p_port ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Change Output Port Type " ) ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > add_do_method ( node . ptr ( ) , " set_output_port_type " , p_port , p_type ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_output_port_type " , p_port , node - > get_output_port_type ( p_port ) ) ;
2020-09-22 21:54:30 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
2020-12-02 10:49:46 +01:00
void VisualShaderEditor : : _change_input_port_name ( const String & p_text , Object * p_line_edit , int p_node_id , int p_port_id ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > node = visual_shader - > get_node ( type , p_node_id ) ;
ERR_FAIL_COND ( ! node . is_valid ( ) ) ;
2020-12-02 10:49:46 +01:00
String prev_name = node - > get_input_port_name ( p_port_id ) ;
if ( prev_name = = p_text ) {
return ;
}
LineEdit * line_edit = Object : : cast_to < LineEdit > ( p_line_edit ) ;
2023-09-09 17:24:40 +02:00
ERR_FAIL_NULL ( line_edit ) ;
2020-12-02 10:49:46 +01:00
String validated_name = visual_shader - > validate_port_name ( p_text , node . ptr ( ) , p_port_id , false ) ;
2021-12-09 10:42:46 +01:00
if ( validated_name . is_empty ( ) | | prev_name = = validated_name ) {
2020-12-02 10:49:46 +01:00
line_edit - > set_text ( node - > get_input_port_name ( p_port_id ) ) ;
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Change Input Port Name " ) ) ;
2020-12-02 10:49:46 +01:00
undo_redo - > add_do_method ( node . ptr ( ) , " set_input_port_name " , p_port_id , validated_name ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > add_undo_method ( node . ptr ( ) , " set_input_port_name " , p_port_id , node - > get_input_port_name ( p_port_id ) ) ;
undo_redo - > commit_action ( ) ;
}
2020-12-02 10:49:46 +01:00
void VisualShaderEditor : : _change_output_port_name ( const String & p_text , Object * p_line_edit , int p_node_id , int p_port_id ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > node = visual_shader - > get_node ( type , p_node_id ) ;
ERR_FAIL_COND ( ! node . is_valid ( ) ) ;
2020-12-02 10:49:46 +01:00
String prev_name = node - > get_output_port_name ( p_port_id ) ;
if ( prev_name = = p_text ) {
return ;
}
LineEdit * line_edit = Object : : cast_to < LineEdit > ( p_line_edit ) ;
2023-09-09 17:24:40 +02:00
ERR_FAIL_NULL ( line_edit ) ;
2020-12-02 10:49:46 +01:00
String validated_name = visual_shader - > validate_port_name ( p_text , node . ptr ( ) , p_port_id , true ) ;
2021-12-09 10:42:46 +01:00
if ( validated_name . is_empty ( ) | | prev_name = = validated_name ) {
2020-12-02 10:49:46 +01:00
line_edit - > set_text ( node - > get_output_port_name ( p_port_id ) ) ;
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Change Output Port Name " ) ) ;
2020-12-02 10:49:46 +01:00
undo_redo - > add_do_method ( node . ptr ( ) , " set_output_port_name " , p_port_id , validated_name ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_output_port_name " , p_port_id , prev_name ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
2020-12-20 16:45:53 +01:00
void VisualShaderEditor : : _expand_output_port ( int p_node , int p_port , bool p_expand ) {
VisualShader : : Type type = get_current_shader_type ( ) ;
Ref < VisualShaderNode > node = visual_shader - > get_node ( type , p_node ) ;
ERR_FAIL_COND ( ! node . is_valid ( ) ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-12-20 16:45:53 +01:00
if ( p_expand ) {
undo_redo - > create_action ( TTR ( " Expand Output Port " ) ) ;
} else {
undo_redo - > create_action ( TTR ( " Shrink Output Port " ) ) ;
}
undo_redo - > add_do_method ( node . ptr ( ) , " _set_output_port_expanded " , p_port , p_expand ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " _set_output_port_expanded " , p_port , ! p_expand ) ;
int type_size = 0 ;
2022-02-01 09:32:01 +01:00
switch ( node - > get_output_port_type ( p_port ) ) {
case VisualShaderNode : : PORT_TYPE_VECTOR_2D : {
type_size = 2 ;
} break ;
2022-02-06 18:15:28 +01:00
case VisualShaderNode : : PORT_TYPE_VECTOR_3D : {
2022-02-01 09:32:01 +01:00
type_size = 3 ;
} break ;
2022-04-12 19:09:29 +02:00
case VisualShaderNode : : PORT_TYPE_VECTOR_4D : {
type_size = 4 ;
} break ;
2022-02-01 09:32:01 +01:00
default :
break ;
2020-12-20 16:45:53 +01:00
}
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2022-09-29 11:53:28 +02:00
int cn_from_node = E . from_node ;
int cn_from_port = E . from_port ;
int cn_to_node = E . to_node ;
int cn_to_port = E . to_port ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
if ( cn_from_node = = p_node ) {
2020-12-20 16:45:53 +01:00
if ( p_expand ) {
2022-09-29 11:53:28 +02:00
if ( cn_from_port > p_port ) { // reconnect ports after expanded ports
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port + type_size , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port + type_size , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port + type_size , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port + type_size , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
}
} else {
2022-09-29 11:53:28 +02:00
if ( cn_from_port > p_port + type_size ) { // reconnect ports after expanded ports
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port - type_size , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port - type_size , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port - type_size , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port - type_size , cn_to_node , cn_to_port ) ;
} else if ( cn_from_port > p_port ) { // disconnect component ports
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
2022-09-29 11:53:28 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
2020-12-20 16:45:53 +01:00
}
}
}
}
int preview_port = node - > get_output_port_for_preview ( ) ;
if ( p_expand ) {
if ( preview_port > p_port ) {
undo_redo - > add_do_method ( node . ptr ( ) , " set_output_port_for_preview " , preview_port + type_size ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_output_port_for_preview " , preview_port ) ;
}
} else {
if ( preview_port > p_port + type_size ) {
undo_redo - > add_do_method ( node . ptr ( ) , " set_output_port_for_preview " , preview_port - type_size ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_output_port_for_preview " , preview_port ) ;
}
}
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > commit_action ( ) ;
}
2019-05-12 14:09:39 +02:00
void VisualShaderEditor : : _remove_input_port ( int p_node , int p_port ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Remove Input Port " ) ) ;
2019-05-12 14:09:39 +02:00
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2022-09-29 11:53:28 +02:00
int cn_from_node = E . from_node ;
int cn_from_port = E . from_port ;
int cn_to_node = E . to_node ;
int cn_to_port = E . to_port ;
if ( cn_to_node = = p_node ) {
if ( cn_to_port = = p_port ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
} else if ( cn_to_port > p_port ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port - 1 ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port - 1 ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port - 1 ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port - 1 ) ;
2019-05-12 14:09:39 +02:00
}
}
}
undo_redo - > add_do_method ( node . ptr ( ) , " remove_input_port " , p_port ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " add_input_port " , p_port , ( int ) node - > get_input_port_type ( p_port ) , node - > get_input_port_name ( p_port ) ) ;
2020-09-22 21:54:30 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _remove_output_port ( int p_node , int p_port ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Remove Output Port " ) ) ;
2019-05-12 14:09:39 +02:00
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2022-09-29 11:53:28 +02:00
int cn_from_node = E . from_node ;
int cn_from_port = E . from_port ;
int cn_to_node = E . to_node ;
int cn_to_port = E . to_port ;
if ( cn_from_node = = p_node ) {
if ( cn_from_port = = p_port ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
} else if ( cn_from_port > p_port ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes_forced " , type , cn_from_node , cn_from_port - 1 , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port - 1 , cn_to_node , cn_to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port - 1 , cn_to_node , cn_to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port - 1 , cn_to_node , cn_to_port ) ;
2019-05-12 14:09:39 +02:00
}
}
}
2020-12-01 14:24:06 +01:00
int preview_port = node - > get_output_port_for_preview ( ) ;
if ( preview_port ! = - 1 ) {
if ( preview_port = = p_port ) {
undo_redo - > add_do_method ( node . ptr ( ) , " set_output_port_for_preview " , - 1 ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_output_port_for_preview " , preview_port ) ;
} else if ( preview_port > p_port ) {
undo_redo - > add_do_method ( node . ptr ( ) , " set_output_port_for_preview " , preview_port - 1 ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_output_port_for_preview " , preview_port ) ;
}
}
2019-05-12 14:09:39 +02:00
undo_redo - > add_do_method ( node . ptr ( ) , " remove_output_port " , p_port ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " add_output_port " , p_port , ( int ) node - > get_output_port_type ( p_port ) , node - > get_output_port_name ( p_port ) ) ;
2020-09-22 21:54:30 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
2023-08-09 18:31:15 +02:00
void VisualShaderEditor : : _expression_focus_out ( Object * p_code_edit , int p_node ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeExpression > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2023-08-09 18:31:15 +02:00
CodeEdit * expression_box = Object : : cast_to < CodeEdit > ( p_code_edit ) ;
2019-05-22 06:39:08 +02:00
2020-05-14 16:41:43 +02:00
if ( node - > get_expression ( ) = = expression_box - > get_text ( ) ) {
2019-05-22 06:39:08 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2019-05-12 14:09:39 +02:00
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > create_action ( TTR ( " Set VisualShader Expression " ) ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > add_do_method ( node . ptr ( ) , " set_expression " , expression_box - > get_text ( ) ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_expression " , node - > get_expression ( ) ) ;
2020-10-15 13:47:27 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " set_expression " , type , p_node , expression_box - > get_text ( ) ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " set_expression " , type , p_node , node - > get_expression ( ) ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _set_node_size ( int p_type , int p_node , const Vector2 & p_size ) {
2020-10-15 13:47:27 +02:00
VisualShader : : Type type = VisualShader : : Type ( p_type ) ;
2020-10-04 11:11:58 +02:00
Ref < VisualShaderNodeResizableBase > node = visual_shader - > get_node ( type , p_node ) ;
2019-05-12 14:09:39 +02:00
if ( node . is_null ( ) ) {
return ;
}
2020-10-04 11:11:58 +02:00
Size2 size = p_size ;
if ( ! node - > is_allow_v_resize ( ) ) {
size . y = 0 ;
2019-05-12 14:09:39 +02:00
}
2020-10-04 11:11:58 +02:00
node - > set_size ( size ) ;
2019-05-12 14:09:39 +02:00
2020-10-15 13:47:27 +02:00
if ( get_current_shader_type ( ) = = type ) {
Ref < VisualShaderNodeExpression > expression_node = Object : : cast_to < VisualShaderNodeExpression > ( node . ptr ( ) ) ;
Control * text_box = nullptr ;
if ( ! expression_node . is_null ( ) ) {
2021-04-24 22:33:50 +02:00
text_box = expression_node - > is_ctrl_pressed ( 0 ) ;
2020-10-15 13:47:27 +02:00
if ( text_box ) {
text_box - > set_custom_minimum_size ( Size2 ( 0 , 0 ) ) ;
}
}
2019-05-12 14:09:39 +02:00
2023-08-09 18:31:15 +02:00
GraphElement * graph_element = nullptr ;
2019-05-12 14:09:39 +02:00
Node * node2 = graph - > get_node ( itos ( p_node ) ) ;
2023-08-09 18:31:15 +02:00
graph_element = Object : : cast_to < GraphElement > ( node2 ) ;
if ( ! graph_element ) {
2019-05-12 14:09:39 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2019-05-12 14:09:39 +02:00
2024-02-07 02:37:26 +01:00
graph_element - > set_size ( size ) ;
2019-05-12 14:09:39 +02:00
}
2024-02-07 02:37:26 +01:00
// Update all parent frames.
graph_plugin - > update_frames ( type , p_node ) ;
2019-05-12 14:09:39 +02:00
}
2024-02-07 02:37:26 +01:00
// Called once after the node was resized.
2019-05-12 14:09:39 +02:00
void VisualShaderEditor : : _node_resized ( const Vector2 & p_new_size , int p_type , int p_node ) {
2020-10-04 11:11:58 +02:00
Ref < VisualShaderNodeResizableBase > node = visual_shader - > get_node ( VisualShader : : Type ( p_type ) , p_node ) ;
2019-05-12 14:09:39 +02:00
if ( node . is_null ( ) ) {
return ;
}
2024-02-07 02:37:26 +01:00
GraphElement * graph_element = Object : : cast_to < GraphElement > ( graph - > get_node ( itos ( p_node ) ) ) ;
if ( ! graph_element ) {
return ;
2023-08-09 18:31:15 +02:00
}
2024-02-07 02:37:26 +01:00
Size2 size = graph_element - > get_size ( ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2024-02-07 02:37:26 +01:00
undo_redo - > create_action ( TTR ( " Resize VisualShader Node " ) ) ;
undo_redo - > add_do_method ( this , " _set_node_size " , p_type , p_node , size ) ;
2019-05-12 14:09:39 +02:00
undo_redo - > add_undo_method ( this , " _set_node_size " , p_type , p_node , node - > get_size ( ) ) ;
undo_redo - > commit_action ( ) ;
}
2018-07-14 23:15:42 +02:00
void VisualShaderEditor : : _preview_select_port ( int p_node , int p_port ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2018-07-14 23:15:42 +02:00
Ref < VisualShaderNode > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
2020-09-10 07:31:07 +02:00
int prev_port = node - > get_output_port_for_preview ( ) ;
2018-07-14 23:15:42 +02:00
if ( node - > get_output_port_for_preview ( ) = = p_port ) {
p_port = - 1 ; //toggle it
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-09-09 16:40:27 +02:00
undo_redo - > create_action ( p_port = = - 1 ? TTR ( " Hide Port Preview " ) : TTR ( " Show Port Preview " ) ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > add_do_method ( node . ptr ( ) , " set_output_port_for_preview " , p_port ) ;
2020-09-10 07:31:07 +02:00
undo_redo - > add_undo_method ( node . ptr ( ) , " set_output_port_for_preview " , prev_port ) ;
2020-11-26 12:25:35 +01:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , p_node ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_title_popup_show ( const Point2 & p_position , int p_node_id ) {
2021-02-21 09:33:55 +01:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2024-02-07 02:37:26 +01:00
Ref < VisualShaderNodeFrame > node = visual_shader - > get_node ( type , p_node_id ) ;
2021-02-21 09:33:55 +01:00
if ( node . is_null ( ) ) {
return ;
}
2024-02-07 02:37:26 +01:00
frame_title_change_edit - > set_text ( node - > get_title ( ) ) ;
frame_title_change_popup - > set_meta ( " id " , p_node_id ) ;
frame_title_change_popup - > set_position ( p_position ) ;
2024-09-04 01:52:07 +02:00
frame_title_change_popup - > popup ( ) ;
2024-02-07 02:37:26 +01:00
// Select current text.
frame_title_change_edit - > grab_focus ( ) ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_title_text_changed ( const String & p_new_text ) {
frame_title_change_edit - > reset_size ( ) ;
frame_title_change_popup - > reset_size ( ) ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_title_text_submitted ( const String & p_new_text ) {
frame_title_change_popup - > hide ( ) ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_title_popup_focus_out ( ) {
frame_title_change_popup - > hide ( ) ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_title_popup_hide ( ) {
int node_id = ( int ) frame_title_change_popup - > get_meta ( " id " , - 1 ) ;
ERR_FAIL_COND ( node_id = = - 1 ) ;
2021-02-21 09:33:55 +01:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2024-02-07 02:37:26 +01:00
Ref < VisualShaderNodeFrame > node = visual_shader - > get_node ( type , node_id ) ;
2021-02-21 09:33:55 +01:00
ERR_FAIL_COND ( node . is_null ( ) ) ;
2024-02-07 02:37:26 +01:00
if ( node - > get_title ( ) = = frame_title_change_edit - > get_text ( ) ) {
2021-02-21 09:33:55 +01:00
return ; // nothing changed - ignored
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2024-02-07 02:37:26 +01:00
undo_redo - > create_action ( TTR ( " Set Frame Title " ) ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " set_title " , frame_title_change_edit - > get_text ( ) ) ;
2021-02-21 09:33:55 +01:00
undo_redo - > add_undo_method ( node . ptr ( ) , " set_title " , node - > get_title ( ) ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , node_id ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , node_id ) ;
undo_redo - > commit_action ( ) ;
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_color_enabled_changed ( int p_node_id ) {
int item_index = popup_menu - > get_item_index ( NodeMenuOptions : : ENABLE_FRAME_COLOR ) ;
// The new state.
bool tint_color_enabled = ! popup_menu - > is_item_checked ( item_index ) ;
popup_menu - > set_item_checked ( item_index , tint_color_enabled ) ;
int frame_color_item_idx = popup_menu - > get_item_index ( NodeMenuOptions : : SET_FRAME_COLOR ) ;
if ( tint_color_enabled & & frame_color_item_idx = = - 1 ) {
popup_menu - > add_item ( TTR ( " Set Tint Color " ) , NodeMenuOptions : : SET_FRAME_COLOR ) ;
} else if ( ! tint_color_enabled & & frame_color_item_idx ! = - 1 ) {
popup_menu - > remove_item ( frame_color_item_idx ) ;
}
2021-02-21 09:33:55 +01:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2024-02-07 02:37:26 +01:00
Ref < VisualShaderNodeFrame > node = visual_shader - > get_node ( type , p_node_id ) ;
ERR_FAIL_COND ( node . is_null ( ) ) ;
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
undo_redo - > create_action ( TTR ( " Toggle Frame Color " ) ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " set_tint_color_enabled " , tint_color_enabled ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_tint_color_enabled " , node - > is_tint_color_enabled ( ) ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " set_frame_color_enabled " , ( int ) type , p_node_id , tint_color_enabled ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " set_frame_color_enabled " , ( int ) type , p_node_id , node - > is_tint_color_enabled ( ) ) ;
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _frame_color_popup_show ( const Point2 & p_position , int p_node_id ) {
VisualShader : : Type type = get_current_shader_type ( ) ;
Ref < VisualShaderNodeFrame > node = visual_shader - > get_node ( type , p_node_id ) ;
2021-02-21 09:33:55 +01:00
if ( node . is_null ( ) ) {
return ;
}
2024-02-07 02:37:26 +01:00
frame_tint_color_picker - > set_pick_color ( node - > get_tint_color ( ) ) ;
frame_tint_color_pick_popup - > set_meta ( " id " , p_node_id ) ;
frame_tint_color_pick_popup - > set_position ( p_position ) ;
frame_tint_color_pick_popup - > popup ( ) ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_color_confirm ( ) {
frame_tint_color_pick_popup - > hide ( ) ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_color_changed ( const Color & p_color ) {
ERR_FAIL_COND ( ! frame_tint_color_pick_popup - > has_meta ( " id " ) ) ;
int node_id = ( int ) frame_tint_color_pick_popup - > get_meta ( " id " ) ;
VisualShader : : Type type = get_current_shader_type ( ) ;
Ref < VisualShaderNodeFrame > node = visual_shader - > get_node ( type , node_id ) ;
ERR_FAIL_COND ( node . is_null ( ) ) ;
node - > set_tint_color ( p_color ) ;
graph_plugin - > set_frame_color ( type , node_id , p_color ) ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _frame_color_popup_hide ( ) {
ERR_FAIL_COND ( ! frame_tint_color_pick_popup - > has_meta ( " id " ) ) ;
int node_id = ( int ) frame_tint_color_pick_popup - > get_meta ( " id " ) ;
2021-02-21 09:33:55 +01:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2024-02-07 02:37:26 +01:00
Ref < VisualShaderNodeFrame > node = visual_shader - > get_node ( type , node_id ) ;
2021-02-21 09:33:55 +01:00
ERR_FAIL_COND ( node . is_null ( ) ) ;
2024-02-07 02:37:26 +01:00
if ( node - > get_tint_color ( ) = = frame_tint_color_picker - > get_pick_color ( ) ) {
return ;
2021-02-21 09:33:55 +01:00
}
2024-02-07 02:37:26 +01:00
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2024-02-07 02:37:26 +01:00
undo_redo - > create_action ( TTR ( " Set Frame Color " ) ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " set_tint_color " , frame_tint_color_picker - > get_pick_color ( ) ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_tint_color " , node - > get_tint_color ( ) ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " set_frame_color " , ( int ) type , node_id , frame_tint_color_picker - > get_pick_color ( ) ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " set_frame_color " , ( int ) type , node_id , node - > get_tint_color ( ) ) ;
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _frame_autoshrink_enabled_changed ( int p_node_id ) {
int item_index = popup_menu - > get_item_index ( NodeMenuOptions : : ENABLE_FRAME_AUTOSHRINK ) ;
bool autoshrink_enabled = popup_menu - > is_item_checked ( item_index ) ;
popup_menu - > set_item_checked ( item_index , ! autoshrink_enabled ) ;
VisualShader : : Type type = get_current_shader_type ( ) ;
Ref < VisualShaderNodeFrame > node = visual_shader - > get_node ( type , p_node_id ) ;
ERR_FAIL_COND ( node . is_null ( ) ) ;
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
undo_redo - > create_action ( TTR ( " Toggle Auto Shrink " ) ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " set_autoshrink_enabled " , ! autoshrink_enabled ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_autoshrink_enabled " , autoshrink_enabled ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " set_frame_autoshrink_enabled " , ( int ) type , p_node_id , ! autoshrink_enabled ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " set_frame_autoshrink_enabled " , ( int ) type , p_node_id , autoshrink_enabled ) ;
2021-02-21 09:33:55 +01:00
undo_redo - > commit_action ( ) ;
2024-02-07 02:37:26 +01:00
popup_menu - > hide ( ) ;
2021-02-21 09:33:55 +01:00
}
2022-08-27 11:22:43 +02:00
void VisualShaderEditor : : _parameter_line_edit_changed ( const String & p_text , int p_node_id ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2018-07-14 23:15:42 +02:00
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameter > node = visual_shader - > get_node ( type , p_node_id ) ;
2018-07-14 23:15:42 +02:00
ERR_FAIL_COND ( ! node . is_valid ( ) ) ;
2022-08-27 11:22:43 +02:00
String validated_name = visual_shader - > validate_parameter_name ( p_text , node ) ;
2018-07-14 23:15:42 +02:00
2022-08-27 11:22:43 +02:00
if ( validated_name = = node - > get_parameter_name ( ) ) {
2020-09-22 08:54:59 +02:00
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2022-08-27 11:22:43 +02:00
undo_redo - > create_action ( TTR ( " Set Parameter Name " ) ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " set_parameter_name " , validated_name ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " set_parameter_name " , node - > get_parameter_name ( ) ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " set_parameter_name " , type , p_node_id , validated_name ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " set_parameter_name " , type , p_node_id , node - > get_parameter_name ( ) ) ;
2021-08-12 15:55:14 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node_deferred " , type , p_node_id ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node_deferred " , type , p_node_id ) ;
2020-09-21 13:32:59 +02:00
2022-08-27 11:22:43 +02:00
undo_redo - > add_do_method ( this , " _update_parameters " , true ) ;
undo_redo - > add_undo_method ( this , " _update_parameters " , true ) ;
2020-09-21 13:32:59 +02:00
2022-05-19 17:00:06 +02:00
HashSet < String > changed_names ;
2022-08-27 11:22:43 +02:00
changed_names . insert ( node - > get_parameter_name ( ) ) ;
_update_parameter_refs ( changed_names ) ;
2018-07-14 23:15:42 +02:00
2020-09-21 13:32:59 +02:00
undo_redo - > commit_action ( ) ;
2018-07-14 23:15:42 +02:00
}
2022-08-27 11:22:43 +02:00
void VisualShaderEditor : : _parameter_line_edit_focus_out ( Object * line_edit , int p_node_id ) {
_parameter_line_edit_changed ( Object : : cast_to < LineEdit > ( line_edit ) - > get_text ( ) , p_node_id ) ;
2018-07-14 23:15:42 +02:00
}
2019-05-12 14:09:39 +02:00
void VisualShaderEditor : : _port_name_focus_out ( Object * line_edit , int p_node_id , int p_port_id , bool p_output ) {
if ( ! p_output ) {
2020-12-02 10:49:46 +01:00
_change_input_port_name ( Object : : cast_to < LineEdit > ( line_edit ) - > get_text ( ) , line_edit , p_node_id , p_port_id ) ;
2019-05-12 14:09:39 +02:00
} else {
2020-12-02 10:49:46 +01:00
_change_output_port_name ( Object : : cast_to < LineEdit > ( line_edit ) - > get_text ( ) , line_edit , p_node_id , p_port_id ) ;
2019-05-12 14:09:39 +02:00
}
}
2022-08-01 20:01:48 +02:00
void VisualShaderEditor : : _port_edited ( const StringName & p_property , const Variant & p_value , const String & p_field , bool p_changing ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2018-07-14 23:15:42 +02:00
Ref < VisualShaderNode > vsn = visual_shader - > get_node ( type , editing_node ) ;
ERR_FAIL_COND ( ! vsn . is_valid ( ) ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2019-02-21 20:41:01 +01:00
undo_redo - > create_action ( TTR ( " Set Input Default Port " ) ) ;
2021-04-12 12:47:37 +02:00
Ref < VisualShaderNodeCustom > custom = Object : : cast_to < VisualShaderNodeCustom > ( vsn . ptr ( ) ) ;
if ( custom . is_valid ( ) ) {
2022-08-01 20:01:48 +02:00
undo_redo - > add_do_method ( custom . ptr ( ) , " _set_input_port_default_value " , editing_port , p_value ) ;
2021-04-12 12:47:37 +02:00
undo_redo - > add_undo_method ( custom . ptr ( ) , " _set_input_port_default_value " , editing_port , vsn - > get_input_port_default_value ( editing_port ) ) ;
} else {
2022-08-01 20:01:48 +02:00
undo_redo - > add_do_method ( vsn . ptr ( ) , " set_input_port_default_value " , editing_port , p_value ) ;
2021-04-12 12:47:37 +02:00
undo_redo - > add_undo_method ( vsn . ptr ( ) , " set_input_port_default_value " , editing_port , vsn - > get_input_port_default_value ( editing_port ) ) ;
}
2022-08-01 20:01:48 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " set_input_port_default_value " , type , editing_node , editing_port , p_value ) ;
2020-09-10 07:31:07 +02:00
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " set_input_port_default_value " , type , editing_node , editing_port , vsn - > get_input_port_default_value ( editing_port ) ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _edit_port_default_input ( Object * p_button , int p_node , int p_port ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2022-08-01 20:01:48 +02:00
Ref < VisualShaderNode > vs_node = visual_shader - > get_node ( type , p_node ) ;
Variant value = vs_node - > get_input_port_default_value ( p_port ) ;
edited_property_holder - > set_edited_property ( value ) ;
2024-03-05 13:27:33 +01:00
editing_node = p_node ;
editing_port = p_port ;
2022-08-01 20:01:48 +02:00
if ( property_editor ) {
property_editor - > disconnect ( " property_changed " , callable_mp ( this , & VisualShaderEditor : : _port_edited ) ) ;
property_editor_popup - > remove_child ( property_editor ) ;
}
2018-07-14 23:15:42 +02:00
2022-08-01 20:01:48 +02:00
// TODO: Define these properties with actual PropertyInfo and feed it to the property editor widget.
2024-03-05 13:27:33 +01:00
property_editor = EditorInspector : : instantiate_property_editor ( edited_property_holder . ptr ( ) , value . get_type ( ) , " edited_property " , PROPERTY_HINT_NONE , " " , PROPERTY_USAGE_NONE , true ) ;
ERR_FAIL_NULL_MSG ( property_editor , " Failed to create property editor for type: " + Variant : : get_type_name ( value . get_type ( ) ) ) ;
// Determine the best size for the popup based on the property type.
// This is done here, since the property editors are also used in the inspector where they have different layout requirements, so we can't just change their default minimum size.
Size2 popup_pref_size ;
switch ( value . get_type ( ) ) {
case Variant : : VECTOR3 :
case Variant : : BASIS :
popup_pref_size . width = 320 ;
break ;
case Variant : : VECTOR4 :
case Variant : : QUATERNION :
case Variant : : PLANE :
case Variant : : TRANSFORM2D :
case Variant : : TRANSFORM3D :
case Variant : : PROJECTION :
popup_pref_size . width = 480 ;
break ;
default :
popup_pref_size . width = 180 ;
break ;
}
property_editor_popup - > set_min_size ( popup_pref_size ) ;
2022-08-01 20:01:48 +02:00
2024-03-05 13:27:33 +01:00
property_editor - > set_object_and_property ( edited_property_holder . ptr ( ) , " edited_property " ) ;
property_editor - > update_property ( ) ;
property_editor - > set_name_split_ratio ( 0 ) ;
property_editor_popup - > add_child ( property_editor ) ;
2022-08-01 20:01:48 +02:00
2024-03-05 13:27:33 +01:00
property_editor - > connect ( " property_changed " , callable_mp ( this , & VisualShaderEditor : : _port_edited ) ) ;
2018-07-14 23:15:42 +02:00
2024-03-05 13:27:33 +01:00
Button * button = Object : : cast_to < Button > ( p_button ) ;
if ( button ) {
property_editor_popup - > set_position ( button - > get_screen_position ( ) + Vector2 ( 0 , button - > get_size ( ) . height ) * graph - > get_zoom ( ) ) ;
}
property_editor_popup - > reset_size ( ) ;
if ( button ) {
property_editor_popup - > popup ( ) ;
} else {
property_editor_popup - > popup_centered_ratio ( ) ;
}
property_editor - > select ( 0 ) ; // Focus the first focusable control.
2018-07-14 23:15:42 +02:00
}
2023-09-15 12:27:12 +02:00
void VisualShaderEditor : : _set_custom_node_option ( int p_index , int p_node , int p_op ) {
VisualShader : : Type type = get_current_shader_type ( ) ;
Ref < VisualShaderNodeCustom > node = visual_shader - > get_node ( type , p_node ) ;
if ( node . is_null ( ) ) {
return ;
}
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
undo_redo - > create_action ( TTR ( " Set Custom Node Option " ) ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " _set_option_index " , p_op , p_index ) ;
undo_redo - > add_undo_method ( node . ptr ( ) , " _set_option_index " , p_op , node - > get_option_index ( p_op ) ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , p_node ) ;
undo_redo - > commit_action ( ) ;
}
2022-01-28 12:36:35 +01:00
void VisualShaderEditor : : _setup_node ( VisualShaderNode * p_node , const Vector < Variant > & p_ops ) {
// INPUT
{
VisualShaderNodeInput * input = Object : : cast_to < VisualShaderNodeInput > ( p_node ) ;
if ( input ) {
2023-12-28 23:44:23 +01:00
ERR_FAIL_COND ( ! p_ops [ 0 ] . is_string ( ) ) ;
2022-01-28 12:36:35 +01:00
input - > set_input_name ( ( String ) p_ops [ 0 ] ) ;
return ;
}
}
// FLOAT_CONST
{
VisualShaderNodeFloatConstant * float_const = Object : : cast_to < VisualShaderNodeFloatConstant > ( p_node ) ;
if ( float_const ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : FLOAT ) ;
float_const - > set_constant ( ( float ) p_ops [ 0 ] ) ;
return ;
}
}
2021-01-18 10:23:04 +01:00
// FLOAT_OP
{
VisualShaderNodeFloatOp * floatOp = Object : : cast_to < VisualShaderNodeFloatOp > ( p_node ) ;
2018-07-14 23:15:42 +02:00
2021-01-18 10:23:04 +01:00
if ( floatOp ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
floatOp - > set_operator ( ( VisualShaderNodeFloatOp : : Operator ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2018-07-14 23:15:42 +02:00
2021-01-18 10:23:04 +01:00
// FLOAT_FUNC
{
VisualShaderNodeFloatFunc * floatFunc = Object : : cast_to < VisualShaderNodeFloatFunc > ( p_node ) ;
2019-08-09 21:51:48 +02:00
2021-01-18 10:23:04 +01:00
if ( floatFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
floatFunc - > set_function ( ( VisualShaderNodeFloatFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
// VECTOR_OP
{
VisualShaderNodeVectorOp * vecOp = Object : : cast_to < VisualShaderNodeVectorOp > ( p_node ) ;
2019-05-19 15:27:00 +02:00
2021-01-18 10:23:04 +01:00
if ( vecOp ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
2022-02-01 09:32:01 +01:00
ERR_FAIL_COND ( p_ops [ 1 ] . get_type ( ) ! = Variant : : INT ) ;
2022-01-28 12:36:35 +01:00
vecOp - > set_operator ( ( VisualShaderNodeVectorOp : : Operator ) ( int ) p_ops [ 0 ] ) ;
2022-02-01 09:32:01 +01:00
vecOp - > set_op_type ( ( VisualShaderNodeVectorOp : : OpType ) ( int ) p_ops [ 1 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
2019-05-19 15:27:00 +02:00
}
2021-01-18 10:23:04 +01:00
}
2019-05-19 15:27:00 +02:00
2021-01-18 10:23:04 +01:00
// VECTOR_FUNC
{
VisualShaderNodeVectorFunc * vecFunc = Object : : cast_to < VisualShaderNodeVectorFunc > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( vecFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
2022-02-01 09:32:01 +01:00
ERR_FAIL_COND ( p_ops [ 1 ] . get_type ( ) ! = Variant : : INT ) ;
2022-01-28 12:36:35 +01:00
vecFunc - > set_function ( ( VisualShaderNodeVectorFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
2022-02-01 09:32:01 +01:00
vecFunc - > set_op_type ( ( VisualShaderNodeVectorFunc : : OpType ) ( int ) p_ops [ 1 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
// COLOR_OP
{
VisualShaderNodeColorOp * colorOp = Object : : cast_to < VisualShaderNodeColorOp > ( p_node ) ;
2019-07-08 09:05:33 +02:00
2021-01-18 10:23:04 +01:00
if ( colorOp ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
colorOp - > set_operator ( ( VisualShaderNodeColorOp : : Operator ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-07-08 09:05:33 +02:00
2021-01-18 10:23:04 +01:00
// COLOR_FUNC
{
VisualShaderNodeColorFunc * colorFunc = Object : : cast_to < VisualShaderNodeColorFunc > ( p_node ) ;
2019-07-08 09:05:33 +02:00
2021-01-18 10:23:04 +01:00
if ( colorFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
colorFunc - > set_function ( ( VisualShaderNodeColorFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-07-08 09:05:33 +02:00
2021-01-18 10:23:04 +01:00
// INT_OP
{
VisualShaderNodeIntOp * intOp = Object : : cast_to < VisualShaderNodeIntOp > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( intOp ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
intOp - > set_operator ( ( VisualShaderNodeIntOp : : Operator ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
// INT_FUNC
{
VisualShaderNodeIntFunc * intFunc = Object : : cast_to < VisualShaderNodeIntFunc > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( intFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
intFunc - > set_function ( ( VisualShaderNodeIntFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2022-12-27 18:49:11 +01:00
// UINT_OP
{
VisualShaderNodeUIntOp * uintOp = Object : : cast_to < VisualShaderNodeUIntOp > ( p_node ) ;
if ( uintOp ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
uintOp - > set_operator ( ( VisualShaderNodeUIntOp : : Operator ) ( int ) p_ops [ 0 ] ) ;
return ;
}
}
// UINT_FUNC
{
VisualShaderNodeUIntFunc * uintFunc = Object : : cast_to < VisualShaderNodeUIntFunc > ( p_node ) ;
if ( uintFunc ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
uintFunc - > set_function ( ( VisualShaderNodeUIntFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
return ;
}
}
2021-08-11 18:08:37 +02:00
// TRANSFORM_OP
{
VisualShaderNodeTransformOp * matOp = Object : : cast_to < VisualShaderNodeTransformOp > ( p_node ) ;
if ( matOp ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
matOp - > set_operator ( ( VisualShaderNodeTransformOp : : Operator ) ( int ) p_ops [ 0 ] ) ;
2021-08-11 18:08:37 +02:00
return ;
}
}
2021-01-18 10:23:04 +01:00
// TRANSFORM_FUNC
{
VisualShaderNodeTransformFunc * matFunc = Object : : cast_to < VisualShaderNodeTransformFunc > ( p_node ) ;
2020-02-25 15:50:49 +01:00
2021-01-18 10:23:04 +01:00
if ( matFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
matFunc - > set_function ( ( VisualShaderNodeTransformFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2020-02-25 15:50:49 +01:00
2022-02-01 09:32:01 +01:00
// VECTOR_COMPOSE
{
VisualShaderNodeVectorCompose * vecCompose = Object : : cast_to < VisualShaderNodeVectorCompose > ( p_node ) ;
if ( vecCompose ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
vecCompose - > set_op_type ( ( VisualShaderNodeVectorCompose : : OpType ) ( int ) p_ops [ 0 ] ) ;
return ;
}
}
// VECTOR_DECOMPOSE
{
VisualShaderNodeVectorDecompose * vecDecompose = Object : : cast_to < VisualShaderNodeVectorDecompose > ( p_node ) ;
if ( vecDecompose ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
vecDecompose - > set_op_type ( ( VisualShaderNodeVectorDecompose : : OpType ) ( int ) p_ops [ 0 ] ) ;
return ;
}
}
// UV_FUNC
2021-06-05 14:53:53 +02:00
{
VisualShaderNodeUVFunc * uvFunc = Object : : cast_to < VisualShaderNodeUVFunc > ( p_node ) ;
if ( uvFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
uvFunc - > set_function ( ( VisualShaderNodeUVFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
2021-06-05 14:53:53 +02:00
return ;
}
}
2021-01-18 10:23:04 +01:00
// IS
{
VisualShaderNodeIs * is = Object : : cast_to < VisualShaderNodeIs > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( is ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
is - > set_function ( ( VisualShaderNodeIs : : Function ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
// COMPARE
{
VisualShaderNodeCompare * cmp = Object : : cast_to < VisualShaderNodeCompare > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( cmp ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
cmp - > set_function ( ( VisualShaderNodeCompare : : Function ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2020-02-25 15:50:49 +01:00
2022-02-01 09:32:01 +01:00
// DISTANCE
{
VisualShaderNodeVectorDistance * dist = Object : : cast_to < VisualShaderNodeVectorDistance > ( p_node ) ;
if ( dist ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
dist - > set_op_type ( ( VisualShaderNodeVectorDistance : : OpType ) ( int ) p_ops [ 0 ] ) ;
return ;
}
}
2021-01-18 10:23:04 +01:00
// DERIVATIVE
{
2022-01-28 19:36:10 +01:00
VisualShaderNodeDerivativeFunc * derFunc = Object : : cast_to < VisualShaderNodeDerivativeFunc > ( p_node ) ;
2020-02-25 15:50:49 +01:00
2022-01-28 19:36:10 +01:00
if ( derFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
2022-01-28 19:36:10 +01:00
ERR_FAIL_COND ( p_ops [ 1 ] . get_type ( ) ! = Variant : : INT ) ;
derFunc - > set_function ( ( VisualShaderNodeDerivativeFunc : : Function ) ( int ) p_ops [ 0 ] ) ;
derFunc - > set_op_type ( ( VisualShaderNodeDerivativeFunc : : OpType ) ( int ) p_ops [ 1 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
// MIX
{
VisualShaderNodeMix * mix = Object : : cast_to < VisualShaderNodeMix > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( mix ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
mix - > set_op_type ( ( VisualShaderNodeMix : : OpType ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
// CLAMP
{
VisualShaderNodeClamp * clampFunc = Object : : cast_to < VisualShaderNodeClamp > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( clampFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
clampFunc - > set_op_type ( ( VisualShaderNodeClamp : : OpType ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
// SWITCH
{
VisualShaderNodeSwitch * switchFunc = Object : : cast_to < VisualShaderNodeSwitch > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( switchFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
switchFunc - > set_op_type ( ( VisualShaderNodeSwitch : : OpType ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2019-02-22 18:38:58 +01:00
2022-02-01 09:32:01 +01:00
// FACEFORWARD
{
VisualShaderNodeFaceForward * faceForward = Object : : cast_to < VisualShaderNodeFaceForward > ( p_node ) ;
if ( faceForward ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
faceForward - > set_op_type ( ( VisualShaderNodeFaceForward : : OpType ) ( int ) p_ops [ 0 ] ) ;
return ;
}
}
// LENGTH
{
VisualShaderNodeVectorLen * length = Object : : cast_to < VisualShaderNodeVectorLen > ( p_node ) ;
if ( length ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
length - > set_op_type ( ( VisualShaderNodeVectorLen : : OpType ) ( int ) p_ops [ 0 ] ) ;
return ;
}
}
2021-01-18 10:23:04 +01:00
// SMOOTHSTEP
{
VisualShaderNodeSmoothStep * smoothStepFunc = Object : : cast_to < VisualShaderNodeSmoothStep > ( p_node ) ;
2019-02-22 18:38:58 +01:00
2021-01-18 10:23:04 +01:00
if ( smoothStepFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
smoothStepFunc - > set_op_type ( ( VisualShaderNodeSmoothStep : : OpType ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
2020-02-14 21:09:53 +01:00
2021-01-18 10:23:04 +01:00
// STEP
{
VisualShaderNodeStep * stepFunc = Object : : cast_to < VisualShaderNodeStep > ( p_node ) ;
2020-02-14 21:09:53 +01:00
2021-01-18 10:23:04 +01:00
if ( stepFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
stepFunc - > set_op_type ( ( VisualShaderNodeStep : : OpType ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
return ;
}
}
// MULTIPLY_ADD
{
VisualShaderNodeMultiplyAdd * fmaFunc = Object : : cast_to < VisualShaderNodeMultiplyAdd > ( p_node ) ;
if ( fmaFunc ) {
2022-01-28 12:36:35 +01:00
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
fmaFunc - > set_op_type ( ( VisualShaderNodeMultiplyAdd : : OpType ) ( int ) p_ops [ 0 ] ) ;
2021-01-18 10:23:04 +01:00
}
}
2024-09-22 02:22:51 +02:00
// REMAP
{
VisualShaderNodeRemap * remap_func = Object : : cast_to < VisualShaderNodeRemap > ( p_node ) ;
if ( remap_func ) {
ERR_FAIL_COND ( p_ops [ 0 ] . get_type ( ) ! = Variant : : INT ) ;
remap_func - > set_op_type ( ( VisualShaderNodeRemap : : OpType ) ( int ) p_ops [ 0 ] ) ;
}
}
2021-01-18 10:23:04 +01:00
}
2024-02-15 17:25:58 +01:00
void VisualShaderEditor : : _add_node ( int p_idx , const Vector < Variant > & p_ops , const String & p_resource_path , int p_node_idx ) {
2021-05-22 05:28:24 +02:00
ERR_FAIL_INDEX ( p_idx , add_options . size ( ) ) ;
2021-01-18 10:23:04 +01:00
2021-07-12 09:34:40 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2021-01-18 10:23:04 +01:00
Ref < VisualShaderNode > vsnode ;
bool is_custom = add_options [ p_idx ] . is_custom ;
2020-02-14 21:09:53 +01:00
2021-12-09 10:42:46 +01:00
if ( ! is_custom & & ! add_options [ p_idx ] . type . is_empty ( ) ) {
2021-06-18 00:03:09 +02:00
VisualShaderNode * vsn = Object : : cast_to < VisualShaderNode > ( ClassDB : : instantiate ( add_options [ p_idx ] . type ) ) ;
2023-09-09 17:24:40 +02:00
ERR_FAIL_NULL ( vsn ) ;
2022-01-28 12:36:35 +01:00
if ( ! p_ops . is_empty ( ) ) {
_setup_node ( vsn , p_ops ) ;
2019-02-22 18:38:58 +01:00
}
2022-08-27 11:22:43 +02:00
VisualShaderNodeParameterRef * parameter_ref = Object : : cast_to < VisualShaderNodeParameterRef > ( vsn ) ;
if ( parameter_ref & & to_node ! = - 1 & & to_slot ! = - 1 ) {
2021-07-12 09:34:40 +02:00
VisualShaderNode : : PortType input_port_type = visual_shader - > get_node ( type , to_node ) - > get_input_port_type ( to_slot ) ;
bool success = false ;
2022-08-27 11:22:43 +02:00
for ( int i = 0 ; i < parameter_ref - > get_parameters_count ( ) ; i + + ) {
if ( parameter_ref - > get_port_type_by_index ( i ) = = input_port_type ) {
parameter_ref - > set_parameter_name ( parameter_ref - > get_parameter_name_by_index ( i ) ) ;
2021-07-12 09:34:40 +02:00
success = true ;
break ;
}
}
if ( ! success ) {
2022-08-27 11:22:43 +02:00
for ( int i = 0 ; i < parameter_ref - > get_parameters_count ( ) ; i + + ) {
if ( visual_shader - > is_port_types_compatible ( parameter_ref - > get_port_type_by_index ( i ) , input_port_type ) ) {
parameter_ref - > set_parameter_name ( parameter_ref - > get_parameter_name_by_index ( i ) ) ;
2021-07-12 09:34:40 +02:00
break ;
}
}
}
}
2018-07-14 23:15:42 +02:00
vsnode = Ref < VisualShaderNode > ( vsn ) ;
} else {
2023-01-04 12:30:20 +01:00
StringName base_type ;
bool is_native = add_options [ p_idx ] . is_native ;
if ( is_native ) {
base_type = add_options [ p_idx ] . type ;
} else {
ERR_FAIL_COND ( add_options [ p_idx ] . script . is_null ( ) ) ;
base_type = add_options [ p_idx ] . script - > get_instance_base_type ( ) ;
}
2021-06-18 00:03:09 +02:00
VisualShaderNode * vsn = Object : : cast_to < VisualShaderNode > ( ClassDB : : instantiate ( base_type ) ) ;
2023-09-09 17:24:40 +02:00
ERR_FAIL_NULL ( vsn ) ;
2018-07-14 23:15:42 +02:00
vsnode = Ref < VisualShaderNode > ( vsn ) ;
2023-01-04 12:30:20 +01:00
if ( ! is_native ) {
vsnode - > set_script ( add_options [ p_idx ] . script ) ;
}
2023-06-22 09:33:40 +02:00
VisualShaderNodeCustom * custom_node = Object : : cast_to < VisualShaderNodeCustom > ( vsn ) ;
2023-09-09 17:24:40 +02:00
ERR_FAIL_NULL ( custom_node ) ;
2023-09-15 12:27:12 +02:00
custom_node - > update_property_default_values ( ) ;
custom_node - > update_input_port_default_values ( ) ;
custom_node - > update_properties ( ) ;
2018-07-14 23:15:42 +02:00
}
2022-01-12 08:57:19 +01:00
bool is_texture2d = ( Object : : cast_to < VisualShaderNodeTexture > ( vsnode . ptr ( ) ) ! = nullptr ) ;
bool is_texture3d = ( Object : : cast_to < VisualShaderNodeTexture3D > ( vsnode . ptr ( ) ) ! = nullptr ) ;
bool is_texture2d_array = ( Object : : cast_to < VisualShaderNodeTexture2DArray > ( vsnode . ptr ( ) ) ! = nullptr ) ;
bool is_cubemap = ( Object : : cast_to < VisualShaderNodeCubemap > ( vsnode . ptr ( ) ) ! = nullptr ) ;
bool is_curve = ( Object : : cast_to < VisualShaderNodeCurveTexture > ( vsnode . ptr ( ) ) ! = nullptr ) ;
bool is_curve_xyz = ( Object : : cast_to < VisualShaderNodeCurveXYZTexture > ( vsnode . ptr ( ) ) ! = nullptr ) ;
2022-08-27 11:22:43 +02:00
bool is_parameter = ( Object : : cast_to < VisualShaderNodeParameter > ( vsnode . ptr ( ) ) ! = nullptr ) ;
2024-06-11 10:27:24 +02:00
bool is_mesh_emitter = ( Object : : cast_to < VisualShaderNodeParticleMeshEmitter > ( vsnode . ptr ( ) ) ! = nullptr ) ;
2022-01-12 08:57:19 +01:00
2023-07-10 17:26:02 +02:00
Point2 position = graph - > get_scroll_offset ( ) ;
2019-02-22 18:38:58 +01:00
if ( saved_node_pos_dirty ) {
position + = saved_node_pos ;
} else {
position + = graph - > get_size ( ) * 0.5 ;
position / = EDSCALE ;
}
2021-08-11 09:53:26 +02:00
position / = graph - > get_zoom ( ) ;
2019-02-22 18:38:58 +01:00
saved_node_pos_dirty = false ;
2018-07-14 23:15:42 +02:00
int id_to_use = visual_shader - > get_valid_node_id ( type ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2021-05-22 05:28:24 +02:00
if ( p_resource_path . is_empty ( ) ) {
undo_redo - > create_action ( TTR ( " Add Node to Visual Shader " ) ) ;
} else {
id_to_use + = p_node_idx ;
}
2018-07-14 23:15:42 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " add_node " , type , vsnode , position , id_to_use ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " remove_node " , type , id_to_use ) ;
2024-02-07 02:37:26 +01:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " add_node " , type , id_to_use , false , true ) ;
2023-01-12 12:19:55 +01:00
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " remove_node " , type , id_to_use , false ) ;
2019-05-12 14:09:39 +02:00
VisualShaderNodeExpression * expr = Object : : cast_to < VisualShaderNodeExpression > ( vsnode . ptr ( ) ) ;
if ( expr ) {
2023-01-06 12:20:25 +01:00
expr - > set_size ( Size2 ( 250 * EDSCALE , 150 * EDSCALE ) ) ;
2019-05-12 14:09:39 +02:00
}
2024-02-07 02:37:26 +01:00
Ref < VisualShaderNodeFrame > frame = vsnode ;
if ( frame . is_valid ( ) ) {
frame - > set_size ( Size2 ( 320 * EDSCALE , 180 * EDSCALE ) ) ;
}
2024-05-07 16:48:03 +02:00
Ref < VisualShaderNodeReroute > reroute = vsnode ;
2021-01-16 08:44:38 +01:00
bool created_expression_port = false ;
2024-01-19 11:35:46 +01:00
// A node is inserted in an already present connection.
if ( from_node ! = - 1 & & from_slot ! = - 1 & & to_node ! = - 1 & & to_slot ! = - 1 ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , from_node , from_slot , to_node , to_slot ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , from_node , from_slot , to_node , to_slot ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , from_node , from_slot , to_node , to_slot ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , from_node , from_slot , to_node , to_slot ) ;
}
2024-05-07 16:48:03 +02:00
// Create a connection from the output port of an existing node to the new one.
if ( from_node ! = - 1 & & from_slot ! = - 1 ) {
VisualShaderNode : : PortType output_port_type = visual_shader - > get_node ( type , from_node ) - > get_output_port_type ( from_slot ) ;
if ( expr & & expr - > is_editable ( ) ) {
expr - > add_input_port ( 0 , output_port_type , " input0 " ) ;
created_expression_port = true ;
}
if ( vsnode - > get_input_port_count ( ) > 0 | | created_expression_port ) {
int _to_node = id_to_use ;
if ( created_expression_port ) {
int _to_slot = 0 ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
} else {
int _to_slot = - 1 ;
// Attempting to connect to the default input port or to the first correct port (if it's not found).
for ( int i = 0 ; i < vsnode - > get_input_port_count ( ) ; i + + ) {
if ( visual_shader - > is_port_types_compatible ( output_port_type , vsnode - > get_input_port_type ( i ) ) | | reroute . is_valid ( ) ) {
if ( i = = vsnode - > get_default_input_port ( output_port_type ) ) {
_to_slot = i ;
break ;
} else if ( _to_slot = = - 1 ) {
_to_slot = i ;
}
}
}
if ( _to_slot > = 0 ) {
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , from_node , from_slot , _to_node , _to_slot ) ;
}
}
if ( output_port_type = = VisualShaderNode : : PORT_TYPE_SAMPLER ) {
if ( is_texture2d ) {
2023-07-22 20:16:54 +02:00
undo_redo - > force_fixed_history ( ) ; // vsnode is freshly created and has no path, so history can't be correctly determined.
2024-05-07 16:48:03 +02:00
undo_redo - > add_do_method ( vsnode . ptr ( ) , " set_source " , VisualShaderNodeTexture : : SOURCE_PORT ) ;
}
if ( is_texture3d | | is_texture2d_array ) {
2023-07-22 20:16:54 +02:00
undo_redo - > force_fixed_history ( ) ;
2024-05-07 16:48:03 +02:00
undo_redo - > add_do_method ( vsnode . ptr ( ) , " set_source " , VisualShaderNodeSample3D : : SOURCE_PORT ) ;
}
if ( is_cubemap ) {
2023-07-22 20:16:54 +02:00
undo_redo - > force_fixed_history ( ) ;
2024-05-07 16:48:03 +02:00
undo_redo - > add_do_method ( vsnode . ptr ( ) , " set_source " , VisualShaderNodeCubemap : : SOURCE_PORT ) ;
}
}
}
}
2024-01-19 11:35:46 +01:00
// Create a connection from the new node to an input port of an existing one.
2019-06-26 20:50:38 +02:00
if ( to_node ! = - 1 & & to_slot ! = - 1 ) {
2021-01-16 08:44:38 +01:00
VisualShaderNode : : PortType input_port_type = visual_shader - > get_node ( type , to_node ) - > get_input_port_type ( to_slot ) ;
if ( expr & & expr - > is_editable ( ) & & input_port_type ! = VisualShaderNode : : PORT_TYPE_SAMPLER ) {
2023-01-06 12:20:25 +01:00
expr - > add_output_port ( 0 , input_port_type , " output0 " ) ;
2021-01-16 08:44:38 +01:00
String initial_expression_code ;
switch ( input_port_type ) {
case VisualShaderNode : : PORT_TYPE_SCALAR :
initial_expression_code = " output0 = 1.0; " ;
break ;
case VisualShaderNode : : PORT_TYPE_SCALAR_INT :
initial_expression_code = " output0 = 1; " ;
break ;
2022-12-27 18:49:11 +01:00
case VisualShaderNode : : PORT_TYPE_SCALAR_UINT :
initial_expression_code = " output0 = 1u; " ;
break ;
2022-02-01 09:32:01 +01:00
case VisualShaderNode : : PORT_TYPE_VECTOR_2D :
initial_expression_code = " output0 = vec2(1.0, 1.0); " ;
break ;
2022-02-06 18:15:28 +01:00
case VisualShaderNode : : PORT_TYPE_VECTOR_3D :
2021-01-16 08:44:38 +01:00
initial_expression_code = " output0 = vec3(1.0, 1.0, 1.0); " ;
break ;
2022-04-12 19:09:29 +02:00
case VisualShaderNode : : PORT_TYPE_VECTOR_4D :
initial_expression_code = " output0 = vec4(1.0, 1.0, 1.0, 1.0); " ;
break ;
2021-01-16 08:44:38 +01:00
case VisualShaderNode : : PORT_TYPE_BOOLEAN :
initial_expression_code = " output0 = true; " ;
break ;
case VisualShaderNode : : PORT_TYPE_TRANSFORM :
initial_expression_code = " output0 = mat4(1.0); " ;
break ;
default :
break ;
}
2023-01-06 12:20:25 +01:00
expr - > set_expression ( initial_expression_code ) ;
expr - > set_size ( Size2 ( 500 * EDSCALE , 200 * EDSCALE ) ) ;
2021-01-16 08:44:38 +01:00
created_expression_port = true ;
}
if ( vsnode - > get_output_port_count ( ) > 0 | | created_expression_port ) {
2019-06-26 20:50:38 +02:00
int _from_node = id_to_use ;
2021-01-27 15:27:33 +01:00
if ( created_expression_port ) {
2022-04-07 12:23:40 +02:00
int _from_slot = 0 ;
2019-06-26 20:50:38 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , type , _from_node , _from_slot , to_node , to_slot ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , _from_node , _from_slot , to_node , to_slot ) ;
2020-09-10 07:31:07 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , _from_node , _from_slot , to_node , to_slot ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , _from_node , _from_slot , to_node , to_slot ) ;
2021-01-27 15:27:33 +01:00
} else {
2021-06-17 17:03:07 +02:00
// Need to setting up Input node properly before committing since `is_port_types_compatible` (calling below) is using `mode` and `shader_type`.
VisualShaderNodeInput * input = Object : : cast_to < VisualShaderNodeInput > ( vsnode . ptr ( ) ) ;
if ( input ) {
input - > set_shader_mode ( visual_shader - > get_mode ( ) ) ;
input - > set_shader_type ( visual_shader - > get_shader_type ( ) ) ;
}
2021-01-27 15:27:33 +01:00
// Attempting to connect to the first correct port.
for ( int i = 0 ; i < vsnode - > get_output_port_count ( ) ; i + + ) {
2024-05-07 16:48:03 +02:00
if ( visual_shader - > is_port_types_compatible ( vsnode - > get_output_port_type ( i ) , input_port_type ) | | reroute . is_valid ( ) ) {
2021-01-27 15:27:33 +01:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , type , _from_node , i , to_node , to_slot ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , _from_node , i , to_node , to_slot ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , _from_node , i , to_node , to_slot ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , _from_node , i , to_node , to_slot ) ;
break ;
}
}
2019-06-26 20:50:38 +02:00
}
}
2024-01-19 11:35:46 +01:00
}
2020-11-25 01:03:15 +01:00
_member_cancel ( ) ;
2019-06-26 20:50:38 +02:00
2022-08-27 11:22:43 +02:00
if ( is_parameter ) {
undo_redo - > add_do_method ( this , " _update_parameters " , true ) ;
undo_redo - > add_undo_method ( this , " _update_parameters " , true ) ;
2020-09-21 13:32:59 +02:00
}
2022-01-12 08:57:19 +01:00
if ( is_curve ) {
2023-12-18 15:46:56 +01:00
callable_mp ( graph_plugin . ptr ( ) , & VisualShaderGraphPlugin : : update_curve ) . call_deferred ( id_to_use ) ;
2020-10-04 11:11:58 +02:00
}
2022-01-12 08:57:19 +01:00
if ( is_curve_xyz ) {
2023-12-18 15:46:56 +01:00
callable_mp ( graph_plugin . ptr ( ) , & VisualShaderGraphPlugin : : update_curve_xyz ) . call_deferred ( id_to_use ) ;
2021-07-04 10:56:21 +02:00
}
2021-05-22 05:28:24 +02:00
if ( p_resource_path . is_empty ( ) ) {
undo_redo - > commit_action ( ) ;
} else {
//post-initialization
2022-01-12 08:57:19 +01:00
if ( is_texture2d | | is_texture3d | | is_curve | | is_curve_xyz ) {
2023-07-22 20:16:54 +02:00
undo_redo - > force_fixed_history ( ) ;
2021-05-22 05:28:24 +02:00
undo_redo - > add_do_method ( vsnode . ptr ( ) , " set_texture " , ResourceLoader : : load ( p_resource_path ) ) ;
return ;
}
2022-01-12 08:57:19 +01:00
if ( is_cubemap ) {
2023-07-22 20:16:54 +02:00
undo_redo - > force_fixed_history ( ) ;
2021-05-22 05:28:24 +02:00
undo_redo - > add_do_method ( vsnode . ptr ( ) , " set_cube_map " , ResourceLoader : : load ( p_resource_path ) ) ;
return ;
}
2022-01-12 08:57:19 +01:00
if ( is_texture2d_array ) {
2023-07-22 20:16:54 +02:00
undo_redo - > force_fixed_history ( ) ;
2021-05-22 05:28:24 +02:00
undo_redo - > add_do_method ( vsnode . ptr ( ) , " set_texture_array " , ResourceLoader : : load ( p_resource_path ) ) ;
2024-06-11 10:27:24 +02:00
return ;
}
if ( is_mesh_emitter ) {
undo_redo - > add_do_method ( vsnode . ptr ( ) , " set_mesh " , ResourceLoader : : load ( p_resource_path ) ) ;
return ;
2021-05-22 05:28:24 +02:00
}
}
2018-07-14 23:15:42 +02:00
}
2022-01-09 15:02:13 +01:00
void VisualShaderEditor : : _add_varying ( const String & p_name , VisualShader : : VaryingMode p_mode , VisualShader : : VaryingType p_type ) {
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2022-01-09 15:02:13 +01:00
undo_redo - > create_action ( vformat ( TTR ( " Add Varying to Visual Shader: %s " ) , p_name ) ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " add_varying " , p_name , p_mode , p_type ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " remove_varying " , p_name ) ;
undo_redo - > add_do_method ( this , " _update_varyings " ) ;
undo_redo - > add_undo_method ( this , " _update_varyings " ) ;
for ( int i = 0 ; i < = VisualShader : : TYPE_LIGHT ; i + + ) {
if ( p_mode = = VisualShader : : VARYING_MODE_FRAG_TO_LIGHT & & i = = 0 ) {
continue ;
}
VisualShader : : Type type = VisualShader : : Type ( i ) ;
Vector < int > nodes = visual_shader - > get_node_list ( type ) ;
for ( int j = 0 ; j < nodes . size ( ) ; j + + ) {
int node_id = nodes [ j ] ;
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , node_id ) ;
Ref < VisualShaderNodeVarying > var = vsnode ;
if ( var . is_valid ( ) ) {
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , node_id ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , node_id ) ;
}
}
}
undo_redo - > add_do_method ( this , " _update_varying_tree " ) ;
undo_redo - > add_undo_method ( this , " _update_varying_tree " ) ;
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _remove_varying ( const String & p_name ) {
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2022-01-09 15:02:13 +01:00
undo_redo - > create_action ( vformat ( TTR ( " Remove Varying from Visual Shader: %s " ) , p_name ) ) ;
2022-09-29 11:53:28 +02:00
VisualShader : : VaryingMode var_mode = visual_shader - > get_varying_mode ( p_name ) ;
2022-01-09 15:02:13 +01:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " remove_varying " , p_name ) ;
2022-09-29 11:53:28 +02:00
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " add_varying " , p_name , var_mode , visual_shader - > get_varying_type ( p_name ) ) ;
2022-01-09 15:02:13 +01:00
undo_redo - > add_do_method ( this , " _update_varyings " ) ;
undo_redo - > add_undo_method ( this , " _update_varyings " ) ;
for ( int i = 0 ; i < = VisualShader : : TYPE_LIGHT ; i + + ) {
2022-09-29 11:53:28 +02:00
if ( var_mode = = VisualShader : : VARYING_MODE_FRAG_TO_LIGHT & & i = = 0 ) {
2022-01-09 15:02:13 +01:00
continue ;
}
VisualShader : : Type type = VisualShader : : Type ( i ) ;
Vector < int > nodes = visual_shader - > get_node_list ( type ) ;
for ( int j = 0 ; j < nodes . size ( ) ; j + + ) {
int node_id = nodes [ j ] ;
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , node_id ) ;
Ref < VisualShaderNodeVarying > var = vsnode ;
if ( var . is_valid ( ) ) {
String var_name = var - > get_varying_name ( ) ;
if ( var_name = = p_name ) {
undo_redo - > add_do_method ( var . ptr ( ) , " set_varying_name " , " [None] " ) ;
undo_redo - > add_undo_method ( var . ptr ( ) , " set_varying_name " , var_name ) ;
undo_redo - > add_do_method ( var . ptr ( ) , " set_varying_type " , VisualShader : : VARYING_TYPE_FLOAT ) ;
undo_redo - > add_undo_method ( var . ptr ( ) , " set_varying_type " , var - > get_varying_type ( ) ) ;
}
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type , node_id ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type , node_id ) ;
}
}
2022-09-29 11:53:28 +02:00
List < VisualShader : : Connection > node_connections ;
visual_shader - > get_node_connections ( type , & node_connections ) ;
2022-01-09 15:02:13 +01:00
2022-09-29 11:53:28 +02:00
for ( VisualShader : : Connection & E : node_connections ) {
2022-01-09 15:02:13 +01:00
Ref < VisualShaderNodeVaryingGetter > var_getter = Object : : cast_to < VisualShaderNodeVaryingGetter > ( visual_shader - > get_node ( type , E . from_node ) . ptr ( ) ) ;
if ( var_getter . is_valid ( ) & & E . from_port > 0 ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
}
Ref < VisualShaderNodeVaryingSetter > var_setter = Object : : cast_to < VisualShaderNodeVaryingSetter > ( visual_shader - > get_node ( type , E . to_node ) . ptr ( ) ) ;
if ( var_setter . is_valid ( ) & & E . to_port > 0 ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
}
}
}
undo_redo - > add_do_method ( this , " _update_varying_tree " ) ;
undo_redo - > add_undo_method ( this , " _update_varying_tree " ) ;
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _update_varyings ( ) {
2024-06-16 09:16:52 +02:00
VisualShaderNodeVarying : : clear_varyings ( visual_shader - > get_rid ( ) ) ;
2022-01-09 15:02:13 +01:00
for ( int i = 0 ; i < visual_shader - > get_varyings_count ( ) ; i + + ) {
const VisualShader : : Varying * var = visual_shader - > get_varying_by_index ( i ) ;
if ( var ! = nullptr ) {
2024-06-16 09:16:52 +02:00
VisualShaderNodeVarying : : add_varying ( visual_shader - > get_rid ( ) , var - > name , var - > mode , var - > type ) ;
2022-01-09 15:02:13 +01:00
}
}
}
2018-07-14 23:15:42 +02:00
void VisualShaderEditor : : _node_dragged ( const Vector2 & p_from , const Vector2 & p_to , int p_node ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2020-09-27 13:05:19 +02:00
drag_buffer . push_back ( { type , p_node , p_from , p_to } ) ;
if ( ! drag_dirty ) {
2023-12-18 15:46:56 +01:00
callable_mp ( this , & VisualShaderEditor : : _nodes_dragged ) . call_deferred ( ) ;
2020-09-27 13:05:19 +02:00
}
drag_dirty = true ;
}
void VisualShaderEditor : : _nodes_dragged ( ) {
drag_dirty = false ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2024-02-07 02:37:26 +01:00
if ( frame_node_id_to_link_to = = - 1 ) {
undo_redo - > create_action ( TTR ( " Move VisualShader Node(s) " ) ) ;
} else {
undo_redo - > create_action ( TTR ( " Move and Attach VisualShader Node(s) to parent frame " ) ) ;
}
2020-09-27 13:05:19 +02:00
2021-07-24 15:46:25 +02:00
for ( const DragOp & E : drag_buffer ) {
2021-07-16 05:45:57 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " set_node_position " , E . type , E . node , E . to ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " set_node_position " , E . type , E . node , E . from ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " set_node_position " , E . type , E . node , E . to ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " set_node_position " , E . type , E . node , E . from ) ;
2020-09-27 13:05:19 +02:00
}
2018-07-14 23:15:42 +02:00
2024-02-07 02:37:26 +01:00
for ( const int node_id : nodes_link_to_frame_buffer ) {
VisualShader : : Type type = visual_shader - > get_shader_type ( ) ;
Ref < VisualShaderNode > vs_node = visual_shader - > get_node ( type , node_id ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " attach_node_to_frame " , type , node_id , frame_node_id_to_link_to ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " attach_node_to_frame " , type , node_id , frame_node_id_to_link_to ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " detach_node_from_frame " , type , node_id ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " detach_node_from_frame " , type , node_id ) ;
}
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
2024-01-19 11:35:46 +01:00
_handle_node_drop_on_connection ( ) ;
drag_buffer . clear ( ) ;
2024-02-07 02:37:26 +01:00
nodes_link_to_frame_buffer . clear ( ) ;
frame_node_id_to_link_to = - 1 ;
2018-07-14 23:15:42 +02:00
}
void VisualShaderEditor : : _connection_request ( const String & p_from , int p_from_index , const String & p_to , int p_to_index ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2018-07-14 23:15:42 +02:00
int from = p_from . to_int ( ) ;
int to = p_to . to_int ( ) ;
if ( ! visual_shader - > can_connect_nodes ( type , from , p_from_index , to , p_to_index ) ) {
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2019-02-21 20:41:01 +01:00
undo_redo - > create_action ( TTR ( " Nodes Connected " ) ) ;
2018-09-19 09:30:45 +02:00
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2021-07-16 05:45:57 +02:00
if ( E . to_node = = to & & E . to_port = = p_to_index ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
2018-09-19 09:30:45 +02:00
}
}
2018-07-14 23:15:42 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , type , from , p_from_index , to , p_to_index ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , from , p_from_index , to , p_to_index ) ;
2020-09-10 07:31:07 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , from , p_from_index , to , p_to_index ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , from , p_from_index , to , p_to_index ) ;
2024-05-07 16:48:03 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , from ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , from ) ;
2020-11-26 12:25:35 +01:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , to ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , to ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _disconnection_request ( const String & p_from , int p_from_index , const String & p_to , int p_to_index ) {
graph - > disconnect_node ( p_from , p_from_index , p_to , p_to_index ) ;
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2018-07-14 23:15:42 +02:00
int from = p_from . to_int ( ) ;
int to = p_to . to_int ( ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2019-02-21 20:41:01 +01:00
undo_redo - > create_action ( TTR ( " Nodes Disconnected " ) ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , from , p_from_index , to , p_to_index ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , from , p_from_index , to , p_to_index ) ;
2020-09-10 07:31:07 +02:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , from , p_from_index , to , p_to_index ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , from , p_from_index , to , p_to_index ) ;
2020-11-26 12:25:35 +01:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , to ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , ( int ) type , to ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _connection_to_empty ( const String & p_from , int p_from_slot , const Vector2 & p_release_position ) {
2019-06-26 20:50:38 +02:00
from_node = p_from . to_int ( ) ;
from_slot = p_from_slot ;
2021-07-13 07:52:52 +02:00
VisualShaderNode : : PortType input_port_type = VisualShaderNode : : PORT_TYPE_MAX ;
VisualShaderNode : : PortType output_port_type = VisualShaderNode : : PORT_TYPE_MAX ;
Ref < VisualShaderNode > node = visual_shader - > get_node ( get_current_shader_type ( ) , from_node ) ;
if ( node . is_valid ( ) ) {
output_port_type = node - > get_output_port_type ( from_slot ) ;
}
_show_members_dialog ( true , input_port_type , output_port_type ) ;
2019-06-26 20:50:38 +02:00
}
void VisualShaderEditor : : _connection_from_empty ( const String & p_to , int p_to_slot , const Vector2 & p_release_position ) {
to_node = p_to . to_int ( ) ;
to_slot = p_to_slot ;
2021-07-13 07:52:52 +02:00
VisualShaderNode : : PortType input_port_type = VisualShaderNode : : PORT_TYPE_MAX ;
VisualShaderNode : : PortType output_port_type = VisualShaderNode : : PORT_TYPE_MAX ;
Ref < VisualShaderNode > node = visual_shader - > get_node ( get_current_shader_type ( ) , to_node ) ;
if ( node . is_valid ( ) ) {
input_port_type = node - > get_input_port_type ( to_slot ) ;
}
_show_members_dialog ( true , input_port_type , output_port_type ) ;
2018-07-14 23:15:42 +02:00
}
2024-01-19 11:35:46 +01:00
bool VisualShaderEditor : : _check_node_drop_on_connection ( const Vector2 & p_position , Ref < GraphEdit : : Connection > * r_closest_connection , int * r_from_port , int * r_to_port ) {
VisualShader : : Type shader_type = get_current_shader_type ( ) ;
// Get selected graph node.
Ref < VisualShaderNode > selected_vsnode ;
int selected_node_id = - 1 ;
int selected_node_count = 0 ;
Rect2 selected_node_rect ;
for ( int i = 0 ; i < graph - > get_child_count ( ) ; i + + ) {
GraphNode * graph_node = Object : : cast_to < GraphNode > ( graph - > get_child ( i ) ) ;
if ( graph_node & & graph_node - > is_selected ( ) ) {
selected_node_id = String ( graph_node - > get_name ( ) ) . to_int ( ) ;
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( shader_type , selected_node_id ) ;
2024-02-07 02:37:26 +01:00
if ( ! vsnode - > is_deletable ( ) ) {
2024-01-19 11:35:46 +01:00
continue ;
}
selected_node_count + = 1 ;
Ref < VisualShaderNode > node = visual_shader - > get_node ( shader_type , selected_node_id ) ;
selected_vsnode = node ;
selected_node_rect = graph_node - > get_rect ( ) ;
}
}
// Only a single node - which has both input and output ports but is not connected yet - can be inserted.
if ( selected_node_count ! = 1 | | ! selected_vsnode . is_valid ( ) ) {
return false ;
}
// Check whether the dragged node was dropped over a connection.
List < Ref < GraphEdit : : Connection > > intersecting_connections = graph - > get_connections_intersecting_with_rect ( selected_node_rect ) ;
if ( intersecting_connections . is_empty ( ) ) {
return false ;
}
Ref < GraphEdit : : Connection > intersecting_connection = intersecting_connections . front ( ) - > get ( ) ;
if ( selected_vsnode - > is_any_port_connected ( ) | | selected_vsnode - > get_input_port_count ( ) = = 0 | | selected_vsnode - > get_output_port_count ( ) = = 0 ) {
return false ;
}
VisualShaderNode : : PortType original_port_type_from = visual_shader - > get_node ( shader_type , String ( intersecting_connection - > from_node ) . to_int ( ) ) - > get_output_port_type ( intersecting_connection - > from_port ) ;
VisualShaderNode : : PortType original_port_type_to = visual_shader - > get_node ( shader_type , String ( intersecting_connection - > to_node ) . to_int ( ) ) - > get_input_port_type ( intersecting_connection - > to_port ) ;
2024-05-07 16:48:03 +02:00
Ref < VisualShaderNodeReroute > reroute_node = selected_vsnode ;
2024-01-19 11:35:46 +01:00
// Searching for the default port or the first compatible input port of the node to insert.
int _to_port = - 1 ;
for ( int i = 0 ; i < selected_vsnode - > get_input_port_count ( ) ; i + + ) {
2024-05-07 16:48:03 +02:00
if ( visual_shader - > is_port_types_compatible ( original_port_type_from , selected_vsnode - > get_input_port_type ( i ) ) | | reroute_node . is_valid ( ) ) {
2024-01-19 11:35:46 +01:00
if ( i = = selected_vsnode - > get_default_input_port ( original_port_type_from ) ) {
_to_port = i ;
break ;
} else if ( _to_port = = - 1 ) {
_to_port = i ;
}
}
}
// Searching for the first compatible output port of the node to insert.
int _from_port = - 1 ;
for ( int i = 0 ; i < selected_vsnode - > get_output_port_count ( ) ; i + + ) {
2024-05-07 16:48:03 +02:00
if ( visual_shader - > is_port_types_compatible ( selected_vsnode - > get_output_port_type ( i ) , original_port_type_to ) | | reroute_node . is_valid ( ) ) {
2024-01-19 11:35:46 +01:00
_from_port = i ;
break ;
}
}
if ( _to_port = = - 1 | | _from_port = = - 1 ) {
return false ;
}
if ( r_closest_connection ! = nullptr ) {
* r_closest_connection = intersecting_connection ;
}
if ( r_from_port ! = nullptr ) {
* r_from_port = _from_port ;
}
if ( r_to_port ! = nullptr ) {
* r_to_port = _to_port ;
}
return true ;
}
void VisualShaderEditor : : _handle_node_drop_on_connection ( ) {
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
undo_redo - > create_action ( TTR ( " Insert node " ) ) ;
// Check whether the dragged node was dropped over a connection.
Ref < GraphEdit : : Connection > closest_connection ;
int _from_port = - 1 ;
int _to_port = - 1 ;
if ( ! _check_node_drop_on_connection ( graph - > get_local_mouse_position ( ) , & closest_connection , & _from_port , & _to_port ) ) {
return ;
}
2024-04-15 15:18:34 +02:00
int selected_node_id = drag_buffer . front ( ) - > get ( ) . node ;
2024-01-19 11:35:46 +01:00
VisualShader : : Type shader_type = get_current_shader_type ( ) ;
Ref < VisualShaderNode > selected_vsnode = visual_shader - > get_node ( shader_type , selected_node_id ) ;
// Delete the old connection.
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
// Add the connection to the dropped node.
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , selected_node_id , _to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , selected_node_id , _to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , selected_node_id , _to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , shader_type , String ( closest_connection - > from_node ) . to_int ( ) , closest_connection - > from_port , selected_node_id , _to_port ) ;
// Add the connection from the dropped node.
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , shader_type , selected_node_id , _from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " disconnect_nodes " , shader_type , selected_node_id , _from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , shader_type , selected_node_id , _from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , shader_type , selected_node_id , _from_port , String ( closest_connection - > to_node ) . to_int ( ) , closest_connection - > to_port ) ;
undo_redo - > commit_action ( ) ;
call_deferred ( SNAME ( " _update_graph " ) ) ;
}
2020-10-15 09:18:37 +02:00
void VisualShaderEditor : : _delete_nodes ( int p_type , const List < int > & p_nodes ) {
VisualShader : : Type type = VisualShader : : Type ( p_type ) ;
2020-09-10 07:31:07 +02:00
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2020-10-15 09:18:37 +02:00
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2021-07-16 05:45:57 +02:00
for ( const int & F : p_nodes ) {
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2021-07-16 05:45:57 +02:00
if ( E . from_node = = F | | E . to_node = = F ) {
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
2020-10-15 09:18:37 +02:00
}
2020-09-10 07:31:07 +02:00
}
}
2024-02-07 02:37:26 +01:00
// The VS nodes need to be added before attaching them to frames.
for ( const int & F : p_nodes ) {
Ref < VisualShaderNode > node = visual_shader - > get_node ( type , F ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " add_node " , type , node , visual_shader - > get_node_position ( type , F ) , F ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " add_node " , type , F , false , false ) ;
}
// Update frame references.
for ( const int & node_id : p_nodes ) {
Ref < VisualShaderNodeFrame > frame = visual_shader - > get_node ( type , node_id ) ;
if ( frame . is_valid ( ) ) {
for ( const int & attached_node_id : frame - > get_attached_nodes ( ) ) {
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " detach_node_from_frame " , type , attached_node_id ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " detach_node_from_frame " , type , attached_node_id ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " attach_node_to_frame " , type , attached_node_id , node_id ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " attach_node_to_frame " , type , attached_node_id , node_id ) ;
}
}
Ref < VisualShaderNode > node = visual_shader - > get_node ( type , node_id ) ;
if ( node - > get_frame ( ) = = - 1 ) {
continue ;
}
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " detach_node_from_frame " , type , node_id ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " detach_node_from_frame " , type , node_id ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " attach_node_to_frame " , type , node_id , node - > get_frame ( ) ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " attach_node_to_frame " , type , node_id , node - > get_frame ( ) ) ;
}
// Restore size of the frame nodes.
for ( const int & F : p_nodes ) {
Ref < VisualShaderNodeFrame > frame = visual_shader - > get_node ( type , F ) ;
if ( frame . is_valid ( ) ) {
undo_redo - > add_undo_method ( this , " _set_node_size " , type , F , frame - > get_size ( ) ) ;
}
}
2022-08-27 11:22:43 +02:00
HashSet < String > parameter_names ;
2019-05-12 14:09:39 +02:00
2021-07-16 05:45:57 +02:00
for ( const int & F : p_nodes ) {
Ref < VisualShaderNode > node = visual_shader - > get_node ( type , F ) ;
2019-07-12 19:36:33 +02:00
2021-07-16 05:45:57 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " remove_node " , type , F ) ;
2019-05-12 14:09:39 +02:00
2022-08-27 11:22:43 +02:00
VisualShaderNodeParameter * parameter = Object : : cast_to < VisualShaderNodeParameter > ( node . ptr ( ) ) ;
if ( parameter ) {
parameter_names . insert ( parameter - > get_parameter_name ( ) ) ;
2020-10-15 09:18:37 +02:00
}
2019-05-12 14:09:39 +02:00
}
2018-07-14 23:15:42 +02:00
2020-10-15 09:18:37 +02:00
List < VisualShader : : Connection > used_conns ;
2021-07-16 05:45:57 +02:00
for ( const int & F : p_nodes ) {
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2021-07-16 05:45:57 +02:00
if ( E . from_node = = F | | E . to_node = = F ) {
2020-10-15 09:18:37 +02:00
bool cancel = false ;
for ( List < VisualShader : : Connection > : : Element * R = used_conns . front ( ) ; R ; R = R - > next ( ) ) {
2021-07-16 05:45:57 +02:00
if ( R - > get ( ) . from_node = = E . from_node & & R - > get ( ) . from_port = = E . from_port & & R - > get ( ) . to_node = = E . to_node & & R - > get ( ) . to_port = = E . to_port ) {
2020-10-15 09:18:37 +02:00
cancel = true ; // to avoid ERR_ALREADY_EXISTS warning
break ;
}
}
if ( ! cancel ) {
2021-07-16 05:45:57 +02:00
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
used_conns . push_back ( E ) ;
2020-10-15 09:18:37 +02:00
}
}
2018-07-14 23:15:42 +02:00
}
}
2020-09-21 13:32:59 +02:00
2023-08-09 18:31:15 +02:00
// Delete nodes from the graph.
2021-07-16 05:45:57 +02:00
for ( const int & F : p_nodes ) {
2023-01-12 12:19:55 +01:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " remove_node " , type , F , false ) ;
2020-10-15 09:18:37 +02:00
}
2023-08-09 18:31:15 +02:00
// Update parameter refs if any parameter has been deleted.
2022-08-27 11:22:43 +02:00
if ( parameter_names . size ( ) > 0 ) {
undo_redo - > add_do_method ( this , " _update_parameters " , true ) ;
undo_redo - > add_undo_method ( this , " _update_parameters " , true ) ;
2020-09-21 13:32:59 +02:00
2022-08-27 11:22:43 +02:00
_update_parameter_refs ( parameter_names ) ;
2020-09-21 13:32:59 +02:00
}
2020-10-15 09:18:37 +02:00
}
2020-12-30 09:45:31 +01:00
void VisualShaderEditor : : _replace_node ( VisualShader : : Type p_type_id , int p_node_id , const StringName & p_from , const StringName & p_to ) {
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-12-30 09:45:31 +01:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " replace_node " , p_type_id , p_node_id , p_to ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " replace_node " , p_type_id , p_node_id , p_from ) ;
}
2024-02-15 17:25:58 +01:00
void VisualShaderEditor : : _update_constant ( VisualShader : : Type p_type_id , int p_node_id , const Variant & p_var , int p_preview_port ) {
2020-12-30 09:45:31 +01:00
Ref < VisualShaderNode > node = visual_shader - > get_node ( p_type_id , p_node_id ) ;
ERR_FAIL_COND ( ! node . is_valid ( ) ) ;
ERR_FAIL_COND ( ! node - > has_method ( " set_constant " ) ) ;
node - > call ( " set_constant " , p_var ) ;
if ( p_preview_port ! = - 1 ) {
node - > set_output_port_for_preview ( p_preview_port ) ;
}
}
2024-02-15 17:25:58 +01:00
void VisualShaderEditor : : _update_parameter ( VisualShader : : Type p_type_id , int p_node_id , const Variant & p_var , int p_preview_port ) {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameter > parameter = visual_shader - > get_node ( p_type_id , p_node_id ) ;
ERR_FAIL_COND ( ! parameter . is_valid ( ) ) ;
2020-12-30 09:45:31 +01:00
2022-08-27 11:22:43 +02:00
String valid_name = visual_shader - > validate_parameter_name ( parameter - > get_parameter_name ( ) , parameter ) ;
parameter - > set_parameter_name ( valid_name ) ;
graph_plugin - > set_parameter_name ( p_type_id , p_node_id , valid_name ) ;
2020-12-30 09:45:31 +01:00
2022-08-27 11:22:43 +02:00
if ( parameter - > has_method ( " set_default_value_enabled " ) ) {
parameter - > call ( " set_default_value_enabled " , true ) ;
parameter - > call ( " set_default_value " , p_var ) ;
2020-12-30 09:45:31 +01:00
}
if ( p_preview_port ! = - 1 ) {
2022-08-27 11:22:43 +02:00
parameter - > set_output_port_for_preview ( p_preview_port ) ;
2020-12-30 09:45:31 +01:00
}
}
2022-08-27 11:22:43 +02:00
void VisualShaderEditor : : _convert_constants_to_parameters ( bool p_vice_versa ) {
2020-12-30 09:45:31 +01:00
VisualShader : : Type type_id = get_current_shader_type ( ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-12-30 09:45:31 +01:00
if ( ! p_vice_versa ) {
2022-08-27 11:22:43 +02:00
undo_redo - > create_action ( TTR ( " Convert Constant Node(s) To Parameter(s) " ) ) ;
2020-12-30 09:45:31 +01:00
} else {
2022-08-27 11:22:43 +02:00
undo_redo - > create_action ( TTR ( " Convert Parameter Node(s) To Constant(s) " ) ) ;
2020-12-30 09:45:31 +01:00
}
2022-08-27 11:22:43 +02:00
const HashSet < int > & current_set = p_vice_versa ? selected_parameters : selected_constants ;
2022-05-19 17:00:06 +02:00
HashSet < String > deleted_names ;
2020-12-30 09:45:31 +01:00
2022-05-19 01:43:40 +02:00
for ( const int & E : current_set ) {
int node_id = E ;
2020-12-30 09:45:31 +01:00
Ref < VisualShaderNode > node = visual_shader - > get_node ( type_id , node_id ) ;
2021-05-20 12:07:26 +02:00
bool caught = false ;
2020-12-30 09:45:31 +01:00
Variant var ;
// float
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeFloatConstant > float_const = Object : : cast_to < VisualShaderNodeFloatConstant > ( node . ptr ( ) ) ;
if ( float_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeFloatConstant " , " VisualShaderNodeFloatParameter " ) ;
2020-12-30 09:45:31 +01:00
var = float_const - > get_constant ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeFloatParameter > float_parameter = Object : : cast_to < VisualShaderNodeFloatParameter > ( node . ptr ( ) ) ;
if ( float_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeFloatParameter " , " VisualShaderNodeFloatConstant " ) ;
var = float_parameter - > get_default_value ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
}
// int
2021-05-20 12:07:26 +02:00
if ( ! caught ) {
2020-12-30 09:45:31 +01:00
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeIntConstant > int_const = Object : : cast_to < VisualShaderNodeIntConstant > ( node . ptr ( ) ) ;
if ( int_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeIntConstant " , " VisualShaderNodeIntParameter " ) ;
2020-12-30 09:45:31 +01:00
var = int_const - > get_constant ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeIntParameter > int_parameter = Object : : cast_to < VisualShaderNodeIntParameter > ( node . ptr ( ) ) ;
if ( int_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeIntParameter " , " VisualShaderNodeIntConstant " ) ;
var = int_parameter - > get_default_value ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
}
}
// boolean
2021-05-20 12:07:26 +02:00
if ( ! caught ) {
2020-12-30 09:45:31 +01:00
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeBooleanConstant > boolean_const = Object : : cast_to < VisualShaderNodeBooleanConstant > ( node . ptr ( ) ) ;
if ( boolean_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeBooleanConstant " , " VisualShaderNodeBooleanParameter " ) ;
2020-12-30 09:45:31 +01:00
var = boolean_const - > get_constant ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeBooleanParameter > boolean_parameter = Object : : cast_to < VisualShaderNodeBooleanParameter > ( node . ptr ( ) ) ;
if ( boolean_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeBooleanParameter " , " VisualShaderNodeBooleanConstant " ) ;
var = boolean_parameter - > get_default_value ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
}
}
2022-02-01 09:32:01 +01:00
// vec2
if ( ! caught ) {
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeVec2Constant > vec2_const = Object : : cast_to < VisualShaderNodeVec2Constant > ( node . ptr ( ) ) ;
if ( vec2_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeVec2Constant " , " VisualShaderNodeVec2Parameter " ) ;
2022-02-01 09:32:01 +01:00
var = vec2_const - > get_constant ( ) ;
caught = true ;
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeVec2Parameter > vec2_parameter = Object : : cast_to < VisualShaderNodeVec2Parameter > ( node . ptr ( ) ) ;
if ( vec2_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeVec2Parameter " , " VisualShaderNodeVec2Constant " ) ;
var = vec2_parameter - > get_default_value ( ) ;
2022-02-01 09:32:01 +01:00
caught = true ;
}
}
}
2020-12-30 09:45:31 +01:00
// vec3
2021-05-20 12:07:26 +02:00
if ( ! caught ) {
2020-12-30 09:45:31 +01:00
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeVec3Constant > vec3_const = Object : : cast_to < VisualShaderNodeVec3Constant > ( node . ptr ( ) ) ;
if ( vec3_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeVec3Constant " , " VisualShaderNodeVec3Parameter " ) ;
2020-12-30 09:45:31 +01:00
var = vec3_const - > get_constant ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeVec3Parameter > vec3_parameter = Object : : cast_to < VisualShaderNodeVec3Parameter > ( node . ptr ( ) ) ;
if ( vec3_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeVec3Parameter " , " VisualShaderNodeVec3Constant " ) ;
var = vec3_parameter - > get_default_value ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
}
}
2022-04-12 19:09:29 +02:00
// vec4
if ( ! caught ) {
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeVec4Constant > vec4_const = Object : : cast_to < VisualShaderNodeVec4Constant > ( node . ptr ( ) ) ;
if ( vec4_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeVec4Constant " , " VisualShaderNodeVec4Parameter " ) ;
2022-04-12 19:09:29 +02:00
var = vec4_const - > get_constant ( ) ;
caught = true ;
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeVec4Parameter > vec4_parameter = Object : : cast_to < VisualShaderNodeVec4Parameter > ( node . ptr ( ) ) ;
if ( vec4_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeVec4Parameter " , " VisualShaderNodeVec4Constant " ) ;
var = vec4_parameter - > get_default_value ( ) ;
2022-04-12 19:09:29 +02:00
caught = true ;
}
}
}
2020-12-30 09:45:31 +01:00
// color
2021-05-20 12:07:26 +02:00
if ( ! caught ) {
2020-12-30 09:45:31 +01:00
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeColorConstant > color_const = Object : : cast_to < VisualShaderNodeColorConstant > ( node . ptr ( ) ) ;
if ( color_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeColorConstant " , " VisualShaderNodeColorParameter " ) ;
2020-12-30 09:45:31 +01:00
var = color_const - > get_constant ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeColorParameter > color_parameter = Object : : cast_to < VisualShaderNodeColorParameter > ( node . ptr ( ) ) ;
if ( color_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeColorParameter " , " VisualShaderNodeColorConstant " ) ;
var = color_parameter - > get_default_value ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
}
}
// transform
2021-05-20 12:07:26 +02:00
if ( ! caught ) {
2020-12-30 09:45:31 +01:00
if ( ! p_vice_versa ) {
Ref < VisualShaderNodeTransformConstant > transform_const = Object : : cast_to < VisualShaderNodeTransformConstant > ( node . ptr ( ) ) ;
if ( transform_const . is_valid ( ) ) {
2022-08-27 11:22:43 +02:00
_replace_node ( type_id , node_id , " VisualShaderNodeTransformConstant " , " VisualShaderNodeTransformParameter " ) ;
2020-12-30 09:45:31 +01:00
var = transform_const - > get_constant ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
} else {
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeTransformParameter > transform_parameter = Object : : cast_to < VisualShaderNodeTransformParameter > ( node . ptr ( ) ) ;
if ( transform_parameter . is_valid ( ) ) {
_replace_node ( type_id , node_id , " VisualShaderNodeTransformParameter " , " VisualShaderNodeTransformConstant " ) ;
var = transform_parameter - > get_default_value ( ) ;
2021-05-20 12:07:26 +02:00
caught = true ;
2020-12-30 09:45:31 +01:00
}
}
}
2021-05-20 12:07:26 +02:00
ERR_CONTINUE ( ! caught ) ;
2020-12-30 09:45:31 +01:00
int preview_port = node - > get_output_port_for_preview ( ) ;
if ( ! p_vice_versa ) {
2022-08-27 11:22:43 +02:00
undo_redo - > add_do_method ( this , " _update_parameter " , type_id , node_id , var , preview_port ) ;
2020-12-30 09:45:31 +01:00
undo_redo - > add_undo_method ( this , " _update_constant " , type_id , node_id , var , preview_port ) ;
} else {
undo_redo - > add_do_method ( this , " _update_constant " , type_id , node_id , var , preview_port ) ;
2022-08-27 11:22:43 +02:00
undo_redo - > add_undo_method ( this , " _update_parameter " , type_id , node_id , var , preview_port ) ;
2020-12-30 09:45:31 +01:00
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameter > parameter = Object : : cast_to < VisualShaderNodeParameter > ( node . ptr ( ) ) ;
ERR_CONTINUE ( ! parameter . is_valid ( ) ) ;
2020-12-30 09:45:31 +01:00
2022-08-27 11:22:43 +02:00
deleted_names . insert ( parameter - > get_parameter_name ( ) ) ;
2020-12-30 09:45:31 +01:00
}
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type_id , node_id ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type_id , node_id ) ;
}
2022-08-27 11:22:43 +02:00
undo_redo - > add_do_method ( this , " _update_parameters " , true ) ;
undo_redo - > add_undo_method ( this , " _update_parameters " , true ) ;
2020-12-30 09:45:31 +01:00
if ( deleted_names . size ( ) > 0 ) {
2022-08-27 11:22:43 +02:00
_update_parameter_refs ( deleted_names ) ;
2020-12-30 09:45:31 +01:00
}
undo_redo - > commit_action ( ) ;
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _detach_nodes_from_frame ( int p_type , const List < int > & p_nodes ) {
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
for ( int node_id : p_nodes ) {
Ref < VisualShaderNode > node = visual_shader - > get_node ( ( VisualShader : : Type ) p_type , node_id ) ;
if ( ! node . is_valid ( ) ) {
continue ;
}
int frame_id = node - > get_frame ( ) ;
if ( frame_id ! = - 1 ) {
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " detach_node_from_frame " , p_type , node_id ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " detach_node_from_frame " , p_type , node_id ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " attach_node_to_frame " , p_type , node_id , frame_id ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " attach_node_to_frame " , p_type , node_id , frame_id ) ;
}
}
}
void VisualShaderEditor : : _detach_nodes_from_frame_request ( ) {
// Called from context menu.
List < int > to_detach_node_ids ;
for ( int i = 0 ; i < graph - > get_child_count ( ) ; i + + ) {
GraphElement * gn = Object : : cast_to < GraphElement > ( graph - > get_child ( i ) ) ;
if ( gn ) {
int id = String ( gn - > get_name ( ) ) . to_int ( ) ;
if ( gn - > is_selected ( ) ) {
to_detach_node_ids . push_back ( id ) ;
}
}
}
if ( to_detach_node_ids . is_empty ( ) ) {
return ;
}
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
undo_redo - > create_action ( TTR ( " Detach VisualShader Node(s) from Frame " ) ) ;
_detach_nodes_from_frame ( get_current_shader_type ( ) , to_detach_node_ids ) ;
undo_redo - > commit_action ( ) ;
}
2023-09-26 16:41:39 +02:00
void VisualShaderEditor : : _delete_node_request ( int p_type , int p_node ) {
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNode > node = visual_shader - > get_node ( ( VisualShader : : Type ) p_type , p_node ) ;
2024-02-07 02:37:26 +01:00
if ( ! node - > is_deletable ( ) ) {
2023-08-09 18:31:15 +02:00
return ;
}
2020-10-15 09:18:37 +02:00
List < int > to_erase ;
to_erase . push_back ( p_node ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 09:18:37 +02:00
undo_redo - > create_action ( TTR ( " Delete VisualShader Node " ) ) ;
_delete_nodes ( p_type , to_erase ) ;
undo_redo - > commit_action ( ) ;
}
2023-09-26 16:41:39 +02:00
void VisualShaderEditor : : _delete_nodes_request ( const TypedArray < StringName > & p_nodes ) {
2020-10-15 09:18:37 +02:00
List < int > to_erase ;
2022-05-17 12:13:35 +02:00
if ( p_nodes . is_empty ( ) ) {
// Called from context menu.
for ( int i = 0 ; i < graph - > get_child_count ( ) ; i + + ) {
2023-08-09 18:31:15 +02:00
GraphElement * graph_element = Object : : cast_to < GraphElement > ( graph - > get_child ( i ) ) ;
2024-02-07 02:37:26 +01:00
if ( ! graph_element ) {
continue ;
}
VisualShader : : Type type = get_current_shader_type ( ) ;
int id = String ( graph_element - > get_name ( ) ) . to_int ( ) ;
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , id ) ;
if ( vsnode - > is_deletable ( ) & & graph_element - > is_selected ( ) ) {
to_erase . push_back ( graph_element - > get_name ( ) . operator String ( ) . to_int ( ) ) ;
2020-10-15 09:18:37 +02:00
}
}
2022-05-17 12:13:35 +02:00
} else {
2023-08-09 18:31:15 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2022-05-17 12:13:35 +02:00
for ( int i = 0 ; i < p_nodes . size ( ) ; i + + ) {
2023-08-09 18:31:15 +02:00
int id = p_nodes [ i ] . operator String ( ) . to_int ( ) ;
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , id ) ;
2024-02-07 02:37:26 +01:00
if ( vsnode - > is_deletable ( ) ) {
2023-08-09 18:31:15 +02:00
to_erase . push_back ( id ) ;
}
2022-05-17 12:13:35 +02:00
}
2020-10-15 09:18:37 +02:00
}
2020-09-21 13:32:59 +02:00
2020-12-15 13:04:21 +01:00
if ( to_erase . is_empty ( ) ) {
2020-10-15 09:18:37 +02:00
return ;
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2020-10-15 09:18:37 +02:00
undo_redo - > create_action ( TTR ( " Delete VisualShader Node(s) " ) ) ;
_delete_nodes ( get_current_shader_type ( ) , to_erase ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _node_selected ( Object * p_node ) {
2020-09-07 09:28:13 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2018-07-14 23:15:42 +02:00
2023-08-09 18:31:15 +02:00
GraphElement * graph_element = Object : : cast_to < GraphElement > ( p_node ) ;
2023-09-09 17:24:40 +02:00
ERR_FAIL_NULL ( graph_element ) ;
2018-07-14 23:15:42 +02:00
2023-08-09 18:31:15 +02:00
int id = String ( graph_element - > get_name ( ) ) . to_int ( ) ;
2018-07-14 23:15:42 +02:00
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , id ) ;
ERR_FAIL_COND ( ! vsnode . is_valid ( ) ) ;
}
2019-07-10 11:54:12 +02:00
void VisualShaderEditor : : _graph_gui_input ( const Ref < InputEvent > & p_event ) {
2024-01-19 11:35:46 +01:00
Ref < InputEventMouseMotion > mm = p_event ;
2019-02-22 18:38:58 +01:00
Ref < InputEventMouseButton > mb = p_event ;
2020-12-30 09:45:31 +01:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2019-02-22 18:38:58 +01:00
2024-01-19 11:35:46 +01:00
// Highlight valid connection on which a node can be dropped.
if ( mm . is_valid ( ) & & mm - > get_button_mask ( ) . has_flag ( MouseButtonMask : : LEFT ) ) {
Ref < GraphEdit : : Connection > closest_connection ;
graph - > reset_all_connection_activity ( ) ;
if ( _check_node_drop_on_connection ( graph - > get_local_mouse_position ( ) , & closest_connection ) ) {
graph - > set_connection_activity ( closest_connection - > from_node , closest_connection - > from_port , closest_connection - > to_node , closest_connection - > to_port , 1.0 ) ;
}
}
2023-08-09 18:31:15 +02:00
Ref < VisualShaderNode > selected_vsnode ;
// Right click actions.
2021-08-13 23:31:57 +02:00
if ( mb . is_valid ( ) & & mb - > is_pressed ( ) & & mb - > get_button_index ( ) = = MouseButton : : RIGHT ) {
2020-12-30 09:45:31 +01:00
selected_constants . clear ( ) ;
2022-08-27 11:22:43 +02:00
selected_parameters . clear ( ) ;
2024-02-07 02:37:26 +01:00
selected_frame = - 1 ;
2021-07-03 10:11:10 +02:00
selected_float_constant = - 1 ;
2020-12-30 09:45:31 +01:00
2024-02-07 02:37:26 +01:00
List < int > selected_deletable_graph_elements ;
List < GraphElement * > selected_graph_elements ;
2020-02-27 10:10:09 +01:00
for ( int i = 0 ; i < graph - > get_child_count ( ) ; i + + ) {
2023-08-09 18:31:15 +02:00
GraphElement * graph_element = Object : : cast_to < GraphElement > ( graph - > get_child ( i ) ) ;
2024-02-07 02:37:26 +01:00
if ( ! graph_element ) {
continue ;
}
int id = String ( graph_element - > get_name ( ) ) . to_int ( ) ;
Ref < VisualShaderNode > vsnode = visual_shader - > get_node ( type , id ) ;
if ( ! graph_element - > is_selected ( ) ) {
continue ;
}
2020-12-30 09:45:31 +01:00
2024-02-07 02:37:26 +01:00
selected_graph_elements . push_back ( graph_element ) ;
2021-02-21 09:33:55 +01:00
2024-02-07 02:37:26 +01:00
if ( ! vsnode - > is_deletable ( ) ) {
continue ;
}
2023-08-09 18:31:15 +02:00
2024-02-07 02:37:26 +01:00
selected_deletable_graph_elements . push_back ( id ) ;
Ref < VisualShaderNode > node = visual_shader - > get_node ( type , id ) ;
selected_vsnode = node ;
VisualShaderNodeFrame * frame_node = Object : : cast_to < VisualShaderNodeFrame > ( node . ptr ( ) ) ;
if ( frame_node ! = nullptr ) {
selected_frame = id ;
}
VisualShaderNodeConstant * constant_node = Object : : cast_to < VisualShaderNodeConstant > ( node . ptr ( ) ) ;
if ( constant_node ! = nullptr ) {
selected_constants . insert ( id ) ;
}
VisualShaderNodeFloatConstant * float_constant_node = Object : : cast_to < VisualShaderNodeFloatConstant > ( node . ptr ( ) ) ;
if ( float_constant_node ! = nullptr ) {
selected_float_constant = id ;
}
VisualShaderNodeParameter * parameter_node = Object : : cast_to < VisualShaderNodeParameter > ( node . ptr ( ) ) ;
if ( parameter_node ! = nullptr & & parameter_node - > is_convertible_to_constant ( ) ) {
selected_parameters . insert ( id ) ;
2020-02-27 10:10:09 +01:00
}
}
2021-02-21 09:33:55 +01:00
2024-02-07 02:37:26 +01:00
if ( selected_deletable_graph_elements . size ( ) > 1 ) {
selected_frame = - 1 ;
2021-07-03 10:11:10 +02:00
selected_float_constant = - 1 ;
2021-02-21 09:33:55 +01:00
}
2022-02-07 20:58:37 +01:00
bool copy_buffer_empty = true ;
for ( const CopyItem & item : copy_items_buffer ) {
if ( ! item . disabled ) {
copy_buffer_empty = false ;
break ;
}
}
2024-01-19 11:35:46 +01:00
menu_point = graph - > get_local_mouse_position ( ) ;
Point2 gpos = get_screen_position ( ) + get_local_mouse_position ( ) ;
Ref < GraphEdit : : Connection > closest_connection = graph - > get_closest_connection_at_point ( menu_point ) ;
if ( closest_connection . is_valid ( ) ) {
clicked_connection = closest_connection ;
2024-05-07 16:48:03 +02:00
saved_node_pos = graph - > get_local_mouse_position ( ) ;
saved_node_pos_dirty = true ;
2024-01-19 11:35:46 +01:00
connection_popup_menu - > set_position ( gpos ) ;
connection_popup_menu - > reset_size ( ) ;
connection_popup_menu - > popup ( ) ;
2024-02-07 02:37:26 +01:00
} else if ( selected_graph_elements . is_empty ( ) & & copy_buffer_empty ) {
2020-02-27 10:10:09 +01:00
_show_members_dialog ( true ) ;
} else {
2024-02-07 02:37:26 +01:00
popup_menu - > set_item_disabled ( NodeMenuOptions : : CUT , selected_deletable_graph_elements . is_empty ( ) ) ;
popup_menu - > set_item_disabled ( NodeMenuOptions : : COPY , selected_deletable_graph_elements . is_empty ( ) ) ;
2022-02-07 20:58:37 +01:00
popup_menu - > set_item_disabled ( NodeMenuOptions : : PASTE , copy_buffer_empty ) ;
2024-02-07 02:37:26 +01:00
popup_menu - > set_item_disabled ( NodeMenuOptions : : DELETE , selected_deletable_graph_elements . is_empty ( ) ) ;
popup_menu - > set_item_disabled ( NodeMenuOptions : : DUPLICATE , selected_deletable_graph_elements . is_empty ( ) ) ;
2022-02-07 20:58:37 +01:00
popup_menu - > set_item_disabled ( NodeMenuOptions : : CLEAR_COPY_BUFFER , copy_buffer_empty ) ;
2020-12-30 09:45:31 +01:00
int temp = popup_menu - > get_item_index ( NodeMenuOptions : : SEPARATOR2 ) ;
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
2021-07-03 10:11:10 +02:00
temp = popup_menu - > get_item_index ( NodeMenuOptions : : FLOAT_CONSTANTS ) ;
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
2022-08-27 11:22:43 +02:00
temp = popup_menu - > get_item_index ( NodeMenuOptions : : CONVERT_CONSTANTS_TO_PARAMETERS ) ;
2020-12-30 09:45:31 +01:00
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
2022-08-27 11:22:43 +02:00
temp = popup_menu - > get_item_index ( NodeMenuOptions : : CONVERT_PARAMETERS_TO_CONSTANTS ) ;
2020-12-30 09:45:31 +01:00
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
2021-04-04 16:50:19 +02:00
temp = popup_menu - > get_item_index ( NodeMenuOptions : : SEPARATOR3 ) ;
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
2024-02-07 02:37:26 +01:00
temp = popup_menu - > get_item_index ( NodeMenuOptions : : UNLINK_FROM_PARENT_FRAME ) ;
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
temp = popup_menu - > get_item_index ( NodeMenuOptions : : SET_FRAME_TITLE ) ;
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
temp = popup_menu - > get_item_index ( NodeMenuOptions : : ENABLE_FRAME_COLOR ) ;
2021-02-21 09:33:55 +01:00
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
2024-02-07 02:37:26 +01:00
temp = popup_menu - > get_item_index ( NodeMenuOptions : : SET_FRAME_COLOR ) ;
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
temp = popup_menu - > get_item_index ( NodeMenuOptions : : ENABLE_FRAME_AUTOSHRINK ) ;
2021-02-21 09:33:55 +01:00
if ( temp ! = - 1 ) {
popup_menu - > remove_item ( temp ) ;
}
2022-08-27 11:22:43 +02:00
if ( selected_constants . size ( ) > 0 | | selected_parameters . size ( ) > 0 ) {
2021-02-21 09:33:55 +01:00
popup_menu - > add_separator ( " " , NodeMenuOptions : : SEPARATOR2 ) ;
2020-12-30 09:45:31 +01:00
2021-07-03 10:11:10 +02:00
if ( selected_float_constant ! = - 1 ) {
if ( ! constants_submenu ) {
constants_submenu = memnew ( PopupMenu ) ;
for ( int i = 0 ; i < MAX_FLOAT_CONST_DEFS ; i + + ) {
constants_submenu - > add_item ( float_constant_defs [ i ] . name , i ) ;
}
constants_submenu - > connect ( " index_pressed " , callable_mp ( this , & VisualShaderEditor : : _float_constant_selected ) ) ;
}
2023-11-28 17:33:04 +01:00
popup_menu - > add_submenu_node_item ( TTR ( " Float Constants " ) , constants_submenu , int ( NodeMenuOptions : : FLOAT_CONSTANTS ) ) ;
2021-07-03 10:11:10 +02:00
}
2020-12-30 09:45:31 +01:00
if ( selected_constants . size ( ) > 0 ) {
2022-08-27 11:22:43 +02:00
popup_menu - > add_item ( TTR ( " Convert Constant(s) to Parameter(s) " ) , NodeMenuOptions : : CONVERT_CONSTANTS_TO_PARAMETERS ) ;
2020-12-30 09:45:31 +01:00
}
2022-08-27 11:22:43 +02:00
if ( selected_parameters . size ( ) > 0 ) {
popup_menu - > add_item ( TTR ( " Convert Parameter(s) to Constant(s) " ) , NodeMenuOptions : : CONVERT_PARAMETERS_TO_CONSTANTS ) ;
2020-12-30 09:45:31 +01:00
}
}
2024-02-07 02:37:26 +01:00
// Check if any selected node is attached to a frame.
bool is_attached_to_frame = false ;
for ( GraphElement * graph_element : selected_graph_elements ) {
if ( graph - > get_element_frame ( graph_element - > get_name ( ) ) ) {
is_attached_to_frame = true ;
break ;
}
}
if ( is_attached_to_frame ) {
popup_menu - > add_item ( TTR ( " Detach from Parent Frame " ) , NodeMenuOptions : : UNLINK_FROM_PARENT_FRAME ) ;
}
if ( selected_frame ! = - 1 ) {
2021-07-03 10:11:10 +02:00
popup_menu - > add_separator ( " " , NodeMenuOptions : : SEPARATOR3 ) ;
2024-02-07 02:37:26 +01:00
popup_menu - > add_item ( TTR ( " Set Frame Title " ) , NodeMenuOptions : : SET_FRAME_TITLE ) ;
popup_menu - > add_check_item ( TTR ( " Enable Auto Shrink " ) , NodeMenuOptions : : ENABLE_FRAME_AUTOSHRINK ) ;
popup_menu - > add_check_item ( TTR ( " Enable Tint Color " ) , NodeMenuOptions : : ENABLE_FRAME_COLOR ) ;
VisualShaderNodeFrame * frame_ref = Object : : cast_to < VisualShaderNodeFrame > ( selected_vsnode . ptr ( ) ) ;
if ( frame_ref ) {
int item_index = popup_menu - > get_item_index ( NodeMenuOptions : : ENABLE_FRAME_COLOR ) ;
popup_menu - > set_item_checked ( item_index , frame_ref - > is_tint_color_enabled ( ) ) ;
if ( frame_ref - > is_tint_color_enabled ( ) ) {
popup_menu - > add_item ( TTR ( " Set Tint Color " ) , NodeMenuOptions : : SET_FRAME_COLOR ) ;
}
item_index = popup_menu - > get_item_index ( NodeMenuOptions : : ENABLE_FRAME_AUTOSHRINK ) ;
popup_menu - > set_item_checked ( item_index , frame_ref - > is_autoshrink_enabled ( ) ) ;
}
2021-07-03 10:11:10 +02:00
}
2020-02-27 10:10:09 +01:00
popup_menu - > set_position ( gpos ) ;
2021-11-20 09:04:57 +01:00
popup_menu - > reset_size ( ) ;
2020-02-27 10:10:09 +01:00
popup_menu - > popup ( ) ;
}
}
2019-02-22 18:38:58 +01:00
}
2021-07-13 07:52:52 +02:00
void VisualShaderEditor : : _show_members_dialog ( bool at_mouse_pos , VisualShaderNode : : PortType p_input_port_type , VisualShaderNode : : PortType p_output_port_type ) {
if ( members_input_port_type ! = p_input_port_type | | members_output_port_type ! = p_output_port_type ) {
members_input_port_type = p_input_port_type ;
members_output_port_type = p_output_port_type ;
_update_options_menu ( ) ;
}
2019-04-14 23:23:22 +02:00
if ( at_mouse_pos ) {
saved_node_pos_dirty = true ;
saved_node_pos = graph - > get_local_mouse_position ( ) ;
2021-08-31 17:43:35 +02:00
Point2 gpos = get_screen_position ( ) + get_local_mouse_position ( ) ;
2019-04-14 23:23:22 +02:00
members_dialog - > set_position ( gpos ) ;
} else {
saved_node_pos_dirty = false ;
2021-08-31 17:43:35 +02:00
members_dialog - > set_position ( graph - > get_screen_position ( ) + Point2 ( 5 * EDSCALE , 65 * EDSCALE ) ) ;
2019-04-14 23:23:22 +02:00
}
2023-11-22 10:58:18 +01:00
if ( members_dialog - > is_visible ( ) ) {
members_dialog - > grab_focus ( ) ;
return ;
}
2021-08-31 17:43:35 +02:00
members_dialog - > popup ( ) ;
2019-04-14 23:23:22 +02:00
2021-08-31 17:43:35 +02:00
// Keep dialog within window bounds.
2023-07-03 20:17:56 +02:00
Rect2 window_rect = Rect2 ( get_window ( ) - > get_position ( ) , get_window ( ) - > get_size ( ) ) ;
2020-03-06 18:00:16 +01:00
Rect2 dialog_rect = Rect2 ( members_dialog - > get_position ( ) , members_dialog - > get_size ( ) ) ;
2024-03-03 14:37:52 +01:00
Vector2 difference = ( dialog_rect . get_end ( ) - window_rect . get_end ( ) ) . maxf ( 0 ) ;
2021-08-31 17:43:35 +02:00
members_dialog - > set_position ( members_dialog - > get_position ( ) - difference ) ;
2019-04-14 23:23:22 +02:00
2024-08-31 19:23:34 +02:00
node_filter - > grab_focus ( ) ;
2019-04-14 23:23:22 +02:00
node_filter - > select_all ( ) ;
2018-07-15 09:23:59 +02:00
}
2022-01-09 15:02:13 +01:00
void VisualShaderEditor : : _varying_menu_id_pressed ( int p_idx ) {
switch ( VaryingMenuOptions ( p_idx ) ) {
case VaryingMenuOptions : : ADD : {
_show_add_varying_dialog ( ) ;
} break ;
case VaryingMenuOptions : : REMOVE : {
_show_remove_varying_dialog ( ) ;
} break ;
default :
break ;
}
}
void VisualShaderEditor : : _show_add_varying_dialog ( ) {
_varying_name_changed ( varying_name - > get_text ( ) ) ;
add_varying_dialog - > set_position ( graph - > get_screen_position ( ) + varying_button - > get_position ( ) + Point2 ( 5 * EDSCALE , 65 * EDSCALE ) ) ;
add_varying_dialog - > popup ( ) ;
2024-08-31 19:23:34 +02:00
varying_name - > grab_focus ( ) ;
2022-01-09 15:02:13 +01:00
// Keep dialog within window bounds.
Rect2 window_rect = Rect2 ( DisplayServer : : get_singleton ( ) - > window_get_position ( ) , DisplayServer : : get_singleton ( ) - > window_get_size ( ) ) ;
Rect2 dialog_rect = Rect2 ( add_varying_dialog - > get_position ( ) , add_varying_dialog - > get_size ( ) ) ;
2024-03-03 14:37:52 +01:00
Vector2 difference = ( dialog_rect . get_end ( ) - window_rect . get_end ( ) ) . maxf ( 0 ) ;
2022-01-09 15:02:13 +01:00
add_varying_dialog - > set_position ( add_varying_dialog - > get_position ( ) - difference ) ;
}
void VisualShaderEditor : : _show_remove_varying_dialog ( ) {
remove_varying_dialog - > set_position ( graph - > get_screen_position ( ) + varying_button - > get_position ( ) + Point2 ( 5 * EDSCALE , 65 * EDSCALE ) ) ;
remove_varying_dialog - > popup ( ) ;
2024-08-31 19:23:34 +02:00
varyings - > grab_focus ( ) ;
2022-01-09 15:02:13 +01:00
// Keep dialog within window bounds.
Rect2 window_rect = Rect2 ( DisplayServer : : get_singleton ( ) - > window_get_position ( ) , DisplayServer : : get_singleton ( ) - > window_get_size ( ) ) ;
Rect2 dialog_rect = Rect2 ( remove_varying_dialog - > get_position ( ) , remove_varying_dialog - > get_size ( ) ) ;
2024-03-03 14:37:52 +01:00
Vector2 difference = ( dialog_rect . get_end ( ) - window_rect . get_end ( ) ) . maxf ( 0 ) ;
2022-01-09 15:02:13 +01:00
remove_varying_dialog - > set_position ( remove_varying_dialog - > get_position ( ) - difference ) ;
}
2024-08-31 19:23:34 +02:00
void VisualShaderEditor : : _sbox_input ( const Ref < InputEvent > & p_event ) {
// Redirect navigational key events to the tree.
Ref < InputEventKey > key = p_event ;
if ( key . is_valid ( ) ) {
if ( key - > is_action ( " ui_up " , true ) | | key - > is_action ( " ui_down " , true ) | | key - > is_action ( " ui_page_up " ) | | key - > is_action ( " ui_page_down " ) ) {
members - > gui_input ( key ) ;
node_filter - > accept_event ( ) ;
}
2019-04-14 23:23:22 +02:00
}
2019-02-22 18:38:58 +01:00
}
2024-07-11 15:20:25 +02:00
void VisualShaderEditor : : _param_filter_changed ( const String & p_text ) {
param_filter_name = p_text ;
if ( ! _update_preview_parameter_tree ( ) ) {
_clear_preview_param ( ) ;
}
}
void VisualShaderEditor : : _param_property_changed ( const String & p_property , const Variant & p_value , const String & p_field , bool p_changing ) {
if ( p_changing ) {
return ;
}
String raw_prop_name = p_property . trim_prefix ( " shader_parameter/ " ) ;
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
undo_redo - > create_action ( vformat ( TTR ( " Edit Preview Parameter: %s " ) , p_property ) ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " _set_preview_shader_parameter " , raw_prop_name , p_value ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " _set_preview_shader_parameter " , raw_prop_name , preview_material - > get ( p_property ) ) ;
undo_redo - > add_do_method ( this , " _update_current_param " ) ;
undo_redo - > add_undo_method ( this , " _update_current_param " ) ;
undo_redo - > commit_action ( ) ;
}
void VisualShaderEditor : : _update_current_param ( ) {
if ( current_prop ! = nullptr ) {
String name = current_prop - > get_meta ( " id " ) ;
preview_material - > set ( " shader_parameter/ " + name , visual_shader - > _get_preview_shader_parameter ( name ) ) ;
current_prop - > update_property ( ) ;
current_prop - > update_editor_property_status ( ) ;
current_prop - > update_cache ( ) ;
}
}
void VisualShaderEditor : : _param_selected ( ) {
_clear_preview_param ( ) ;
TreeItem * item = parameters - > get_selected ( ) ;
selected_param_id = item - > get_meta ( " id " ) ;
PropertyInfo pi = parameter_props . get ( selected_param_id ) ;
EditorProperty * prop = EditorInspector : : instantiate_property_editor ( preview_material . ptr ( ) , pi . type , pi . name , pi . hint , pi . hint_string , pi . usage ) ;
if ( ! prop ) {
return ;
}
prop - > connect ( " property_changed " , callable_mp ( this , & VisualShaderEditor : : _param_property_changed ) ) ;
prop - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
prop - > set_object_and_property ( preview_material . ptr ( ) , " shader_parameter/ " + pi . name ) ;
prop - > set_label ( TTR ( " Value: " ) ) ;
prop - > update_property ( ) ;
prop - > update_editor_property_status ( ) ;
prop - > update_cache ( ) ;
current_prop = prop ;
current_prop - > set_meta ( " id " , selected_param_id ) ;
param_vbox2 - > add_child ( prop ) ;
param_vbox - > show ( ) ;
}
void VisualShaderEditor : : _param_unselected ( ) {
parameters - > deselect_all ( ) ;
_clear_preview_param ( ) ;
}
2018-07-14 23:15:42 +02:00
void VisualShaderEditor : : _notification ( int p_what ) {
2022-02-16 15:17:55 +01:00
switch ( p_what ) {
2023-05-23 14:40:13 +02:00
case NOTIFICATION_POSTINITIALIZE : {
_update_options_menu ( ) ;
} break ;
2022-02-16 15:17:55 +01:00
case EditorSettings : : NOTIFICATION_EDITOR_SETTINGS_CHANGED : {
2022-11-23 00:14:08 +01:00
if ( EditorSettings : : get_singleton ( ) - > check_changed_settings_in_group ( " editors/panning " ) ) {
graph - > get_panner ( ) - > setup ( ( ViewPanner : : ControlScheme ) EDITOR_GET ( " editors/panning/sub_editors_panning_scheme " ) . operator int ( ) , ED_GET_SHORTCUT ( " canvas_item_editor/pan_view " ) , bool ( EDITOR_GET ( " editors/panning/simple_panning " ) ) ) ;
graph - > set_warped_panning ( bool ( EDITOR_GET ( " editors/panning/warped_mouse_panning " ) ) ) ;
}
if ( EditorSettings : : get_singleton ( ) - > check_changed_settings_in_group ( " editors/visual_editors " ) ) {
graph - > set_minimap_opacity ( EDITOR_GET ( " editors/visual_editors/minimap_opacity " ) ) ;
2024-02-09 15:02:58 +01:00
graph - > set_grid_pattern ( ( GraphEdit : : GridPattern ) int ( EDITOR_GET ( " editors/visual_editors/grid_pattern " ) ) ) ;
2022-11-23 00:14:08 +01:00
graph - > set_connection_lines_curvature ( EDITOR_GET ( " editors/visual_editors/lines_curvature " ) ) ;
2024-02-09 15:02:58 +01:00
2022-11-23 00:14:08 +01:00
_update_graph ( ) ;
}
2022-02-16 15:17:55 +01:00
} break ;
2019-02-22 18:38:58 +01:00
2022-02-16 15:17:55 +01:00
case NOTIFICATION_ENTER_TREE : {
node_filter - > set_clear_button_enabled ( true ) ;
2021-09-28 18:00:16 +02:00
2022-02-16 15:17:55 +01:00
// collapse tree by default
TreeItem * category = members - > get_root ( ) - > get_first_child ( ) ;
while ( category ) {
category - > set_collapsed ( true ) ;
TreeItem * sub_category = category - > get_first_child ( ) ;
while ( sub_category ) {
sub_category - > set_collapsed ( true ) ;
sub_category = sub_category - > get_next ( ) ;
}
category = category - > get_next ( ) ;
}
2018-07-14 23:15:42 +02:00
2022-10-18 16:43:37 +02:00
graph - > get_panner ( ) - > setup ( ( ViewPanner : : ControlScheme ) EDITOR_GET ( " editors/panning/sub_editors_panning_scheme " ) . operator int ( ) , ED_GET_SHORTCUT ( " canvas_item_editor/pan_view " ) , bool ( EDITOR_GET ( " editors/panning/simple_panning " ) ) ) ;
graph - > set_warped_panning ( bool ( EDITOR_GET ( " editors/panning/warped_mouse_panning " ) ) ) ;
2023-05-23 14:40:13 +02:00
} break ;
2022-02-16 15:17:55 +01:00
case NOTIFICATION_THEME_CHANGED : {
2023-08-13 02:33:39 +02:00
highend_label - > set_modulate ( get_theme_color ( SNAME ( " highend_color " ) , EditorStringName ( Editor ) ) ) ;
2020-02-12 16:39:19 +01:00
2024-07-11 15:20:25 +02:00
param_filter - > set_right_icon ( Control : : get_editor_theme_icon ( SNAME ( " Search " ) ) ) ;
2023-08-13 02:33:39 +02:00
node_filter - > set_right_icon ( Control : : get_editor_theme_icon ( SNAME ( " Search " ) ) ) ;
2019-02-22 18:38:58 +01:00
2024-07-11 15:20:25 +02:00
code_preview_button - > set_icon ( Control : : get_editor_theme_icon ( SNAME ( " Shader " ) ) ) ;
shader_preview_button - > set_icon ( Control : : get_editor_theme_icon ( SNAME ( " SubViewport " ) ) ) ;
2019-08-18 11:29:22 +02:00
2022-02-16 15:17:55 +01:00
{
Color background_color = EDITOR_GET ( " text_editor/theme/highlighting/background_color " ) ;
Color text_color = EDITOR_GET ( " text_editor/theme/highlighting/text_color " ) ;
Color keyword_color = EDITOR_GET ( " text_editor/theme/highlighting/keyword_color " ) ;
Color control_flow_keyword_color = EDITOR_GET ( " text_editor/theme/highlighting/control_flow_keyword_color " ) ;
Color comment_color = EDITOR_GET ( " text_editor/theme/highlighting/comment_color " ) ;
Color symbol_color = EDITOR_GET ( " text_editor/theme/highlighting/symbol_color " ) ;
Color function_color = EDITOR_GET ( " text_editor/theme/highlighting/function_color " ) ;
Color number_color = EDITOR_GET ( " text_editor/theme/highlighting/number_color " ) ;
Color members_color = EDITOR_GET ( " text_editor/theme/highlighting/member_variable_color " ) ;
2023-08-13 02:33:39 +02:00
Color error_color = get_theme_color ( SNAME ( " error_color " ) , EditorStringName ( Editor ) ) ;
2019-08-18 11:29:22 +02:00
2022-02-16 15:17:55 +01:00
preview_text - > add_theme_color_override ( " background_color " , background_color ) ;
2024-05-14 15:57:29 +02:00
varying_error_label - > add_theme_color_override ( SceneStringName ( font_color ) , error_color ) ;
2019-08-18 11:29:22 +02:00
2022-02-16 15:17:55 +01:00
for ( const String & E : keyword_list ) {
if ( ShaderLanguage : : is_control_flow_keyword ( E ) ) {
syntax_highlighter - > add_keyword_color ( E , control_flow_keyword_color ) ;
} else {
syntax_highlighter - > add_keyword_color ( E , keyword_color ) ;
}
2021-04-08 16:12:22 +02:00
}
2019-08-18 11:29:22 +02:00
2023-10-19 18:05:19 +02:00
preview_text - > begin_bulk_theme_override ( ) ;
2024-05-14 15:57:29 +02:00
preview_text - > add_theme_font_override ( SceneStringName ( font ) , get_theme_font ( SNAME ( " expression " ) , EditorStringName ( EditorFonts ) ) ) ;
preview_text - > add_theme_font_size_override ( SceneStringName ( font_size ) , get_theme_font_size ( SNAME ( " expression_size " ) , EditorStringName ( EditorFonts ) ) ) ;
preview_text - > add_theme_color_override ( SceneStringName ( font_color ) , text_color ) ;
2023-10-19 18:05:19 +02:00
preview_text - > end_bulk_theme_override ( ) ;
2022-02-16 15:17:55 +01:00
syntax_highlighter - > set_number_color ( number_color ) ;
syntax_highlighter - > set_symbol_color ( symbol_color ) ;
syntax_highlighter - > set_function_color ( function_color ) ;
syntax_highlighter - > set_member_variable_color ( members_color ) ;
syntax_highlighter - > clear_color_regions ( ) ;
syntax_highlighter - > add_color_region ( " /* " , " */ " , comment_color , false ) ;
syntax_highlighter - > add_color_region ( " // " , " " , comment_color , true ) ;
preview_text - > clear_comment_delimiters ( ) ;
preview_text - > add_comment_delimiter ( " /* " , " */ " , false ) ;
preview_text - > add_comment_delimiter ( " // " , " " , true ) ;
2024-05-14 15:50:53 +02:00
error_panel - > add_theme_style_override ( SceneStringName ( panel ) , get_theme_stylebox ( SceneStringName ( panel ) , SNAME ( " Panel " ) ) ) ;
2023-10-19 18:05:19 +02:00
error_label - > begin_bulk_theme_override ( ) ;
2024-05-14 15:57:29 +02:00
error_label - > add_theme_font_override ( SceneStringName ( font ) , get_theme_font ( SNAME ( " status_source " ) , EditorStringName ( EditorFonts ) ) ) ;
error_label - > add_theme_font_size_override ( SceneStringName ( font_size ) , get_theme_font_size ( SNAME ( " status_source_size " ) , EditorStringName ( EditorFonts ) ) ) ;
error_label - > add_theme_color_override ( SceneStringName ( font_color ) , error_color ) ;
2023-10-19 18:05:19 +02:00
error_label - > end_bulk_theme_override ( ) ;
2022-02-16 15:17:55 +01:00
}
2019-08-25 07:42:21 +02:00
2023-08-13 02:33:39 +02:00
tools - > set_icon ( get_editor_theme_icon ( SNAME ( " Tools " ) ) ) ;
2020-09-10 22:25:40 +02:00
2024-07-11 15:20:25 +02:00
if ( is_visible_in_tree ( ) ) {
2022-02-16 15:17:55 +01:00
_update_graph ( ) ;
}
} break ;
2019-08-18 11:29:22 +02:00
2022-02-16 15:17:55 +01:00
case NOTIFICATION_DRAG_BEGIN : {
Dictionary dd = get_viewport ( ) - > gui_get_drag_data ( ) ;
if ( members - > is_visible_in_tree ( ) & & dd . has ( " id " ) ) {
members - > set_drop_mode_flags ( Tree : : DROP_MODE_ON_ITEM ) ;
}
} break ;
2019-02-22 18:38:58 +01:00
2022-02-16 15:17:55 +01:00
case NOTIFICATION_DRAG_END : {
members - > set_drop_mode_flags ( 0 ) ;
} break ;
2018-07-14 23:15:42 +02:00
}
}
void VisualShaderEditor : : _scroll_changed ( const Vector2 & p_scroll ) {
2020-05-14 16:41:43 +02:00
if ( updating ) {
2018-07-14 23:15:42 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
updating = true ;
visual_shader - > set_graph_offset ( p_scroll / EDSCALE ) ;
updating = false ;
}
void VisualShaderEditor : : _node_changed ( int p_id ) {
2020-05-14 16:41:43 +02:00
if ( updating ) {
2018-07-14 23:15:42 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
if ( is_visible_in_tree ( ) ) {
_update_graph ( ) ;
}
}
2024-02-07 02:37:26 +01:00
void VisualShaderEditor : : _nodes_linked_to_frame_request ( const TypedArray < StringName > & p_nodes , const StringName & p_frame ) {
Vector < int > node_ids ;
for ( int i = 0 ; i < p_nodes . size ( ) ; i + + ) {
node_ids . push_back ( p_nodes [ i ] . operator String ( ) . to_int ( ) ) ;
}
frame_node_id_to_link_to = p_frame . operator String ( ) . to_int ( ) ;
nodes_link_to_frame_buffer = node_ids ;
}
void VisualShaderEditor : : _frame_rect_changed ( const GraphFrame * p_frame , const Rect2 & p_new_rect ) {
if ( p_frame = = nullptr ) {
return ;
}
int node_id = String ( p_frame - > get_name ( ) ) . to_int ( ) ;
Ref < VisualShaderNodeResizableBase > vsnode = visual_shader - > get_node ( visual_shader - > get_shader_type ( ) , node_id ) ;
if ( vsnode . is_null ( ) ) {
return ;
}
vsnode - > set_size ( p_new_rect . size / graph - > get_zoom ( ) ) ;
}
2021-10-30 15:12:14 +02:00
void VisualShaderEditor : : _dup_copy_nodes ( int p_type , List < CopyItem > & r_items , List < VisualShader : : Connection > & r_connections ) {
2019-07-12 19:36:33 +02:00
VisualShader : : Type type = ( VisualShader : : Type ) p_type ;
selection_center . x = 0.0f ;
selection_center . y = 0.0f ;
2018-07-14 23:15:42 +02:00
2022-05-19 17:00:06 +02:00
HashSet < int > nodes ;
2021-10-30 15:12:14 +02:00
2018-07-14 23:15:42 +02:00
for ( int i = 0 ; i < graph - > get_child_count ( ) ; i + + ) {
2023-08-09 18:31:15 +02:00
GraphElement * graph_element = Object : : cast_to < GraphElement > ( graph - > get_child ( i ) ) ;
if ( graph_element ) {
int id = String ( graph_element - > get_name ( ) ) . to_int ( ) ;
2021-10-30 15:12:14 +02:00
2018-07-14 23:15:42 +02:00
Ref < VisualShaderNode > node = visual_shader - > get_node ( type , id ) ;
Ref < VisualShaderNodeOutput > output = node ;
2018-12-09 11:51:09 +01:00
if ( output . is_valid ( ) ) { // can't duplicate output
2018-07-14 23:15:42 +02:00
continue ;
2018-12-09 11:51:09 +01:00
}
2021-10-30 15:12:14 +02:00
2023-08-09 18:31:15 +02:00
if ( node . is_valid ( ) & & graph_element - > is_selected ( ) ) {
2019-07-12 19:36:33 +02:00
Vector2 pos = visual_shader - > get_node_position ( type , id ) ;
selection_center + = pos ;
2021-10-30 15:12:14 +02:00
CopyItem item ;
item . id = id ;
item . node = visual_shader - > get_node ( type , id ) - > duplicate ( ) ;
item . position = visual_shader - > get_node_position ( type , id ) ;
Ref < VisualShaderNodeResizableBase > resizable_base = node ;
if ( resizable_base . is_valid ( ) ) {
item . size = resizable_base - > get_size ( ) ;
}
Ref < VisualShaderNodeGroupBase > group = node ;
if ( group . is_valid ( ) ) {
item . group_inputs = group - > get_inputs ( ) ;
item . group_outputs = group - > get_outputs ( ) ;
}
Ref < VisualShaderNodeExpression > expression = node ;
if ( expression . is_valid ( ) ) {
item . expression = expression - > get_expression ( ) ;
}
r_items . push_back ( item ) ;
nodes . insert ( id ) ;
2018-07-14 23:15:42 +02:00
}
}
}
2022-09-29 11:53:28 +02:00
List < VisualShader : : Connection > node_connections ;
visual_shader - > get_node_connections ( type , & node_connections ) ;
2021-10-30 15:12:14 +02:00
2022-09-29 11:53:28 +02:00
for ( const VisualShader : : Connection & E : node_connections ) {
2021-10-30 15:12:14 +02:00
if ( nodes . has ( E . from_node ) & & nodes . has ( E . to_node ) ) {
r_connections . push_back ( E ) ;
}
}
selection_center / = ( float ) r_items . size ( ) ;
2019-07-12 19:36:33 +02:00
}
2018-07-14 23:15:42 +02:00
2021-10-30 15:12:14 +02:00
void VisualShaderEditor : : _dup_paste_nodes ( int p_type , List < CopyItem > & r_items , const List < VisualShader : : Connection > & p_connections , const Vector2 & p_offset , bool p_duplicate ) {
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2021-10-30 15:12:14 +02:00
if ( p_duplicate ) {
undo_redo - > create_action ( TTR ( " Duplicate VisualShader Node(s) " ) ) ;
} else {
2022-02-07 20:58:37 +01:00
bool copy_buffer_empty = true ;
for ( const CopyItem & item : copy_items_buffer ) {
if ( ! item . disabled ) {
copy_buffer_empty = false ;
break ;
}
}
if ( copy_buffer_empty ) {
return ;
}
2021-10-30 15:12:14 +02:00
undo_redo - > create_action ( TTR ( " Paste VisualShader Node(s) " ) ) ;
}
2019-07-12 19:36:33 +02:00
VisualShader : : Type type = ( VisualShader : : Type ) p_type ;
2018-07-14 23:15:42 +02:00
int base_id = visual_shader - > get_valid_node_id ( type ) ;
int id_from = base_id ;
2024-02-07 02:37:26 +01:00
HashMap < int , int > connection_remap ; // Used for connections and frame attachments.
2022-05-19 17:00:06 +02:00
HashSet < int > unsupported_set ;
HashSet < int > added_set ;
2018-07-14 23:15:42 +02:00
2021-10-30 15:12:14 +02:00
for ( CopyItem & item : r_items ) {
2022-02-07 20:58:37 +01:00
if ( item . disabled ) {
2021-10-30 15:12:14 +02:00
unsupported_set . insert ( item . id ) ;
2019-08-07 15:46:47 +02:00
continue ;
}
2021-10-30 15:12:14 +02:00
connection_remap [ item . id ] = id_from ;
Ref < VisualShaderNode > node = item . node - > duplicate ( ) ;
2024-02-07 02:37:26 +01:00
node - > set_frame ( - 1 ) ; // Do not reattach nodes to frame (for now).
2018-07-14 23:15:42 +02:00
2021-10-30 15:12:14 +02:00
Ref < VisualShaderNodeResizableBase > resizable_base = Object : : cast_to < VisualShaderNodeResizableBase > ( node . ptr ( ) ) ;
if ( resizable_base . is_valid ( ) ) {
undo_redo - > add_do_method ( node . ptr ( ) , " set_size " , item . size ) ;
}
2018-07-14 23:15:42 +02:00
2024-02-07 02:37:26 +01:00
Ref < VisualShaderNodeFrame > frame = Object : : cast_to < VisualShaderNodeFrame > ( node . ptr ( ) ) ;
if ( frame . is_valid ( ) ) {
// Do not reattach nodes to frame (for now).
undo_redo - > add_do_method ( node . ptr ( ) , " set_attached_nodes " , PackedInt32Array ( ) ) ;
}
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeGroupBase > group = Object : : cast_to < VisualShaderNodeGroupBase > ( node . ptr ( ) ) ;
2021-10-30 15:12:14 +02:00
if ( group . is_valid ( ) ) {
undo_redo - > add_do_method ( node . ptr ( ) , " set_inputs " , item . group_inputs ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " set_outputs " , item . group_outputs ) ;
2019-05-12 14:09:39 +02:00
}
2021-10-30 15:12:14 +02:00
2019-05-12 14:09:39 +02:00
Ref < VisualShaderNodeExpression > expression = Object : : cast_to < VisualShaderNodeExpression > ( node . ptr ( ) ) ;
2021-10-30 15:12:14 +02:00
if ( expression . is_valid ( ) ) {
undo_redo - > add_do_method ( node . ptr ( ) , " set_expression " , item . expression ) ;
2019-05-12 14:09:39 +02:00
}
2021-10-30 15:12:14 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " add_node " , type , node , item . position + p_offset , id_from ) ;
2024-02-07 02:37:26 +01:00
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " add_node " , type , id_from , false , false ) ;
2021-10-30 15:12:14 +02:00
added_set . insert ( id_from ) ;
2018-07-14 23:15:42 +02:00
id_from + + ;
}
2024-02-07 02:37:26 +01:00
// Attach nodes to frame.
for ( const CopyItem & item : r_items ) {
Ref < VisualShaderNode > node = item . node ;
if ( node - > get_frame ( ) = = - 1 ) {
continue ;
}
int new_node_id = connection_remap [ item . id ] ;
2024-05-20 09:56:16 +02:00
int new_frame_id = node - > get_frame ( ) ;
2024-02-07 02:37:26 +01:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " attach_node_to_frame " , type , new_node_id , new_frame_id ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " attach_node_to_frame " , type , new_node_id , new_frame_id ) ;
}
// Connect nodes.
2021-10-30 15:12:14 +02:00
for ( const VisualShader : : Connection & E : p_connections ) {
2021-07-16 05:45:57 +02:00
if ( unsupported_set . has ( E . from_node ) | | unsupported_set . has ( E . to_node ) ) {
2019-08-07 15:46:47 +02:00
continue ;
}
2021-10-30 15:12:14 +02:00
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " connect_nodes " , type , connection_remap [ E . from_node ] , E . from_port , connection_remap [ E . to_node ] , E . to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , connection_remap [ E . from_node ] , E . from_port , connection_remap [ E . to_node ] , E . to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , connection_remap [ E . from_node ] , E . from_port , connection_remap [ E . to_node ] , E . to_port ) ;
2018-07-14 23:15:42 +02:00
}
2020-09-10 07:31:07 +02:00
id_from = base_id ;
2022-02-07 20:58:37 +01:00
for ( const CopyItem & item : r_items ) {
if ( item . disabled ) {
continue ;
}
2020-09-10 07:31:07 +02:00
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " remove_node " , type , id_from ) ;
2023-01-12 12:19:55 +01:00
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " remove_node " , type , id_from , false ) ;
2020-09-10 07:31:07 +02:00
id_from + + ;
}
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
2024-02-07 02:37:26 +01:00
// Reselect nodes by excluding the other ones.
2021-10-30 15:12:14 +02:00
for ( int i = 0 ; i < graph - > get_child_count ( ) ; i + + ) {
2023-08-09 18:31:15 +02:00
GraphElement * graph_element = Object : : cast_to < GraphElement > ( graph - > get_child ( i ) ) ;
if ( graph_element ) {
int id = String ( graph_element - > get_name ( ) ) . to_int ( ) ;
2021-10-30 15:12:14 +02:00
if ( added_set . has ( id ) ) {
2023-08-09 18:31:15 +02:00
graph_element - > set_selected ( true ) ;
2021-10-30 15:12:14 +02:00
} else {
2023-08-09 18:31:15 +02:00
graph_element - > set_selected ( false ) ;
2018-07-14 23:15:42 +02:00
}
}
}
}
2021-10-30 15:12:14 +02:00
void VisualShaderEditor : : _clear_copy_buffer ( ) {
copy_items_buffer . clear ( ) ;
copy_connections_buffer . clear ( ) ;
2019-07-12 19:36:33 +02:00
}
void VisualShaderEditor : : _duplicate_nodes ( ) {
2020-10-15 10:23:08 +02:00
int type = get_current_shader_type ( ) ;
2019-07-12 19:36:33 +02:00
2021-10-30 15:12:14 +02:00
List < CopyItem > items ;
2022-09-29 11:53:28 +02:00
List < VisualShader : : Connection > node_connections ;
2019-07-12 19:36:33 +02:00
2022-09-29 11:53:28 +02:00
_dup_copy_nodes ( type , items , node_connections ) ;
2019-07-12 19:36:33 +02:00
2021-10-30 15:12:14 +02:00
if ( items . is_empty ( ) ) {
2019-07-12 19:36:33 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2019-07-12 19:36:33 +02:00
2022-09-29 11:53:28 +02:00
_dup_paste_nodes ( type , items , node_connections , Vector2 ( 10 , 10 ) * EDSCALE , true ) ;
2019-07-12 19:36:33 +02:00
}
2021-10-30 15:12:14 +02:00
void VisualShaderEditor : : _copy_nodes ( bool p_cut ) {
_clear_copy_buffer ( ) ;
2019-07-12 19:36:33 +02:00
2021-10-30 15:12:14 +02:00
_dup_copy_nodes ( get_current_shader_type ( ) , copy_items_buffer , copy_connections_buffer ) ;
2019-07-12 19:36:33 +02:00
2021-10-30 15:12:14 +02:00
if ( p_cut ) {
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2021-10-30 15:12:14 +02:00
undo_redo - > create_action ( TTR ( " Cut VisualShader Node(s) " ) ) ;
List < int > ids ;
for ( const CopyItem & E : copy_items_buffer ) {
ids . push_back ( E . id ) ;
}
_delete_nodes ( get_current_shader_type ( ) , ids ) ;
undo_redo - > commit_action ( ) ;
}
2019-07-12 19:36:33 +02:00
}
2020-02-27 10:10:09 +01:00
void VisualShaderEditor : : _paste_nodes ( bool p_use_custom_position , const Vector2 & p_custom_position ) {
2021-10-30 15:12:14 +02:00
if ( copy_items_buffer . is_empty ( ) ) {
2019-07-12 19:36:33 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2019-07-12 19:36:33 +02:00
2020-10-15 10:23:08 +02:00
int type = get_current_shader_type ( ) ;
2019-07-12 19:36:33 +02:00
float scale = graph - > get_zoom ( ) ;
2020-02-27 10:10:09 +01:00
Vector2 mpos ;
if ( p_use_custom_position ) {
mpos = p_custom_position ;
} else {
mpos = graph - > get_local_mouse_position ( ) ;
}
2023-07-10 17:26:02 +02:00
_dup_paste_nodes ( type , copy_items_buffer , copy_connections_buffer , graph - > get_scroll_offset ( ) / scale + mpos / scale - selection_center , false ) ;
2019-07-12 19:36:33 +02:00
}
2018-07-14 23:15:42 +02:00
void VisualShaderEditor : : _mode_selected ( int p_id ) {
2021-04-17 19:16:03 +02:00
int offset = 0 ;
if ( mode & MODE_FLAGS_PARTICLES ) {
offset = 3 ;
2020-09-15 09:57:40 +02:00
if ( p_id + offset > VisualShader : : TYPE_PROCESS ) {
custom_mode_box - > set_visible ( false ) ;
custom_mode_enabled = false ;
} else {
custom_mode_box - > set_visible ( true ) ;
if ( custom_mode_box - > is_pressed ( ) ) {
custom_mode_enabled = true ;
offset + = 3 ;
}
}
2021-04-17 19:16:03 +02:00
} else if ( mode & MODE_FLAGS_SKY ) {
2020-09-15 09:57:40 +02:00
offset = 8 ;
2021-10-29 15:42:33 +02:00
} else if ( mode & MODE_FLAGS_FOG ) {
offset = 9 ;
2021-04-17 19:16:03 +02:00
}
visual_shader - > set_shader_type ( VisualShader : : Type ( p_id + offset ) ) ;
2022-02-07 20:58:37 +01:00
_update_nodes ( ) ;
2018-07-14 23:15:42 +02:00
_update_graph ( ) ;
2021-10-30 15:12:14 +02:00
graph - > grab_focus ( ) ;
2018-07-14 23:15:42 +02:00
}
2020-09-15 09:57:40 +02:00
void VisualShaderEditor : : _custom_mode_toggled ( bool p_enabled ) {
if ( ! ( mode & MODE_FLAGS_PARTICLES ) ) {
return ;
}
custom_mode_enabled = p_enabled ;
int id = edit_type - > get_selected ( ) + 3 ;
if ( p_enabled ) {
visual_shader - > set_shader_type ( VisualShader : : Type ( id + 3 ) ) ;
} else {
visual_shader - > set_shader_type ( VisualShader : : Type ( id ) ) ;
}
_update_options_menu ( ) ;
_update_graph ( ) ;
}
2024-02-15 17:25:58 +01:00
void VisualShaderEditor : : _input_select_item ( Ref < VisualShaderNodeInput > p_input , const String & p_name ) {
2020-09-21 13:32:59 +02:00
String prev_name = p_input - > get_input_name ( ) ;
2018-07-14 23:15:42 +02:00
2020-09-21 13:32:59 +02:00
if ( p_name = = prev_name ) {
2018-07-14 23:15:42 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
2022-04-22 19:31:23 +02:00
VisualShaderNode : : PortType next_input_type = p_input - > get_input_type_by_name ( p_name ) ;
VisualShaderNode : : PortType prev_input_type = p_input - > get_input_type_by_name ( prev_name ) ;
bool type_changed = next_input_type ! = prev_input_type ;
2018-07-14 23:15:42 +02:00
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo_man = EditorUndoRedoManager : : get_singleton ( ) ;
2022-09-29 11:53:28 +02:00
undo_redo_man - > create_action ( TTR ( " Visual Shader Input Type Changed " ) ) ;
2018-07-14 23:15:42 +02:00
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( p_input . ptr ( ) , " set_input_name " , p_name ) ;
undo_redo_man - > add_undo_method ( p_input . ptr ( ) , " set_input_name " , prev_name ) ;
2020-09-21 13:32:59 +02:00
2022-04-22 19:31:23 +02:00
if ( type_changed ) {
for ( int type_id = 0 ; type_id < VisualShader : : TYPE_MAX ; type_id + + ) {
VisualShader : : Type type = VisualShader : : Type ( type_id ) ;
int id = visual_shader - > find_node_id ( type , p_input ) ;
if ( id ! = VisualShader : : NODE_ID_INVALID ) {
bool is_expanded = p_input - > is_output_port_expandable ( 0 ) & & p_input - > _is_output_port_expanded ( 0 ) ;
int type_size = 0 ;
if ( is_expanded ) {
switch ( next_input_type ) {
case VisualShaderNode : : PORT_TYPE_VECTOR_2D : {
type_size = 2 ;
} break ;
case VisualShaderNode : : PORT_TYPE_VECTOR_3D : {
type_size = 3 ;
} break ;
case VisualShaderNode : : PORT_TYPE_VECTOR_4D : {
type_size = 4 ;
} break ;
default :
break ;
}
}
2020-09-21 13:32:59 +02:00
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2022-09-29 11:53:28 +02:00
int cn_from_node = E . from_node ;
int cn_from_port = E . from_port ;
int cn_to_node = E . to_node ;
int cn_to_port = E . to_port ;
if ( cn_from_node = = id ) {
bool is_incompatible_types = ! visual_shader - > is_port_types_compatible ( p_input - > get_input_type_by_name ( p_name ) , visual_shader - > get_node ( type , cn_to_node ) - > get_input_port_type ( cn_to_port ) ) ;
if ( is_incompatible_types | | cn_from_port > type_size ) {
undo_redo_man - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo_man - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo_man - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
undo_redo_man - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , cn_from_node , cn_from_port , cn_to_node , cn_to_port ) ;
2020-09-21 13:32:59 +02:00
}
}
}
2022-04-22 19:31:23 +02:00
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type_id , id ) ;
undo_redo_man - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type_id , id ) ;
2018-07-14 23:15:42 +02:00
}
}
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > commit_action ( ) ;
2018-07-14 23:15:42 +02:00
}
2024-02-15 17:25:58 +01:00
void VisualShaderEditor : : _parameter_ref_select_item ( Ref < VisualShaderNodeParameterRef > p_parameter_ref , const String & p_name ) {
2022-08-27 11:22:43 +02:00
String prev_name = p_parameter_ref - > get_parameter_name ( ) ;
2020-07-28 10:02:57 +02:00
if ( p_name = = prev_name ) {
return ;
}
2022-08-27 11:22:43 +02:00
bool type_changed = p_parameter_ref - > get_parameter_type_by_name ( p_name ) ! = p_parameter_ref - > get_parameter_type_by_name ( prev_name ) ;
2020-07-28 10:02:57 +02:00
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo_man = EditorUndoRedoManager : : get_singleton ( ) ;
2022-09-29 11:53:28 +02:00
undo_redo_man - > create_action ( TTR ( " ParameterRef Name Changed " ) ) ;
2020-07-28 10:02:57 +02:00
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( p_parameter_ref . ptr ( ) , " set_parameter_name " , p_name ) ;
undo_redo_man - > add_undo_method ( p_parameter_ref . ptr ( ) , " set_parameter_name " , prev_name ) ;
2020-07-28 10:02:57 +02:00
2020-09-21 13:32:59 +02:00
// update output port
for ( int type_id = 0 ; type_id < VisualShader : : TYPE_MAX ; type_id + + ) {
VisualShader : : Type type = VisualShader : : Type ( type_id ) ;
2022-08-27 11:22:43 +02:00
int id = visual_shader - > find_node_id ( type , p_parameter_ref ) ;
2020-09-21 13:32:59 +02:00
if ( id ! = VisualShader : : NODE_ID_INVALID ) {
if ( type_changed ) {
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2021-07-16 05:45:57 +02:00
if ( E . from_node = = id ) {
2022-08-27 11:22:43 +02:00
if ( visual_shader - > is_port_types_compatible ( p_parameter_ref - > get_parameter_type_by_name ( p_name ) , visual_shader - > get_node ( type , E . to_node ) - > get_input_port_type ( E . to_port ) ) ) {
2020-09-21 13:32:59 +02:00
continue ;
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
2020-09-21 13:32:59 +02:00
}
}
2020-07-28 10:02:57 +02:00
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type_id , id ) ;
undo_redo_man - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type_id , id ) ;
2020-09-21 13:32:59 +02:00
break ;
2020-07-28 10:02:57 +02:00
}
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > commit_action ( ) ;
2020-07-28 10:02:57 +02:00
}
2024-02-15 17:25:58 +01:00
void VisualShaderEditor : : _varying_select_item ( Ref < VisualShaderNodeVarying > p_varying , const String & p_name ) {
2022-01-09 15:02:13 +01:00
String prev_name = p_varying - > get_varying_name ( ) ;
if ( p_name = = prev_name ) {
return ;
}
bool is_getter = Ref < VisualShaderNodeVaryingGetter > ( p_varying . ptr ( ) ) . is_valid ( ) ;
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo_man = EditorUndoRedoManager : : get_singleton ( ) ;
2022-09-29 11:53:28 +02:00
undo_redo_man - > create_action ( TTR ( " Varying Name Changed " ) ) ;
2022-01-09 15:02:13 +01:00
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( p_varying . ptr ( ) , " set_varying_name " , p_name ) ;
undo_redo_man - > add_undo_method ( p_varying . ptr ( ) , " set_varying_name " , prev_name ) ;
2022-01-09 15:02:13 +01:00
VisualShader : : VaryingType vtype = p_varying - > get_varying_type_by_name ( p_name ) ;
VisualShader : : VaryingType prev_vtype = p_varying - > get_varying_type_by_name ( prev_name ) ;
bool type_changed = vtype ! = prev_vtype ;
if ( type_changed ) {
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( p_varying . ptr ( ) , " set_varying_type " , vtype ) ;
undo_redo_man - > add_undo_method ( p_varying . ptr ( ) , " set_varying_type " , prev_vtype ) ;
2022-01-09 15:02:13 +01:00
}
// update ports
for ( int type_id = 0 ; type_id < VisualShader : : TYPE_MAX ; type_id + + ) {
VisualShader : : Type type = VisualShader : : Type ( type_id ) ;
int id = visual_shader - > find_node_id ( type , p_varying ) ;
if ( id ! = VisualShader : : NODE_ID_INVALID ) {
if ( type_changed ) {
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
for ( const VisualShader : : Connection & E : conns ) {
if ( is_getter ) {
if ( E . from_node = = id ) {
if ( visual_shader - > is_port_types_compatible ( p_varying - > get_varying_type_by_name ( p_name ) , visual_shader - > get_node ( type , E . to_node ) - > get_input_port_type ( E . to_port ) ) ) {
continue ;
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
2022-01-09 15:02:13 +01:00
}
} else {
if ( E . to_node = = id ) {
if ( visual_shader - > is_port_types_compatible ( p_varying - > get_varying_type_by_name ( p_name ) , visual_shader - > get_node ( type , E . from_node ) - > get_output_port_type ( E . from_port ) ) ) {
continue ;
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
undo_redo_man - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
2022-01-09 15:02:13 +01:00
}
}
}
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > add_do_method ( graph_plugin . ptr ( ) , " update_node " , type_id , id ) ;
undo_redo_man - > add_undo_method ( graph_plugin . ptr ( ) , " update_node " , type_id , id ) ;
2022-01-09 15:02:13 +01:00
break ;
}
}
2022-09-29 11:53:28 +02:00
undo_redo_man - > commit_action ( ) ;
2022-01-09 15:02:13 +01:00
}
2021-07-03 10:11:10 +02:00
void VisualShaderEditor : : _float_constant_selected ( int p_which ) {
ERR_FAIL_INDEX ( p_which , MAX_FLOAT_CONST_DEFS ) ;
2020-10-01 10:10:51 +02:00
VisualShader : : Type type = get_current_shader_type ( ) ;
2021-07-03 10:11:10 +02:00
Ref < VisualShaderNodeFloatConstant > node = visual_shader - > get_node ( type , selected_float_constant ) ;
ERR_FAIL_COND ( ! node . is_valid ( ) ) ;
if ( Math : : is_equal_approx ( node - > get_constant ( ) , float_constant_defs [ p_which ] . value ) ) {
return ; // same
2020-10-01 10:10:51 +02:00
}
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2021-07-03 10:11:10 +02:00
undo_redo - > create_action ( vformat ( TTR ( " Set Constant: %s " ) , float_constant_defs [ p_which ] . name ) ) ;
undo_redo - > add_do_method ( node . ptr ( ) , " set_constant " , float_constant_defs [ p_which ] . value ) ;
2020-10-01 10:10:51 +02:00
undo_redo - > add_undo_method ( node . ptr ( ) , " set_constant " , node - > get_constant ( ) ) ;
undo_redo - > commit_action ( ) ;
}
2019-02-22 18:38:58 +01:00
void VisualShaderEditor : : _member_filter_changed ( const String & p_text ) {
_update_options_menu ( ) ;
}
void VisualShaderEditor : : _member_selected ( ) {
TreeItem * item = members - > get_selected ( ) ;
2020-04-02 01:20:12 +02:00
if ( item ! = nullptr & & item - > has_meta ( " id " ) ) {
2020-12-14 19:37:30 +01:00
members_dialog - > get_ok_button ( ) - > set_disabled ( false ) ;
2020-02-12 16:39:19 +01:00
highend_label - > set_visible ( add_options [ item - > get_meta ( " id " ) ] . highend ) ;
2019-08-25 09:33:18 +02:00
node_desc - > set_text ( _get_description ( item - > get_meta ( " id " ) ) ) ;
2019-02-22 18:38:58 +01:00
} else {
2020-02-12 16:39:19 +01:00
highend_label - > set_visible ( false ) ;
2020-12-14 19:37:30 +01:00
members_dialog - > get_ok_button ( ) - > set_disabled ( true ) ;
2019-02-22 18:38:58 +01:00
node_desc - > set_text ( " " ) ;
}
}
void VisualShaderEditor : : _member_create ( ) {
TreeItem * item = members - > get_selected ( ) ;
2020-04-02 01:20:12 +02:00
if ( item ! = nullptr & & item - > has_meta ( " id " ) ) {
2019-02-22 18:38:58 +01:00
int idx = members - > get_selected ( ) - > get_meta ( " id " ) ;
2024-01-19 11:35:46 +01:00
if ( connection_node_insert_requested ) {
from_node = String ( clicked_connection - > from_node ) . to_int ( ) ;
from_slot = clicked_connection - > from_port ;
to_node = String ( clicked_connection - > to_node ) . to_int ( ) ;
to_slot = clicked_connection - > to_port ;
connection_node_insert_requested = false ;
saved_node_pos_dirty = true ;
// Find both graph nodes and get their positions.
GraphNode * from_graph_element = Object : : cast_to < GraphNode > ( graph - > get_node ( itos ( from_node ) ) ) ;
GraphNode * to_graph_element = Object : : cast_to < GraphNode > ( graph - > get_node ( itos ( to_node ) ) ) ;
ERR_FAIL_NULL ( from_graph_element ) ;
ERR_FAIL_NULL ( to_graph_element ) ;
// Since the size of the node to add is not known yet, it's not possible to center it exactly.
float zoom = graph - > get_zoom ( ) ;
saved_node_pos = 0.5 * ( from_graph_element - > get_position ( ) + zoom * from_graph_element - > get_output_port_position ( from_slot ) + to_graph_element - > get_position ( ) + zoom * to_graph_element - > get_input_port_position ( to_slot ) ) ;
}
2022-01-28 12:36:35 +01:00
_add_node ( idx , add_options [ idx ] . ops ) ;
2019-02-22 18:38:58 +01:00
members_dialog - > hide ( ) ;
}
}
2019-06-26 20:50:38 +02:00
void VisualShaderEditor : : _member_cancel ( ) {
to_node = - 1 ;
to_slot = - 1 ;
from_node = - 1 ;
from_slot = - 1 ;
2024-01-19 11:35:46 +01:00
connection_node_insert_requested = false ;
2019-06-26 20:50:38 +02:00
}
2022-01-09 15:02:13 +01:00
void VisualShaderEditor : : _update_varying_tree ( ) {
varyings - > clear ( ) ;
TreeItem * root = varyings - > create_item ( ) ;
int count = visual_shader - > get_varyings_count ( ) ;
for ( int i = 0 ; i < count ; i + + ) {
const VisualShader : : Varying * varying = visual_shader - > get_varying_by_index ( i ) ;
if ( varying ) {
TreeItem * item = varyings - > create_item ( root ) ;
item - > set_text ( 0 , varying - > name ) ;
if ( i = = 0 ) {
item - > select ( 0 ) ;
}
switch ( varying - > type ) {
case VisualShader : : VARYING_TYPE_FLOAT :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " float " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-01-09 15:02:13 +01:00
break ;
2022-08-24 11:41:42 +02:00
case VisualShader : : VARYING_TYPE_INT :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " int " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-08-24 11:41:42 +02:00
break ;
2022-12-27 18:49:11 +01:00
case VisualShader : : VARYING_TYPE_UINT :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " uint " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-12-27 18:49:11 +01:00
break ;
2022-01-09 15:02:13 +01:00
case VisualShader : : VARYING_TYPE_VECTOR_2D :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector2 " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-01-09 15:02:13 +01:00
break ;
case VisualShader : : VARYING_TYPE_VECTOR_3D :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector3 " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-01-09 15:02:13 +01:00
break ;
2022-04-12 19:09:29 +02:00
case VisualShader : : VARYING_TYPE_VECTOR_4D :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector4 " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-04-12 19:09:29 +02:00
break ;
2022-08-24 11:41:42 +02:00
case VisualShader : : VARYING_TYPE_BOOLEAN :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " bool " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-01-09 15:02:13 +01:00
break ;
case VisualShader : : VARYING_TYPE_TRANSFORM :
2023-09-13 13:14:07 +02:00
item - > set_icon ( 0 , EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Transform3D " ) , EditorStringName ( EditorIcons ) ) ) ;
2022-01-09 15:02:13 +01:00
break ;
default :
break ;
}
}
}
2022-11-16 20:05:09 +01:00
varying_button - > get_popup ( ) - > set_item_disabled ( int ( VaryingMenuOptions : : REMOVE ) , count = = 0 ) ;
2022-01-09 15:02:13 +01:00
}
void VisualShaderEditor : : _varying_create ( ) {
_add_varying ( varying_name - > get_text ( ) , ( VisualShader : : VaryingMode ) varying_mode - > get_selected ( ) , ( VisualShader : : VaryingType ) varying_type - > get_selected ( ) ) ;
add_varying_dialog - > hide ( ) ;
}
2023-12-13 17:06:14 +01:00
void VisualShaderEditor : : _varying_name_changed ( const String & p_name ) {
2024-08-23 08:30:51 +02:00
if ( ! p_name . is_valid_ascii_identifier ( ) ) {
2022-01-09 15:02:13 +01:00
varying_error_label - > show ( ) ;
varying_error_label - > set_text ( TTR ( " Invalid name for varying. " ) ) ;
add_varying_dialog - > get_ok_button ( ) - > set_disabled ( true ) ;
return ;
}
2023-12-13 17:06:14 +01:00
if ( visual_shader - > has_varying ( p_name ) ) {
2022-01-09 15:02:13 +01:00
varying_error_label - > show ( ) ;
varying_error_label - > set_text ( TTR ( " Varying with that name is already exist. " ) ) ;
add_varying_dialog - > get_ok_button ( ) - > set_disabled ( true ) ;
return ;
}
if ( varying_error_label - > is_visible ( ) ) {
varying_error_label - > hide ( ) ;
add_varying_dialog - > set_size ( Size2 ( add_varying_dialog - > get_size ( ) . x , 0 ) ) ;
}
add_varying_dialog - > get_ok_button ( ) - > set_disabled ( false ) ;
}
void VisualShaderEditor : : _varying_deleted ( ) {
TreeItem * item = varyings - > get_selected ( ) ;
if ( item ! = nullptr ) {
_remove_varying ( item - > get_text ( 0 ) ) ;
remove_varying_dialog - > hide ( ) ;
}
}
void VisualShaderEditor : : _varying_selected ( ) {
add_varying_dialog - > get_ok_button ( ) - > set_disabled ( false ) ;
}
void VisualShaderEditor : : _varying_unselected ( ) {
add_varying_dialog - > get_ok_button ( ) - > set_disabled ( true ) ;
}
2019-02-22 18:38:58 +01:00
void VisualShaderEditor : : _tools_menu_option ( int p_idx ) {
2021-03-07 21:07:30 +01:00
TreeItem * category = members - > get_root ( ) - > get_first_child ( ) ;
2019-02-22 18:38:58 +01:00
switch ( p_idx ) {
case EXPAND_ALL :
while ( category ) {
category - > set_collapsed ( false ) ;
2021-03-07 21:07:30 +01:00
TreeItem * sub_category = category - > get_first_child ( ) ;
2019-02-22 18:38:58 +01:00
while ( sub_category ) {
sub_category - > set_collapsed ( false ) ;
sub_category = sub_category - > get_next ( ) ;
}
category = category - > get_next ( ) ;
}
break ;
case COLLAPSE_ALL :
while ( category ) {
category - > set_collapsed ( true ) ;
2021-03-07 21:07:30 +01:00
TreeItem * sub_category = category - > get_first_child ( ) ;
2019-02-22 18:38:58 +01:00
while ( sub_category ) {
sub_category - > set_collapsed ( true ) ;
sub_category = sub_category - > get_next ( ) ;
}
category = category - > get_next ( ) ;
}
break ;
default :
break ;
}
}
2020-02-27 10:10:09 +01:00
void VisualShaderEditor : : _node_menu_id_pressed ( int p_idx ) {
switch ( p_idx ) {
case NodeMenuOptions : : ADD :
_show_members_dialog ( true ) ;
break ;
2021-10-30 15:12:14 +02:00
case NodeMenuOptions : : CUT :
_copy_nodes ( true ) ;
break ;
2020-02-27 10:10:09 +01:00
case NodeMenuOptions : : COPY :
2021-10-30 15:12:14 +02:00
_copy_nodes ( false ) ;
2020-02-27 10:10:09 +01:00
break ;
2020-02-27 11:55:41 +01:00
case NodeMenuOptions : : PASTE :
_paste_nodes ( true , menu_point ) ;
break ;
2020-02-27 10:10:09 +01:00
case NodeMenuOptions : : DELETE :
2023-09-26 16:41:39 +02:00
_delete_nodes_request ( TypedArray < StringName > ( ) ) ;
2020-02-27 10:10:09 +01:00
break ;
case NodeMenuOptions : : DUPLICATE :
_duplicate_nodes ( ) ;
break ;
2021-10-30 15:12:14 +02:00
case NodeMenuOptions : : CLEAR_COPY_BUFFER :
_clear_copy_buffer ( ) ;
break ;
2022-08-27 11:22:43 +02:00
case NodeMenuOptions : : CONVERT_CONSTANTS_TO_PARAMETERS :
_convert_constants_to_parameters ( false ) ;
2020-12-30 09:45:31 +01:00
break ;
2022-08-27 11:22:43 +02:00
case NodeMenuOptions : : CONVERT_PARAMETERS_TO_CONSTANTS :
_convert_constants_to_parameters ( true ) ;
2020-12-30 09:45:31 +01:00
break ;
2024-02-07 02:37:26 +01:00
case NodeMenuOptions : : UNLINK_FROM_PARENT_FRAME :
_detach_nodes_from_frame_request ( ) ;
break ;
case NodeMenuOptions : : SET_FRAME_TITLE :
_frame_title_popup_show ( get_screen_position ( ) + get_local_mouse_position ( ) , selected_frame ) ;
break ;
case NodeMenuOptions : : ENABLE_FRAME_COLOR :
_frame_color_enabled_changed ( selected_frame ) ;
2021-02-21 09:33:55 +01:00
break ;
2024-02-07 02:37:26 +01:00
case NodeMenuOptions : : SET_FRAME_COLOR :
_frame_color_popup_show ( get_screen_position ( ) + get_local_mouse_position ( ) , selected_frame ) ;
break ;
case NodeMenuOptions : : ENABLE_FRAME_AUTOSHRINK :
_frame_autoshrink_enabled_changed ( selected_frame ) ;
2021-02-21 09:33:55 +01:00
break ;
2020-12-30 09:45:31 +01:00
default :
break ;
2020-02-27 10:10:09 +01:00
}
}
2024-01-19 11:35:46 +01:00
void VisualShaderEditor : : _connection_menu_id_pressed ( int p_idx ) {
switch ( p_idx ) {
case ConnectionMenuOptions : : DISCONNECT : {
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
undo_redo - > create_action ( TTR ( " Disconnect " ) ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " disconnect_nodes " , get_current_shader_type ( ) , String ( clicked_connection - > from_node ) . to_int ( ) , clicked_connection - > from_port , String ( clicked_connection - > to_node ) . to_int ( ) , clicked_connection - > to_port ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , get_current_shader_type ( ) , String ( clicked_connection - > from_node ) . to_int ( ) , clicked_connection - > from_port , String ( clicked_connection - > to_node ) . to_int ( ) , clicked_connection - > to_port ) ;
undo_redo - > add_do_method ( graph_plugin . ptr ( ) , " disconnect_nodes " , get_current_shader_type ( ) , String ( clicked_connection - > from_node ) . to_int ( ) , clicked_connection - > from_port , String ( clicked_connection - > to_node ) . to_int ( ) , clicked_connection - > to_port ) ;
undo_redo - > add_undo_method ( graph_plugin . ptr ( ) , " connect_nodes " , get_current_shader_type ( ) , String ( clicked_connection - > from_node ) . to_int ( ) , clicked_connection - > from_port , String ( clicked_connection - > to_node ) . to_int ( ) , clicked_connection - > to_port ) ;
undo_redo - > commit_action ( ) ;
} break ;
case ConnectionMenuOptions : : INSERT_NEW_NODE : {
VisualShaderNode : : PortType input_port_type = VisualShaderNode : : PORT_TYPE_MAX ;
VisualShaderNode : : PortType output_port_type = VisualShaderNode : : PORT_TYPE_MAX ;
Ref < VisualShaderNode > node1 = visual_shader - > get_node ( get_current_shader_type ( ) , String ( clicked_connection - > from_node ) . to_int ( ) ) ;
if ( node1 . is_valid ( ) ) {
output_port_type = node1 - > get_output_port_type ( from_slot ) ;
}
Ref < VisualShaderNode > node2 = visual_shader - > get_node ( get_current_shader_type ( ) , String ( clicked_connection - > to_node ) . to_int ( ) ) ;
if ( node2 . is_valid ( ) ) {
input_port_type = node2 - > get_input_port_type ( to_slot ) ;
}
connection_node_insert_requested = true ;
_show_members_dialog ( true , input_port_type , output_port_type ) ;
} break ;
2024-05-07 16:48:03 +02:00
case ConnectionMenuOptions : : INSERT_NEW_REROUTE : {
from_node = String ( clicked_connection - > from_node ) . to_int ( ) ;
from_slot = clicked_connection - > from_port ;
to_node = String ( clicked_connection - > to_node ) . to_int ( ) ;
to_slot = clicked_connection - > to_port ;
// Manual offset to place the port exactly at the mouse position.
saved_node_pos - = Vector2 ( 11 * EDSCALE * graph - > get_zoom ( ) , 50 * EDSCALE * graph - > get_zoom ( ) ) ;
// Find reroute addoptions.
int idx = - 1 ;
for ( int i = 0 ; i < add_options . size ( ) ; i + + ) {
if ( add_options [ i ] . name = = " Reroute " ) {
idx = i ;
break ;
}
}
_add_node ( idx , add_options [ idx ] . ops ) ;
} break ;
2024-01-19 11:35:46 +01:00
default :
break ;
}
}
2019-02-22 18:38:58 +01:00
Variant VisualShaderEditor : : get_drag_data_fw ( const Point2 & p_point , Control * p_from ) {
if ( p_from = = members ) {
TreeItem * it = members - > get_item_at_position ( p_point ) ;
2020-05-14 16:41:43 +02:00
if ( ! it ) {
2019-02-22 18:38:58 +01:00
return Variant ( ) ;
2020-05-14 16:41:43 +02:00
}
if ( ! it - > has_meta ( " id " ) ) {
2019-02-22 18:38:58 +01:00
return Variant ( ) ;
2020-05-14 16:41:43 +02:00
}
2019-02-22 18:38:58 +01:00
int id = it - > get_meta ( " id " ) ;
AddOption op = add_options [ id ] ;
Dictionary d ;
d [ " id " ] = id ;
Label * label = memnew ( Label ) ;
label - > set_text ( it - > get_text ( 0 ) ) ;
2024-09-19 02:14:00 +02:00
label - > set_auto_translate_mode ( AUTO_TRANSLATE_MODE_DISABLED ) ;
2019-02-22 18:38:58 +01:00
set_drag_preview ( label ) ;
return d ;
}
return Variant ( ) ;
}
bool VisualShaderEditor : : can_drop_data_fw ( const Point2 & p_point , const Variant & p_data , Control * p_from ) const {
if ( p_from = = graph ) {
Dictionary d = p_data ;
if ( d . has ( " id " ) ) {
return true ;
}
2019-09-30 13:25:32 +02:00
if ( d . has ( " files " ) ) {
return true ;
}
2019-02-22 18:38:58 +01:00
}
return false ;
}
void VisualShaderEditor : : drop_data_fw ( const Point2 & p_point , const Variant & p_data , Control * p_from ) {
if ( p_from = = graph ) {
Dictionary d = p_data ;
if ( d . has ( " id " ) ) {
int idx = d [ " id " ] ;
saved_node_pos = p_point ;
saved_node_pos_dirty = true ;
2022-01-28 12:36:35 +01:00
_add_node ( idx , add_options [ idx ] . ops ) ;
2019-09-30 13:25:32 +02:00
} else if ( d . has ( " files " ) ) {
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2021-05-24 12:37:47 +02:00
undo_redo - > create_action ( TTR ( " Add Node(s) to Visual Shader " ) ) ;
2020-02-17 22:06:54 +01:00
if ( d [ " files " ] . get_type ( ) = = Variant : : PACKED_STRING_ARRAY ) {
PackedStringArray arr = d [ " files " ] ;
2019-09-30 13:25:32 +02:00
for ( int i = 0 ; i < arr . size ( ) ; i + + ) {
String type = ResourceLoader : : get_resource_type ( arr [ i ] ) ;
2019-10-02 22:26:56 +02:00
if ( type = = " GDScript " ) {
2022-09-29 11:53:28 +02:00
Ref < Script > scr = ResourceLoader : : load ( arr [ i ] ) ;
if ( scr - > get_instance_base_type ( ) = = " VisualShaderNodeCustom " ) {
2021-05-22 05:28:24 +02:00
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
2019-10-02 22:26:56 +02:00
saved_node_pos_dirty = true ;
2021-05-22 05:28:24 +02:00
int idx = - 1 ;
for ( int j = custom_node_option_idx ; j < add_options . size ( ) ; j + + ) {
if ( add_options [ j ] . script . is_valid ( ) ) {
if ( add_options [ j ] . script - > get_path ( ) = = arr [ i ] ) {
idx = j ;
break ;
}
}
}
if ( idx ! = - 1 ) {
2022-01-28 12:36:35 +01:00
_add_node ( idx , { } , arr [ i ] , i ) ;
2021-05-22 05:28:24 +02:00
}
2019-10-02 22:26:56 +02:00
}
2020-10-04 11:11:58 +02:00
} else if ( type = = " CurveTexture " ) {
2021-05-22 05:28:24 +02:00
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
2020-10-04 11:11:58 +02:00
saved_node_pos_dirty = true ;
2022-01-28 12:36:35 +01:00
_add_node ( curve_node_option_idx , { } , arr [ i ] , i ) ;
2021-07-14 00:06:44 +02:00
} else if ( type = = " CurveXYZTexture " ) {
2021-07-04 10:56:21 +02:00
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
saved_node_pos_dirty = true ;
2022-01-28 12:36:35 +01:00
_add_node ( curve_xyz_node_option_idx , { } , arr [ i ] , i ) ;
2020-02-13 17:19:41 +01:00
} else if ( ClassDB : : get_parent_class ( type ) = = " Texture2D " ) {
2021-05-22 05:28:24 +02:00
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
2019-09-30 13:25:32 +02:00
saved_node_pos_dirty = true ;
2022-01-28 12:36:35 +01:00
_add_node ( texture2d_node_option_idx , { } , arr [ i ] , i ) ;
2020-09-29 14:27:36 +02:00
} else if ( type = = " Texture2DArray " ) {
2021-05-22 05:28:24 +02:00
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
2020-09-29 14:27:36 +02:00
saved_node_pos_dirty = true ;
2022-01-28 12:36:35 +01:00
_add_node ( texture2d_array_node_option_idx , { } , arr [ i ] , i ) ;
2020-09-29 14:27:36 +02:00
} else if ( ClassDB : : get_parent_class ( type ) = = " Texture3D " ) {
2021-05-22 05:28:24 +02:00
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
2020-09-29 14:27:36 +02:00
saved_node_pos_dirty = true ;
2022-01-28 12:36:35 +01:00
_add_node ( texture3d_node_option_idx , { } , arr [ i ] , i ) ;
2020-09-29 14:27:36 +02:00
} else if ( type = = " Cubemap " ) {
2021-05-22 05:28:24 +02:00
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
2020-09-29 14:27:36 +02:00
saved_node_pos_dirty = true ;
2022-01-28 12:36:35 +01:00
_add_node ( cubemap_node_option_idx , { } , arr [ i ] , i ) ;
2024-06-11 10:27:24 +02:00
} else if ( type = = " Mesh " & & visual_shader - > get_mode ( ) = = Shader : : MODE_PARTICLES & &
( visual_shader - > get_shader_type ( ) = = VisualShader : : TYPE_START | | visual_shader - > get_shader_type ( ) = = VisualShader : : TYPE_START_CUSTOM ) ) {
saved_node_pos = p_point + Vector2 ( 0 , i * 250 * EDSCALE ) ;
saved_node_pos_dirty = true ;
_add_node ( mesh_emitter_option_idx , { } , arr [ i ] , i ) ;
2019-09-30 13:25:32 +02:00
}
}
}
2021-05-24 12:37:47 +02:00
undo_redo - > commit_action ( ) ;
2019-02-22 18:38:58 +01:00
}
}
}
2019-08-18 18:27:08 +02:00
void VisualShaderEditor : : _show_preview_text ( ) {
2024-07-11 15:20:25 +02:00
code_preview_showed = ! code_preview_showed ;
if ( code_preview_showed ) {
if ( code_preview_first ) {
code_preview_window - > set_size ( Size2 ( 400 * EDSCALE , 600 * EDSCALE ) ) ;
code_preview_window - > popup_centered ( ) ;
code_preview_first = false ;
2021-01-10 11:33:14 +01:00
} else {
2024-07-11 15:20:25 +02:00
code_preview_window - > popup ( ) ;
2021-01-10 11:33:14 +01:00
}
2019-08-25 08:22:09 +02:00
if ( pending_update_preview ) {
_update_preview ( ) ;
pending_update_preview = false ;
2019-08-25 07:42:21 +02:00
}
2021-01-10 11:33:14 +01:00
} else {
2024-07-11 15:20:25 +02:00
code_preview_window - > hide ( ) ;
2019-08-25 07:42:21 +02:00
}
2019-08-18 11:29:22 +02:00
}
2021-01-10 11:33:14 +01:00
void VisualShaderEditor : : _preview_close_requested ( ) {
2024-07-11 15:20:25 +02:00
code_preview_showed = false ;
code_preview_button - > set_pressed ( false ) ;
2021-01-10 11:33:14 +01:00
}
2023-05-17 17:22:26 +02:00
static ShaderLanguage : : DataType _visual_shader_editor_get_global_shader_uniform_type ( const StringName & p_variable ) {
2022-08-27 11:22:43 +02:00
RS : : GlobalShaderParameterType gvt = RS : : get_singleton ( ) - > global_shader_parameter_get_type ( p_variable ) ;
2022-04-03 18:56:43 +02:00
return ( ShaderLanguage : : DataType ) RS : : global_shader_uniform_type_get_shader_datatype ( gvt ) ;
2020-04-17 04:52:00 +02:00
}
2019-08-18 11:29:22 +02:00
void VisualShaderEditor : : _update_preview ( ) {
2024-07-11 15:20:25 +02:00
if ( ! code_preview_showed ) {
2019-08-25 08:22:09 +02:00
pending_update_preview = true ;
return ;
}
2019-08-25 07:42:21 +02:00
String code = visual_shader - > get_code ( ) ;
preview_text - > set_text ( code ) ;
2021-08-08 07:04:20 +02:00
ShaderLanguage : : ShaderCompileInfo info ;
info . functions = ShaderTypes : : get_singleton ( ) - > get_functions ( RenderingServer : : ShaderMode ( visual_shader - > get_mode ( ) ) ) ;
info . render_modes = ShaderTypes : : get_singleton ( ) - > get_modes ( RenderingServer : : ShaderMode ( visual_shader - > get_mode ( ) ) ) ;
info . shader_types = ShaderTypes : : get_singleton ( ) - > get_types ( ) ;
2023-05-17 17:22:26 +02:00
info . global_shader_uniform_type_func = _visual_shader_editor_get_global_shader_uniform_type ;
2021-08-08 07:04:20 +02:00
2019-08-25 07:42:21 +02:00
for ( int i = 0 ; i < preview_text - > get_line_count ( ) ; i + + ) {
2020-09-10 22:25:00 +02:00
preview_text - > set_line_background_color ( i , Color ( 0 , 0 , 0 , 0 ) ) ;
2019-08-25 07:42:21 +02:00
}
2023-09-23 21:25:47 +02:00
String preprocessed_code ;
{
String path = visual_shader - > get_path ( ) ;
String error_pp ;
List < ShaderPreprocessor : : FilePosition > err_positions ;
ShaderPreprocessor preprocessor ;
Error err = preprocessor . preprocess ( code , path , preprocessed_code , & error_pp , & err_positions ) ;
if ( err ! = OK ) {
ERR_FAIL_COND ( err_positions . is_empty ( ) ) ;
String file = err_positions . front ( ) - > get ( ) . file ;
int err_line = err_positions . front ( ) - > get ( ) . line ;
Color error_line_color = EDITOR_GET ( " text_editor/theme/highlighting/mark_color " ) ;
preview_text - > set_line_background_color ( err_line - 1 , error_line_color ) ;
error_panel - > show ( ) ;
error_label - > set_text ( " error( " + file + " : " + itos ( err_line ) + " ): " + error_pp ) ;
shader_error = true ;
return ;
}
}
ShaderLanguage sl ;
Error err = sl . compile ( preprocessed_code , info ) ;
2019-08-25 07:42:21 +02:00
if ( err ! = OK ) {
2023-09-23 21:25:47 +02:00
int err_line ;
String err_text ;
Vector < ShaderLanguage : : FilePosition > include_positions = sl . get_include_positions ( ) ;
if ( include_positions . size ( ) > 1 ) {
// Error is in an include.
err_line = include_positions [ 0 ] . line ;
err_text = " error( " + itos ( err_line ) + " ) in include " + include_positions [ include_positions . size ( ) - 1 ] . file + " : " + itos ( include_positions [ include_positions . size ( ) - 1 ] . line ) + " : " + sl . get_error_text ( ) ;
} else {
err_line = sl . get_error_line ( ) ;
err_text = " error( " + itos ( err_line ) + " ): " + sl . get_error_text ( ) ;
}
2021-08-15 19:14:46 +02:00
Color error_line_color = EDITOR_GET ( " text_editor/theme/highlighting/mark_color " ) ;
2023-09-23 21:25:47 +02:00
preview_text - > set_line_background_color ( err_line - 1 , error_line_color ) ;
2021-06-03 09:50:13 +02:00
error_panel - > show ( ) ;
2019-08-25 08:22:09 +02:00
2023-09-23 21:25:47 +02:00
error_label - > set_text ( err_text ) ;
2019-08-25 07:42:21 +02:00
shader_error = true ;
} else {
2021-06-03 09:50:13 +02:00
error_panel - > hide ( ) ;
2019-08-25 07:42:21 +02:00
shader_error = false ;
}
2019-08-18 11:29:22 +02:00
}
2023-02-03 13:09:51 +01:00
void VisualShaderEditor : : _update_next_previews ( int p_node_id ) {
VisualShader : : Type type = get_current_shader_type ( ) ;
LocalVector < int > nodes ;
_get_next_nodes_recursively ( type , p_node_id , nodes ) ;
for ( int node_id : nodes ) {
if ( graph_plugin - > is_preview_visible ( node_id ) ) {
graph_plugin - > update_node_deferred ( type , node_id ) ;
}
}
}
void VisualShaderEditor : : _get_next_nodes_recursively ( VisualShader : : Type p_type , int p_node_id , LocalVector < int > & r_nodes ) const {
2023-05-06 20:16:55 +02:00
const LocalVector < int > & next_connections = visual_shader - > get_next_connected_nodes ( p_type , p_node_id ) ;
2023-02-03 13:09:51 +01:00
for ( int node_id : next_connections ) {
r_nodes . push_back ( node_id ) ;
_get_next_nodes_recursively ( p_type , node_id , r_nodes ) ;
}
}
2021-01-10 11:33:14 +01:00
void VisualShaderEditor : : _visibility_changed ( ) {
if ( ! is_visible ( ) ) {
2024-07-11 15:20:25 +02:00
if ( code_preview_window - > is_visible ( ) ) {
code_preview_button - > set_pressed ( false ) ;
code_preview_window - > hide ( ) ;
code_preview_showed = false ;
2021-01-10 11:33:14 +01:00
}
}
}
2024-07-11 15:20:25 +02:00
void VisualShaderEditor : : _show_shader_preview ( ) {
shader_preview_showed = ! shader_preview_showed ;
if ( shader_preview_showed ) {
shader_preview_vbox - > show ( ) ;
} else {
shader_preview_vbox - > hide ( ) ;
_param_unselected ( ) ;
}
}
2018-07-14 23:15:42 +02:00
void VisualShaderEditor : : _bind_methods ( ) {
2022-02-07 20:58:37 +01:00
ClassDB : : bind_method ( " _update_nodes " , & VisualShaderEditor : : _update_nodes ) ;
2018-07-14 23:15:42 +02:00
ClassDB : : bind_method ( " _update_graph " , & VisualShaderEditor : : _update_graph ) ;
ClassDB : : bind_method ( " _input_select_item " , & VisualShaderEditor : : _input_select_item ) ;
2022-08-27 11:22:43 +02:00
ClassDB : : bind_method ( " _parameter_ref_select_item " , & VisualShaderEditor : : _parameter_ref_select_item ) ;
2022-01-09 15:02:13 +01:00
ClassDB : : bind_method ( " _varying_select_item " , & VisualShaderEditor : : _varying_select_item ) ;
2019-05-12 14:09:39 +02:00
ClassDB : : bind_method ( " _set_node_size " , & VisualShaderEditor : : _set_node_size ) ;
2022-08-27 11:22:43 +02:00
ClassDB : : bind_method ( " _update_parameters " , & VisualShaderEditor : : _update_parameters ) ;
2022-01-09 15:02:13 +01:00
ClassDB : : bind_method ( " _update_varyings " , & VisualShaderEditor : : _update_varyings ) ;
ClassDB : : bind_method ( " _update_varying_tree " , & VisualShaderEditor : : _update_varying_tree ) ;
2020-09-12 10:01:48 +02:00
ClassDB : : bind_method ( " _set_mode " , & VisualShaderEditor : : _set_mode ) ;
2020-12-30 09:45:31 +01:00
ClassDB : : bind_method ( " _update_constant " , & VisualShaderEditor : : _update_constant ) ;
2022-08-27 11:22:43 +02:00
ClassDB : : bind_method ( " _update_parameter " , & VisualShaderEditor : : _update_parameter ) ;
2023-02-03 13:09:51 +01:00
ClassDB : : bind_method ( " _update_next_previews " , & VisualShaderEditor : : _update_next_previews ) ;
2024-07-11 15:20:25 +02:00
ClassDB : : bind_method ( " _update_current_param " , & VisualShaderEditor : : _update_current_param ) ;
2018-07-14 23:15:42 +02:00
}
VisualShaderEditor : : VisualShaderEditor ( ) {
2019-05-12 14:09:39 +02:00
ShaderLanguage : : get_keyword_list ( & keyword_list ) ;
2023-01-23 10:01:28 +01:00
EditorNode : : get_singleton ( ) - > connect ( " resource_saved " , callable_mp ( this , & VisualShaderEditor : : _resource_saved ) ) ;
FileSystemDock : : get_singleton ( ) - > get_script_create_dialog ( ) - > connect ( " script_created " , callable_mp ( this , & VisualShaderEditor : : _script_created ) ) ;
FileSystemDock : : get_singleton ( ) - > connect ( " resource_removed " , callable_mp ( this , & VisualShaderEditor : : _resource_removed ) ) ;
2018-07-14 23:15:42 +02:00
2024-07-11 15:20:25 +02:00
HSplitContainer * main_box = memnew ( HSplitContainer ) ;
main_box - > set_anchors_and_offsets_preset ( Control : : PRESET_FULL_RECT ) ;
add_child ( main_box ) ;
2018-07-14 23:15:42 +02:00
graph = memnew ( GraphEdit ) ;
2024-07-11 15:20:25 +02:00
graph - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
graph - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
graph - > set_custom_minimum_size ( Size2 ( 200 * EDSCALE , 0 ) ) ;
2024-02-09 15:02:58 +01:00
graph - > set_grid_pattern ( GraphEdit : : GridPattern : : GRID_PATTERN_DOTS ) ;
int grid_pattern = EDITOR_GET ( " editors/visual_editors/grid_pattern " ) ;
graph - > set_grid_pattern ( ( GraphEdit : : GridPattern ) grid_pattern ) ;
2022-04-30 03:56:57 +02:00
graph - > set_show_zoom_label ( true ) ;
2024-07-11 15:20:25 +02:00
main_box - > add_child ( graph ) ;
2023-01-14 03:37:19 +01:00
SET_DRAG_FORWARDING_GCD ( graph , VisualShaderEditor ) ;
2022-10-18 16:43:37 +02:00
float graph_minimap_opacity = EDITOR_GET ( " editors/visual_editors/minimap_opacity " ) ;
2021-01-25 15:37:05 +01:00
graph - > set_minimap_opacity ( graph_minimap_opacity ) ;
2022-10-18 16:43:37 +02:00
float graph_lines_curvature = EDITOR_GET ( " editors/visual_editors/lines_curvature " ) ;
2022-05-30 15:38:13 +02:00
graph - > set_connection_lines_curvature ( graph_lines_curvature ) ;
2018-07-14 23:15:42 +02:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_SCALAR ) ;
2020-02-25 15:50:49 +01:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
2022-12-27 18:49:11 +01:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
2019-02-22 18:38:58 +01:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2022-02-01 09:32:01 +01:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
2022-02-06 18:15:28 +01:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
2018-07-14 23:15:42 +02:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_TRANSFORM ) ;
2019-10-01 10:51:50 +02:00
graph - > add_valid_right_disconnect_type ( VisualShaderNode : : PORT_TYPE_SAMPLER ) ;
2018-07-14 23:15:42 +02:00
//graph->add_valid_left_disconnect_type(0);
graph - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
2022-07-28 22:56:41 +02:00
graph - > connect ( " connection_request " , callable_mp ( this , & VisualShaderEditor : : _connection_request ) , CONNECT_DEFERRED ) ;
graph - > connect ( " disconnection_request " , callable_mp ( this , & VisualShaderEditor : : _disconnection_request ) , CONNECT_DEFERRED ) ;
2020-02-21 18:28:45 +01:00
graph - > connect ( " node_selected " , callable_mp ( this , & VisualShaderEditor : : _node_selected ) ) ;
graph - > connect ( " scroll_offset_changed " , callable_mp ( this , & VisualShaderEditor : : _scroll_changed ) ) ;
graph - > connect ( " duplicate_nodes_request " , callable_mp ( this , & VisualShaderEditor : : _duplicate_nodes ) ) ;
2022-07-28 22:56:41 +02:00
graph - > connect ( " copy_nodes_request " , callable_mp ( this , & VisualShaderEditor : : _copy_nodes ) . bind ( false ) ) ;
2024-09-20 12:19:16 +02:00
graph - > connect ( " cut_nodes_request " , callable_mp ( this , & VisualShaderEditor : : _copy_nodes ) . bind ( true ) ) ;
2022-07-28 22:56:41 +02:00
graph - > connect ( " paste_nodes_request " , callable_mp ( this , & VisualShaderEditor : : _paste_nodes ) . bind ( false , Point2 ( ) ) ) ;
2023-09-26 16:41:39 +02:00
graph - > connect ( " delete_nodes_request " , callable_mp ( this , & VisualShaderEditor : : _delete_nodes_request ) ) ;
2024-05-13 16:56:03 +02:00
graph - > connect ( SceneStringName ( gui_input ) , callable_mp ( this , & VisualShaderEditor : : _graph_gui_input ) ) ;
2020-02-21 18:28:45 +01:00
graph - > connect ( " connection_to_empty " , callable_mp ( this , & VisualShaderEditor : : _connection_to_empty ) ) ;
graph - > connect ( " connection_from_empty " , callable_mp ( this , & VisualShaderEditor : : _connection_from_empty ) ) ;
2024-05-13 16:56:03 +02:00
graph - > connect ( SceneStringName ( visibility_changed ) , callable_mp ( this , & VisualShaderEditor : : _visibility_changed ) ) ;
2018-07-14 23:15:42 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR , VisualShaderNode : : PORT_TYPE_SCALAR ) ;
2020-02-25 15:50:49 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
2022-12-27 18:49:11 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
2022-02-01 09:32:01 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
2022-02-06 18:15:28 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
2019-02-22 18:38:58 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2022-04-12 19:09:29 +02:00
2020-02-25 15:50:49 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT , VisualShaderNode : : PORT_TYPE_SCALAR ) ;
2022-12-27 18:49:11 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
2022-02-01 09:32:01 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
2022-02-06 18:15:28 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
2020-02-25 15:50:49 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_INT , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2022-04-12 19:09:29 +02:00
2022-12-27 18:49:11 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT , VisualShaderNode : : PORT_TYPE_SCALAR ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SCALAR_UINT , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2022-02-01 09:32:01 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D , VisualShaderNode : : PORT_TYPE_SCALAR ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
2022-12-27 18:49:11 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
2022-02-01 09:32:01 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
2022-02-06 18:15:28 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
2022-02-01 09:32:01 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_2D , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2022-04-12 19:09:29 +02:00
2022-02-06 18:15:28 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D , VisualShaderNode : : PORT_TYPE_SCALAR ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
2022-12-27 18:49:11 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
2022-02-06 18:15:28 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
2022-02-06 18:15:28 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_3D , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D , VisualShaderNode : : PORT_TYPE_SCALAR ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
2022-12-27 18:49:11 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_VECTOR_4D , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2019-02-22 18:38:58 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN , VisualShaderNode : : PORT_TYPE_SCALAR ) ;
2020-02-25 15:50:49 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ;
2022-12-27 18:49:11 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ;
2022-02-01 09:32:01 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ;
2022-02-06 18:15:28 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ;
2022-04-12 19:09:29 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ;
2019-02-22 18:38:58 +01:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_BOOLEAN , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ;
2022-04-12 19:09:29 +02:00
2018-07-14 23:15:42 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_TRANSFORM , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ;
2019-10-01 10:51:50 +02:00
graph - > add_valid_connection_type ( VisualShaderNode : : PORT_TYPE_SAMPLER , VisualShaderNode : : PORT_TYPE_SAMPLER ) ;
2018-07-14 23:15:42 +02:00
2024-07-11 15:20:25 +02:00
PanelContainer * toolbar_panel = static_cast < PanelContainer * > ( graph - > get_menu_hbox ( ) - > get_parent ( ) ) ;
toolbar_panel - > set_anchors_and_offsets_preset ( Control : : PRESET_TOP_WIDE , PRESET_MODE_MINSIZE , 10 ) ;
toolbar_panel - > set_mouse_filter ( Control : : MOUSE_FILTER_IGNORE ) ;
HFlowContainer * toolbar = memnew ( HFlowContainer ) ;
{
LocalVector < Node * > nodes ;
for ( int i = 0 ; i < graph - > get_menu_hbox ( ) - > get_child_count ( ) ; i + + ) {
Node * child = graph - > get_menu_hbox ( ) - > get_child ( i ) ;
nodes . push_back ( child ) ;
}
for ( Node * node : nodes ) {
graph - > get_menu_hbox ( ) - > remove_child ( node ) ;
toolbar - > add_child ( node ) ;
}
graph - > get_menu_hbox ( ) - > hide ( ) ;
toolbar_panel - > add_child ( toolbar ) ;
}
2018-07-14 23:15:42 +02:00
VSeparator * vs = memnew ( VSeparator ) ;
2024-07-11 15:20:25 +02:00
toolbar - > add_child ( vs ) ;
toolbar - > move_child ( vs , 0 ) ;
2018-07-14 23:15:42 +02:00
2020-09-15 09:57:40 +02:00
custom_mode_box = memnew ( CheckBox ) ;
custom_mode_box - > set_text ( TTR ( " Custom " ) ) ;
custom_mode_box - > set_pressed ( false ) ;
custom_mode_box - > set_visible ( false ) ;
2024-06-01 12:15:13 +02:00
custom_mode_box - > connect ( SceneStringName ( toggled ) , callable_mp ( this , & VisualShaderEditor : : _custom_mode_toggled ) ) ;
2020-09-15 09:57:40 +02:00
edit_type_standard = memnew ( OptionButton ) ;
edit_type_standard - > add_item ( TTR ( " Vertex " ) ) ;
edit_type_standard - > add_item ( TTR ( " Fragment " ) ) ;
edit_type_standard - > add_item ( TTR ( " Light " ) ) ;
edit_type_standard - > select ( 1 ) ;
2024-05-14 14:21:31 +02:00
edit_type_standard - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderEditor : : _mode_selected ) ) ;
2020-09-07 09:28:13 +02:00
edit_type_particles = memnew ( OptionButton ) ;
2020-09-15 09:57:40 +02:00
edit_type_particles - > add_item ( TTR ( " Start " ) ) ;
2020-09-07 09:28:13 +02:00
edit_type_particles - > add_item ( TTR ( " Process " ) ) ;
2020-09-15 09:57:40 +02:00
edit_type_particles - > add_item ( TTR ( " Collide " ) ) ;
2020-09-07 09:28:13 +02:00
edit_type_particles - > select ( 0 ) ;
2024-05-14 14:21:31 +02:00
edit_type_particles - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderEditor : : _mode_selected ) ) ;
2020-09-07 09:28:13 +02:00
2021-04-17 19:16:03 +02:00
edit_type_sky = memnew ( OptionButton ) ;
edit_type_sky - > add_item ( TTR ( " Sky " ) ) ;
edit_type_sky - > select ( 0 ) ;
2024-05-14 14:21:31 +02:00
edit_type_sky - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderEditor : : _mode_selected ) ) ;
2021-04-17 19:16:03 +02:00
2021-10-29 15:42:33 +02:00
edit_type_fog = memnew ( OptionButton ) ;
edit_type_fog - > add_item ( TTR ( " Fog " ) ) ;
edit_type_fog - > select ( 0 ) ;
2024-05-14 14:21:31 +02:00
edit_type_fog - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderEditor : : _mode_selected ) ) ;
2021-10-29 15:42:33 +02:00
2020-09-15 09:57:40 +02:00
edit_type = edit_type_standard ;
2020-09-07 09:28:13 +02:00
2024-07-11 15:20:25 +02:00
toolbar - > add_child ( custom_mode_box ) ;
toolbar - > move_child ( custom_mode_box , 0 ) ;
toolbar - > add_child ( edit_type_standard ) ;
toolbar - > move_child ( edit_type_standard , 0 ) ;
toolbar - > add_child ( edit_type_particles ) ;
toolbar - > move_child ( edit_type_particles , 0 ) ;
toolbar - > add_child ( edit_type_sky ) ;
toolbar - > move_child ( edit_type_sky , 0 ) ;
toolbar - > add_child ( edit_type_fog ) ;
toolbar - > move_child ( edit_type_fog , 0 ) ;
2018-07-14 23:15:42 +02:00
2020-06-19 20:49:04 +02:00
add_node = memnew ( Button ) ;
add_node - > set_flat ( true ) ;
2018-12-04 17:36:42 +01:00
add_node - > set_text ( TTR ( " Add Node... " ) ) ;
2024-07-11 15:20:25 +02:00
toolbar - > add_child ( add_node ) ;
toolbar - > move_child ( add_node , 0 ) ;
2024-05-14 09:40:21 +02:00
add_node - > connect ( SceneStringName ( pressed ) , callable_mp ( this , & VisualShaderEditor : : _show_members_dialog ) . bind ( false , VisualShaderNode : : PORT_TYPE_MAX , VisualShaderNode : : PORT_TYPE_MAX ) ) ;
2019-02-22 18:38:58 +01:00
2024-02-07 02:37:26 +01:00
graph - > connect ( " graph_elements_linked_to_frame_request " , callable_mp ( this , & VisualShaderEditor : : _nodes_linked_to_frame_request ) ) ;
graph - > connect ( " frame_rect_changed " , callable_mp ( this , & VisualShaderEditor : : _frame_rect_changed ) ) ;
2022-11-16 20:05:09 +01:00
varying_button = memnew ( MenuButton ) ;
2022-01-09 15:02:13 +01:00
varying_button - > set_text ( TTR ( " Manage Varyings " ) ) ;
2022-11-16 20:05:09 +01:00
varying_button - > set_switch_on_hover ( true ) ;
2024-07-11 15:20:25 +02:00
toolbar - > add_child ( varying_button ) ;
2022-01-09 15:02:13 +01:00
2022-11-16 20:05:09 +01:00
PopupMenu * varying_menu = varying_button - > get_popup ( ) ;
varying_menu - > add_item ( TTR ( " Add Varying " ) , int ( VaryingMenuOptions : : ADD ) ) ;
varying_menu - > add_item ( TTR ( " Remove Varying " ) , int ( VaryingMenuOptions : : REMOVE ) ) ;
2024-05-14 14:13:31 +02:00
varying_menu - > connect ( SceneStringName ( id_pressed ) , callable_mp ( this , & VisualShaderEditor : : _varying_menu_id_pressed ) ) ;
2022-01-09 15:02:13 +01:00
2024-07-11 15:20:25 +02:00
code_preview_button = memnew ( Button ) ;
code_preview_button - > set_theme_type_variation ( " FlatButton " ) ;
code_preview_button - > set_toggle_mode ( true ) ;
code_preview_button - > set_tooltip_text ( TTR ( " Show generated shader code. " ) ) ;
toolbar - > add_child ( code_preview_button ) ;
code_preview_button - > connect ( SceneStringName ( pressed ) , callable_mp ( this , & VisualShaderEditor : : _show_preview_text ) ) ;
shader_preview_button = memnew ( Button ) ;
shader_preview_button - > set_theme_type_variation ( " FlatButton " ) ;
shader_preview_button - > set_toggle_mode ( true ) ;
shader_preview_button - > set_tooltip_text ( TTR ( " Toggle shader preview. " ) ) ;
shader_preview_button - > set_pressed ( true ) ;
toolbar - > add_child ( shader_preview_button ) ;
shader_preview_button - > connect ( SceneStringName ( pressed ) , callable_mp ( this , & VisualShaderEditor : : _show_shader_preview ) ) ;
2019-08-18 11:29:22 +02:00
///////////////////////////////////////
2024-07-11 15:20:25 +02:00
// CODE PREVIEW
2019-08-18 11:29:22 +02:00
///////////////////////////////////////
2024-08-31 19:23:34 +02:00
code_preview_window = memnew ( AcceptDialog ) ;
2024-07-11 15:20:25 +02:00
code_preview_window - > set_title ( TTR ( " Generated Shader Code " ) ) ;
code_preview_window - > set_visible ( code_preview_showed ) ;
2024-08-31 19:23:34 +02:00
code_preview_window - > set_ok_button_text ( TTR ( " Close " ) ) ;
code_preview_window - > connect ( SceneStringName ( confirmed ) , callable_mp ( this , & VisualShaderEditor : : _preview_close_requested ) ) ;
code_preview_window - > connect ( " canceled " , callable_mp ( this , & VisualShaderEditor : : _preview_close_requested ) ) ;
2024-07-11 15:20:25 +02:00
add_child ( code_preview_window ) ;
2021-01-10 11:33:14 +01:00
2024-07-11 15:20:25 +02:00
code_preview_vbox = memnew ( VBoxContainer ) ;
code_preview_window - > add_child ( code_preview_vbox ) ;
code_preview_vbox - > add_theme_constant_override ( " separation " , 0 ) ;
2021-01-10 11:33:14 +01:00
2020-07-24 16:50:35 +02:00
preview_text = memnew ( CodeEdit ) ;
2021-06-18 00:03:09 +02:00
syntax_highlighter . instantiate ( ) ;
2024-07-11 15:20:25 +02:00
code_preview_vbox - > add_child ( preview_text ) ;
2021-01-10 11:33:14 +01:00
preview_text - > set_v_size_flags ( Control : : SIZE_EXPAND_FILL ) ;
2020-05-03 18:08:15 +02:00
preview_text - > set_syntax_highlighter ( syntax_highlighter ) ;
2020-07-25 19:27:35 +02:00
preview_text - > set_draw_line_numbers ( true ) ;
2021-07-09 15:05:52 +02:00
preview_text - > set_editable ( false ) ;
2019-08-18 11:29:22 +02:00
2021-06-03 09:50:13 +02:00
error_panel = memnew ( PanelContainer ) ;
2024-07-11 15:20:25 +02:00
code_preview_vbox - > add_child ( error_panel ) ;
2021-06-03 09:50:13 +02:00
error_panel - > set_visible ( false ) ;
error_label = memnew ( Label ) ;
error_panel - > add_child ( error_label ) ;
2022-06-15 10:01:45 +02:00
error_label - > set_autowrap_mode ( TextServer : : AUTOWRAP_WORD_SMART ) ;
2019-08-25 07:42:21 +02:00
2020-02-27 10:10:09 +01:00
///////////////////////////////////////
// POPUP MENU
///////////////////////////////////////
popup_menu = memnew ( PopupMenu ) ;
add_child ( popup_menu ) ;
2024-02-07 02:37:26 +01:00
popup_menu - > set_hide_on_checkable_item_selection ( false ) ;
2020-12-25 14:43:39 +01:00
popup_menu - > add_item ( TTR ( " Add Node " ) , NodeMenuOptions : : ADD ) ;
2020-02-27 10:10:09 +01:00
popup_menu - > add_separator ( ) ;
2021-10-30 15:12:14 +02:00
popup_menu - > add_item ( TTR ( " Cut " ) , NodeMenuOptions : : CUT ) ;
2020-12-25 14:43:39 +01:00
popup_menu - > add_item ( TTR ( " Copy " ) , NodeMenuOptions : : COPY ) ;
popup_menu - > add_item ( TTR ( " Paste " ) , NodeMenuOptions : : PASTE ) ;
popup_menu - > add_item ( TTR ( " Delete " ) , NodeMenuOptions : : DELETE ) ;
popup_menu - > add_item ( TTR ( " Duplicate " ) , NodeMenuOptions : : DUPLICATE ) ;
2021-10-30 15:12:14 +02:00
popup_menu - > add_item ( TTR ( " Clear Copy Buffer " ) , NodeMenuOptions : : CLEAR_COPY_BUFFER ) ;
2024-05-14 14:13:31 +02:00
popup_menu - > connect ( SceneStringName ( id_pressed ) , callable_mp ( this , & VisualShaderEditor : : _node_menu_id_pressed ) ) ;
2020-02-27 10:10:09 +01:00
2024-01-19 11:35:46 +01:00
connection_popup_menu = memnew ( PopupMenu ) ;
add_child ( connection_popup_menu ) ;
connection_popup_menu - > add_item ( TTR ( " Disconnect " ) , ConnectionMenuOptions : : DISCONNECT ) ;
connection_popup_menu - > add_item ( TTR ( " Insert New Node " ) , ConnectionMenuOptions : : INSERT_NEW_NODE ) ;
2024-05-07 16:48:03 +02:00
connection_popup_menu - > add_item ( TTR ( " Insert New Reroute " ) , ConnectionMenuOptions : : INSERT_NEW_REROUTE ) ;
2024-05-14 14:13:31 +02:00
connection_popup_menu - > connect ( SceneStringName ( id_pressed ) , callable_mp ( this , & VisualShaderEditor : : _connection_menu_id_pressed ) ) ;
2024-01-19 11:35:46 +01:00
2024-07-11 15:20:25 +02:00
///////////////////////////////////////
// SHADER PREVIEW
///////////////////////////////////////
shader_preview_vbox = memnew ( VBoxContainer ) ;
shader_preview_vbox - > set_custom_minimum_size ( Size2 ( 200 * EDSCALE , 0 ) ) ;
main_box - > add_child ( shader_preview_vbox ) ;
VSplitContainer * preview_split = memnew ( VSplitContainer ) ;
preview_split - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
shader_preview_vbox - > add_child ( preview_split ) ;
// Initialize material editor.
{
env . instantiate ( ) ;
Ref < Sky > sky = memnew ( Sky ( ) ) ;
env - > set_sky ( sky ) ;
env - > set_background ( Environment : : BG_COLOR ) ;
env - > set_ambient_source ( Environment : : AMBIENT_SOURCE_SKY ) ;
env - > set_reflection_source ( Environment : : REFLECTION_SOURCE_SKY ) ;
preview_material . instantiate ( ) ;
preview_material - > connect ( CoreStringName ( property_list_changed ) , callable_mp ( this , & VisualShaderEditor : : _update_preview_parameter_list ) ) ;
material_editor = memnew ( MaterialEditor ) ;
preview_split - > add_child ( material_editor ) ;
}
VBoxContainer * params_vbox = memnew ( VBoxContainer ) ;
preview_split - > add_child ( params_vbox ) ;
param_filter = memnew ( LineEdit ) ;
param_filter - > connect ( SceneStringName ( text_changed ) , callable_mp ( this , & VisualShaderEditor : : _param_filter_changed ) ) ;
param_filter - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
param_filter - > set_placeholder ( TTR ( " Filter Parameters " ) ) ;
params_vbox - > add_child ( param_filter ) ;
ScrollContainer * sc = memnew ( ScrollContainer ) ;
sc - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
params_vbox - > add_child ( sc ) ;
parameters = memnew ( Tree ) ;
parameters - > set_hide_root ( true ) ;
parameters - > set_allow_reselect ( true ) ;
parameters - > set_hide_folding ( false ) ;
parameters - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
parameters - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
2024-09-19 02:14:00 +02:00
parameters - > set_auto_translate_mode ( AUTO_TRANSLATE_MODE_DISABLED ) ;
2024-07-11 15:20:25 +02:00
parameters - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderEditor : : _param_selected ) ) ;
parameters - > connect ( " nothing_selected " , callable_mp ( this , & VisualShaderEditor : : _param_unselected ) ) ;
sc - > add_child ( parameters ) ;
param_vbox = memnew ( VBoxContainer ) ;
param_vbox - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
param_vbox - > hide ( ) ;
params_vbox - > add_child ( param_vbox ) ;
ScrollContainer * sc2 = memnew ( ScrollContainer ) ;
sc2 - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
param_vbox - > add_child ( sc2 ) ;
param_vbox2 = memnew ( VBoxContainer ) ;
param_vbox2 - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
sc2 - > add_child ( param_vbox2 ) ;
2019-02-22 18:38:58 +01:00
///////////////////////////////////////
// SHADER NODES TREE
///////////////////////////////////////
VBoxContainer * members_vb = memnew ( VBoxContainer ) ;
members_vb - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
HBoxContainer * filter_hb = memnew ( HBoxContainer ) ;
members_vb - > add_child ( filter_hb ) ;
node_filter = memnew ( LineEdit ) ;
filter_hb - > add_child ( node_filter ) ;
2024-05-14 11:42:00 +02:00
node_filter - > connect ( SceneStringName ( text_changed ) , callable_mp ( this , & VisualShaderEditor : : _member_filter_changed ) ) ;
2024-05-13 16:56:03 +02:00
node_filter - > connect ( SceneStringName ( gui_input ) , callable_mp ( this , & VisualShaderEditor : : _sbox_input ) ) ;
2019-02-22 18:38:58 +01:00
node_filter - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
node_filter - > set_placeholder ( TTR ( " Search " ) ) ;
tools = memnew ( MenuButton ) ;
filter_hb - > add_child ( tools ) ;
2022-08-25 12:42:17 +02:00
tools - > set_tooltip_text ( TTR ( " Options " ) ) ;
2024-05-14 14:13:31 +02:00
tools - > get_popup ( ) - > connect ( SceneStringName ( id_pressed ) , callable_mp ( this , & VisualShaderEditor : : _tools_menu_option ) ) ;
2019-02-22 18:38:58 +01:00
tools - > get_popup ( ) - > add_item ( TTR ( " Expand All " ) , EXPAND_ALL ) ;
tools - > get_popup ( ) - > add_item ( TTR ( " Collapse All " ) , COLLAPSE_ALL ) ;
members = memnew ( Tree ) ;
members_vb - > add_child ( members ) ;
2023-01-14 03:37:19 +01:00
SET_DRAG_FORWARDING_GCD ( members , VisualShaderEditor ) ;
2024-03-17 09:28:18 +01:00
members - > set_auto_translate_mode ( AUTO_TRANSLATE_MODE_DISABLED ) ; // TODO: Implement proper translation switch.
2019-02-22 18:38:58 +01:00
members - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
members - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
members - > set_hide_root ( true ) ;
members - > set_allow_reselect ( true ) ;
members - > set_hide_folding ( false ) ;
members - > set_custom_minimum_size ( Size2 ( 180 * EDSCALE , 200 * EDSCALE ) ) ;
2020-02-21 18:28:45 +01:00
members - > connect ( " item_activated " , callable_mp ( this , & VisualShaderEditor : : _member_create ) ) ;
2024-05-14 14:21:31 +02:00
members - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderEditor : : _member_selected ) ) ;
2019-02-22 18:38:58 +01:00
2020-02-12 16:39:19 +01:00
HBoxContainer * desc_hbox = memnew ( HBoxContainer ) ;
members_vb - > add_child ( desc_hbox ) ;
2019-02-22 18:38:58 +01:00
Label * desc_label = memnew ( Label ) ;
2020-02-12 16:39:19 +01:00
desc_hbox - > add_child ( desc_label ) ;
2019-02-22 18:38:58 +01:00
desc_label - > set_text ( TTR ( " Description: " ) ) ;
2020-02-12 16:39:19 +01:00
desc_hbox - > add_spacer ( ) ;
highend_label = memnew ( Label ) ;
desc_hbox - > add_child ( highend_label ) ;
highend_label - > set_visible ( false ) ;
highend_label - > set_text ( " Vulkan " ) ;
highend_label - > set_mouse_filter ( Control : : MOUSE_FILTER_STOP ) ;
2022-08-25 12:42:17 +02:00
highend_label - > set_tooltip_text ( TTR ( " High-end node " ) ) ;
2020-02-12 16:39:19 +01:00
2019-02-22 18:38:58 +01:00
node_desc = memnew ( RichTextLabel ) ;
members_vb - > add_child ( node_desc ) ;
node_desc - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
node_desc - > set_v_size_flags ( SIZE_FILL ) ;
node_desc - > set_custom_minimum_size ( Size2 ( 0 , 70 * EDSCALE ) ) ;
members_dialog = memnew ( ConfirmationDialog ) ;
members_dialog - > set_title ( TTR ( " Create Shader Node " ) ) ;
members_dialog - > add_child ( members_vb ) ;
2022-07-08 02:31:19 +02:00
members_dialog - > set_ok_button_text ( TTR ( " Create " ) ) ;
2024-08-31 19:23:34 +02:00
members_dialog - > connect ( SceneStringName ( confirmed ) , callable_mp ( this , & VisualShaderEditor : : _member_create ) ) ;
2020-12-14 19:37:30 +01:00
members_dialog - > get_ok_button ( ) - > set_disabled ( true ) ;
2023-01-21 12:25:29 +01:00
members_dialog - > connect ( " canceled " , callable_mp ( this , & VisualShaderEditor : : _member_cancel ) ) ;
2024-08-31 19:23:34 +02:00
members_dialog - > register_text_enter ( node_filter ) ;
2019-02-22 18:38:58 +01:00
add_child ( members_dialog ) ;
2022-01-09 15:02:13 +01:00
// add varyings dialog
{
add_varying_dialog = memnew ( ConfirmationDialog ) ;
add_varying_dialog - > set_title ( TTR ( " Create Shader Varying " ) ) ;
2022-07-08 02:31:19 +02:00
add_varying_dialog - > set_ok_button_text ( TTR ( " Create " ) ) ;
2024-08-31 19:23:34 +02:00
add_varying_dialog - > connect ( SceneStringName ( confirmed ) , callable_mp ( this , & VisualShaderEditor : : _varying_create ) ) ;
2022-01-09 15:02:13 +01:00
add_varying_dialog - > get_ok_button ( ) - > set_disabled ( true ) ;
add_child ( add_varying_dialog ) ;
VBoxContainer * vb = memnew ( VBoxContainer ) ;
add_varying_dialog - > add_child ( vb ) ;
HBoxContainer * hb = memnew ( HBoxContainer ) ;
vb - > add_child ( hb ) ;
hb - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
varying_type = memnew ( OptionButton ) ;
hb - > add_child ( varying_type ) ;
varying_type - > add_item ( " Float " ) ;
2022-08-24 11:41:42 +02:00
varying_type - > add_item ( " Int " ) ;
2022-12-27 18:49:11 +01:00
varying_type - > add_item ( " UInt " ) ;
2022-01-09 15:02:13 +01:00
varying_type - > add_item ( " Vector2 " ) ;
varying_type - > add_item ( " Vector3 " ) ;
2022-04-12 19:09:29 +02:00
varying_type - > add_item ( " Vector4 " ) ;
2022-08-24 11:41:42 +02:00
varying_type - > add_item ( " Boolean " ) ;
2022-01-09 15:02:13 +01:00
varying_type - > add_item ( " Transform " ) ;
varying_name = memnew ( LineEdit ) ;
hb - > add_child ( varying_name ) ;
varying_name - > set_custom_minimum_size ( Size2 ( 150 * EDSCALE , 0 ) ) ;
varying_name - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
2024-05-14 11:42:00 +02:00
varying_name - > connect ( SceneStringName ( text_changed ) , callable_mp ( this , & VisualShaderEditor : : _varying_name_changed ) ) ;
2024-08-31 19:23:34 +02:00
add_varying_dialog - > register_text_enter ( varying_name ) ;
2022-01-09 15:02:13 +01:00
varying_mode = memnew ( OptionButton ) ;
hb - > add_child ( varying_mode ) ;
varying_mode - > add_item ( " Vertex -> [Fragment, Light] " ) ;
varying_mode - > add_item ( " Fragment -> Light " ) ;
varying_error_label = memnew ( Label ) ;
vb - > add_child ( varying_error_label ) ;
varying_error_label - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
varying_error_label - > hide ( ) ;
}
// remove varying dialog
{
remove_varying_dialog = memnew ( ConfirmationDialog ) ;
remove_varying_dialog - > set_title ( TTR ( " Delete Shader Varying " ) ) ;
2022-07-08 02:31:19 +02:00
remove_varying_dialog - > set_ok_button_text ( TTR ( " Delete " ) ) ;
2024-08-31 19:23:34 +02:00
remove_varying_dialog - > connect ( SceneStringName ( confirmed ) , callable_mp ( this , & VisualShaderEditor : : _varying_deleted ) ) ;
2022-01-09 15:02:13 +01:00
add_child ( remove_varying_dialog ) ;
VBoxContainer * vb = memnew ( VBoxContainer ) ;
remove_varying_dialog - > add_child ( vb ) ;
varyings = memnew ( Tree ) ;
vb - > add_child ( varyings ) ;
2024-03-17 09:28:18 +01:00
varyings - > set_auto_translate_mode ( AUTO_TRANSLATE_MODE_DISABLED ) ;
2022-01-09 15:02:13 +01:00
varyings - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
varyings - > set_v_size_flags ( SIZE_EXPAND_FILL ) ;
varyings - > set_hide_root ( true ) ;
varyings - > set_allow_reselect ( true ) ;
varyings - > set_hide_folding ( false ) ;
varyings - > set_custom_minimum_size ( Size2 ( 180 * EDSCALE , 200 * EDSCALE ) ) ;
varyings - > connect ( " item_activated " , callable_mp ( this , & VisualShaderEditor : : _varying_deleted ) ) ;
2024-05-14 14:21:31 +02:00
varyings - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderEditor : : _varying_selected ) ) ;
2022-01-09 15:02:13 +01:00
varyings - > connect ( " nothing_selected " , callable_mp ( this , & VisualShaderEditor : : _varying_unselected ) ) ;
}
2019-02-22 18:38:58 +01:00
alert = memnew ( AcceptDialog ) ;
2022-06-15 10:01:45 +02:00
alert - > get_label ( ) - > set_autowrap_mode ( TextServer : : AUTOWRAP_WORD ) ;
2021-11-25 03:58:47 +01:00
alert - > get_label ( ) - > set_horizontal_alignment ( HORIZONTAL_ALIGNMENT_CENTER ) ;
alert - > get_label ( ) - > set_vertical_alignment ( VERTICAL_ALIGNMENT_CENTER ) ;
2019-02-22 18:38:58 +01:00
alert - > get_label ( ) - > set_custom_minimum_size ( Size2 ( 400 , 60 ) * EDSCALE ) ;
add_child ( alert ) ;
2024-02-07 02:37:26 +01:00
frame_title_change_popup = memnew ( PopupPanel ) ;
frame_title_change_edit = memnew ( LineEdit ) ;
frame_title_change_edit - > set_expand_to_text_length_enabled ( true ) ;
frame_title_change_edit - > set_select_all_on_focus ( true ) ;
2024-05-14 11:42:00 +02:00
frame_title_change_edit - > connect ( SceneStringName ( text_changed ) , callable_mp ( this , & VisualShaderEditor : : _frame_title_text_changed ) ) ;
2024-02-07 02:37:26 +01:00
frame_title_change_edit - > connect ( " text_submitted " , callable_mp ( this , & VisualShaderEditor : : _frame_title_text_submitted ) ) ;
frame_title_change_popup - > add_child ( frame_title_change_edit ) ;
frame_title_change_edit - > reset_size ( ) ;
frame_title_change_popup - > reset_size ( ) ;
2024-05-13 16:56:03 +02:00
frame_title_change_popup - > connect ( SceneStringName ( focus_exited ) , callable_mp ( this , & VisualShaderEditor : : _frame_title_popup_focus_out ) ) ;
2024-02-07 02:37:26 +01:00
frame_title_change_popup - > connect ( " popup_hide " , callable_mp ( this , & VisualShaderEditor : : _frame_title_popup_hide ) ) ;
add_child ( frame_title_change_popup ) ;
frame_tint_color_pick_popup = memnew ( PopupPanel ) ;
VBoxContainer * frame_popup_item_tint_color_editor = memnew ( VBoxContainer ) ;
frame_tint_color_pick_popup - > add_child ( frame_popup_item_tint_color_editor ) ;
frame_tint_color_picker = memnew ( ColorPicker ) ;
frame_popup_item_tint_color_editor - > add_child ( frame_tint_color_picker ) ;
frame_tint_color_picker - > reset_size ( ) ;
frame_tint_color_picker - > connect ( " color_changed " , callable_mp ( this , & VisualShaderEditor : : _frame_color_changed ) ) ;
Button * frame_tint_color_confirm_button = memnew ( Button ) ;
frame_tint_color_confirm_button - > set_text ( TTR ( " OK " ) ) ;
frame_popup_item_tint_color_editor - > add_child ( frame_tint_color_confirm_button ) ;
2024-05-14 09:40:21 +02:00
frame_tint_color_confirm_button - > connect ( SceneStringName ( pressed ) , callable_mp ( this , & VisualShaderEditor : : _frame_color_confirm ) ) ;
2024-02-07 02:37:26 +01:00
frame_tint_color_pick_popup - > connect ( " popup_hide " , callable_mp ( this , & VisualShaderEditor : : _frame_color_popup_hide ) ) ;
add_child ( frame_tint_color_pick_popup ) ;
2021-02-21 09:33:55 +01:00
2019-02-22 18:38:58 +01:00
///////////////////////////////////////
// SHADER NODES TREE OPTIONS
///////////////////////////////////////
// COLOR
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " ColorFunc " , " Color/Common " , " VisualShaderNodeColorFunc " , TTR ( " Color function. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ColorOp " , " Color/Common " , " VisualShaderNodeColorOp " , TTR ( " Color operator. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Grayscale " , " Color/Functions " , " VisualShaderNodeColorFunc " , TTR ( " Grayscale function. " ) , { VisualShaderNodeColorFunc : : FUNC_GRAYSCALE } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " HSV2RGB " , " Color/Functions " , " VisualShaderNodeColorFunc " , TTR ( " Converts HSV vector to RGB equivalent. " ) , { VisualShaderNodeColorFunc : : FUNC_HSV2RGB , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " RGB2HSV " , " Color/Functions " , " VisualShaderNodeColorFunc " , TTR ( " Converts RGB vector to HSV equivalent. " ) , { VisualShaderNodeColorFunc : : FUNC_RGB2HSV , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Sepia " , " Color/Functions " , " VisualShaderNodeColorFunc " , TTR ( " Sepia function. " ) , { VisualShaderNodeColorFunc : : FUNC_SEPIA } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Burn " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " Burn operator. " ) , { VisualShaderNodeColorOp : : OP_BURN } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Darken " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " Darken operator. " ) , { VisualShaderNodeColorOp : : OP_DARKEN } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Difference " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " Difference operator. " ) , { VisualShaderNodeColorOp : : OP_DIFFERENCE } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Dodge " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " Dodge operator. " ) , { VisualShaderNodeColorOp : : OP_DODGE } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " HardLight " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " HardLight operator. " ) , { VisualShaderNodeColorOp : : OP_HARD_LIGHT } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Lighten " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " Lighten operator. " ) , { VisualShaderNodeColorOp : : OP_LIGHTEN } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Overlay " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " Overlay operator. " ) , { VisualShaderNodeColorOp : : OP_OVERLAY } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Screen " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " Screen operator. " ) , { VisualShaderNodeColorOp : : OP_SCREEN } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " SoftLight " , " Color/Operators " , " VisualShaderNodeColorOp " , TTR ( " SoftLight operator. " ) , { VisualShaderNodeColorOp : : OP_SOFT_LIGHT } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ColorConstant " , " Color/Variables " , " VisualShaderNodeColorConstant " , TTR ( " Color constant. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ColorParameter " , " Color/Variables " , " VisualShaderNodeColorParameter " , TTR ( " Color parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2019-02-22 18:38:58 +01:00
2022-02-01 09:32:01 +01:00
// COMMON
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " DerivativeFunc " , " Common " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) Derivative function. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
2022-02-01 09:32:01 +01:00
2019-07-08 09:05:33 +02:00
// CONDITIONAL
2019-07-19 16:08:40 +02:00
const String & compare_func_desc = TTR ( " Returns the boolean result of the %s comparison between two parameters. " ) ;
2019-05-19 15:27:00 +02:00
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Equal (==) " , " Conditional/Functions " , " VisualShaderNodeCompare " , vformat ( compare_func_desc , TTR ( " Equal (==) " ) ) , { VisualShaderNodeCompare : : FUNC_EQUAL } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " GreaterThan (>) " , " Conditional/Functions " , " VisualShaderNodeCompare " , vformat ( compare_func_desc , TTR ( " Greater Than (>) " ) ) , { VisualShaderNodeCompare : : FUNC_GREATER_THAN } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " GreaterThanEqual (>=) " , " Conditional/Functions " , " VisualShaderNodeCompare " , vformat ( compare_func_desc , TTR ( " Greater Than or Equal (>=) " ) ) , { VisualShaderNodeCompare : : FUNC_GREATER_THAN_EQUAL } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " If " , " Conditional/Functions " , " VisualShaderNodeIf " , TTR ( " Returns an associated vector if the provided scalars are equal, greater or less. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " IsInf " , " Conditional/Functions " , " VisualShaderNodeIs " , TTR ( " Returns the boolean result of the comparison between INF and a scalar parameter. " ) , { VisualShaderNodeIs : : FUNC_IS_INF } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " IsNaN " , " Conditional/Functions " , " VisualShaderNodeIs " , TTR ( " Returns the boolean result of the comparison between NaN and a scalar parameter. " ) , { VisualShaderNodeIs : : FUNC_IS_NAN } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " LessThan (<) " , " Conditional/Functions " , " VisualShaderNodeCompare " , vformat ( compare_func_desc , TTR ( " Less Than (<) " ) ) , { VisualShaderNodeCompare : : FUNC_LESS_THAN } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " LessThanEqual (<=) " , " Conditional/Functions " , " VisualShaderNodeCompare " , vformat ( compare_func_desc , TTR ( " Less Than or Equal (<=) " ) ) , { VisualShaderNodeCompare : : FUNC_LESS_THAN_EQUAL } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " NotEqual (!=) " , " Conditional/Functions " , " VisualShaderNodeCompare " , vformat ( compare_func_desc , TTR ( " Not Equal (!=) " ) ) , { VisualShaderNodeCompare : : FUNC_NOT_EQUAL } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
2024-07-12 17:44:48 +02:00
add_options . push_back ( AddOption ( " SwitchVector2D (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated 2D vector if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " SwitchVector3D (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated 3D vector if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " SwitchVector4D (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated 4D vector if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " SwitchBool (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated boolean if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_BOOLEAN } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " SwitchFloat (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated floating-point scalar if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_FLOAT } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " SwitchInt (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated integer scalar if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_INT } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
add_options . push_back ( AddOption ( " SwitchTransform (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated transform if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_TRANSFORM } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " SwitchUInt (==) " , " Conditional/Functions " , " VisualShaderNodeSwitch " , TTR ( " Returns an associated unsigned integer scalar if the provided boolean value is true or false. " ) , { VisualShaderNodeSwitch : : OP_TYPE_UINT } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Compare (==) " , " Conditional/Common " , " VisualShaderNodeCompare " , TTR ( " Returns the boolean result of the comparison between two parameters. " ) , { } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Is " , " Conditional/Common " , " VisualShaderNodeIs " , TTR ( " Returns the boolean result of the comparison between INF (or NaN) and a scalar parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " BooleanConstant " , " Conditional/Variables " , " VisualShaderNodeBooleanConstant " , TTR ( " Boolean constant. " ) , { } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
add_options . push_back ( AddOption ( " BooleanParameter " , " Conditional/Variables " , " VisualShaderNodeBooleanParameter " , TTR ( " Boolean parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_BOOLEAN ) ) ;
2019-02-22 18:38:58 +01:00
// INPUT
2022-03-28 09:03:52 +02:00
const String translation_gdsl = " \n \n " + TTR ( " Translated to '%s' in Godot Shading Language. " ) ;
const String input_param_shader_modes = TTR ( " '%s' input parameter for all shader modes. " ) + translation_gdsl ;
2020-09-15 09:57:40 +02:00
2022-02-01 09:32:01 +01:00
// NODE3D-FOR-ALL
2020-09-06 09:43:14 +02:00
2024-08-02 12:25:19 +02:00
add_options . push_back ( AddOption ( " ClipSpaceFar " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " clip_space_far " , " CLIP_SPACE_FAR " ) , { " clip_space_far " } , VisualShaderNode : : PORT_TYPE_SCALAR , - 1 , Shader : : MODE_SPATIAL ) ) ;
2023-01-13 23:02:46 +01:00
add_options . push_back ( AddOption ( " Exposure " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " exposure " , " EXPOSURE " ) , { " exposure " } , VisualShaderNode : : PORT_TYPE_SCALAR , - 1 , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " InvProjectionMatrix " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " inv_projection_matrix " , " INV_PROJECTION_MATRIX " ) , { " inv_projection_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " InvViewMatrix " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " inv_view_matrix " , " INV_VIEW_MATRIX " ) , { " inv_view_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ModelMatrix " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " model_matrix " , " MODEL_MATRIX " ) , { " model_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Normal " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " normal " , " NORMAL " ) , { " normal " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " OutputIsSRGB " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " output_is_srgb " , " OUTPUT_IS_SRGB " ) , { " output_is_srgb " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ProjectionMatrix " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " projection_matrix " , " PROJECTION_MATRIX " ) , { " projection_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Time " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " time " , " TIME " ) , { " time " } , VisualShaderNode : : PORT_TYPE_SCALAR , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " UV " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " uv " , " UV " ) , { " uv " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " UV2 " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " uv2 " , " UV2 " ) , { " uv2 " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ViewMatrix " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " view_matrix " , " VIEW_MATRIX " ) , { " view_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , - 1 , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ViewportSize " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " viewport_size " , " VIEWPORT_SIZE " ) , { " viewport_size " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , - 1 , Shader : : MODE_SPATIAL ) ) ;
2020-09-06 09:43:14 +02:00
2020-09-07 09:28:13 +02:00
// CANVASITEM-FOR-ALL
2020-09-06 09:43:14 +02:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Color " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " color " , " COLOR " ) , { " color " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , - 1 , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " TexturePixelSize " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " texture_pixel_size " , " TEXTURE_PIXEL_SIZE " ) , { " texture_pixel_size " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , - 1 , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Time " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " time " , " TIME " ) , { " time " } , VisualShaderNode : : PORT_TYPE_SCALAR , - 1 , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " UV " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " uv " , " UV " ) , { " uv " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , - 1 , Shader : : MODE_CANVAS_ITEM ) ) ;
2019-05-01 16:04:39 +02:00
2020-09-15 09:57:40 +02:00
// PARTICLES-FOR-ALL
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Active " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " active " , " ACTIVE " ) , { " active " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " AttractorForce " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " attractor_force " , " ATTRACTOR_FORCE " ) , { " attractor_force " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " Color " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " color " , " COLOR " ) , { " color " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " Custom " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " custom " , " CUSTOM " ) , { " custom " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " Delta " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " delta " , " DELTA " ) , { " delta " } , VisualShaderNode : : PORT_TYPE_SCALAR , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " EmissionTransform " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " emission_transform " , " EMISSION_TRANSFORM " ) , { " emission_transform " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , - 1 , Shader : : MODE_PARTICLES ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Index " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " index " , " INDEX " ) , { " index " } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT , - 1 , Shader : : MODE_PARTICLES ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " LifeTime " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " lifetime " , " LIFETIME " ) , { " lifetime " } , VisualShaderNode : : PORT_TYPE_SCALAR , - 1 , Shader : : MODE_PARTICLES ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Number " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " number " , " NUMBER " ) , { " number " } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " RandomSeed " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " random_seed " , " RANDOM_SEED " ) , { " random_seed " } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT , - 1 , Shader : : MODE_PARTICLES ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Restart " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " restart " , " RESTART " ) , { " restart " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " Time " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " time " , " TIME " ) , { " time " } , VisualShaderNode : : PORT_TYPE_SCALAR , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " Transform " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " transform " , " TRANSFORM " ) , { " transform " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , - 1 , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " Velocity " , " Input/All " , " VisualShaderNodeInput " , vformat ( input_param_shader_modes , " velocity " , " VELOCITY " ) , { " velocity " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , - 1 , Shader : : MODE_PARTICLES ) ) ;
2020-09-15 09:57:40 +02:00
2019-05-01 16:04:39 +02:00
/////////////////
2019-02-22 18:38:58 +01:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Input " , " Input/Common " , " VisualShaderNodeInput " , TTR ( " Input parameter. " ) ) ) ;
2019-02-22 18:38:58 +01:00
2022-03-28 09:03:52 +02:00
const String input_param_for_vertex_and_fragment_shader_modes = TTR ( " '%s' input parameter for vertex and fragment shader modes. " ) + translation_gdsl ;
const String input_param_for_fragment_and_light_shader_modes = TTR ( " '%s' input parameter for fragment and light shader modes. " ) + translation_gdsl ;
const String input_param_for_fragment_shader_mode = TTR ( " '%s' input parameter for fragment shader mode. " ) + translation_gdsl ;
const String input_param_for_sky_shader_mode = TTR ( " '%s' input parameter for sky shader mode. " ) + translation_gdsl ;
const String input_param_for_fog_shader_mode = TTR ( " '%s' input parameter for fog shader mode. " ) + translation_gdsl ;
const String input_param_for_light_shader_mode = TTR ( " '%s' input parameter for light shader mode. " ) + translation_gdsl ;
const String input_param_for_vertex_shader_mode = TTR ( " '%s' input parameter for vertex shader mode. " ) + translation_gdsl ;
const String input_param_for_start_shader_mode = TTR ( " '%s' input parameter for start shader mode. " ) + translation_gdsl ;
const String input_param_for_process_shader_mode = TTR ( " '%s' input parameter for process shader mode. " ) + translation_gdsl ;
const String input_param_for_collide_shader_mode = TTR ( " '%s' input parameter for collide shader mode. " + translation_gdsl ) ;
const String input_param_for_start_and_process_shader_mode = TTR ( " '%s' input parameter for start and process shader modes. " ) + translation_gdsl ;
const String input_param_for_process_and_collide_shader_mode = TTR ( " '%s' input parameter for process and collide shader modes. " ) + translation_gdsl ;
const String input_param_for_vertex_and_fragment_shader_mode = TTR ( " '%s' input parameter for vertex and fragment shader modes. " ) + translation_gdsl ;
2019-07-02 13:29:26 +02:00
2021-07-18 14:05:25 +02:00
// NODE3D INPUTS
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Binormal " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " binormal " , " BINORMAL " ) , { " binormal " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " CameraDirectionWorld " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " camera_direction_world " , " CAMERA_DIRECTION_WORLD " ) , { " camera_direction_world " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " CameraPositionWorld " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " camera_position_world " , " CAMERA_POSITION_WORLD " ) , { " camera_position_world " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " CameraVisibleLayers " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " camera_visible_layers " , " CAMERA_VISIBLE_LAYERS " ) , { " camera_visible_layers " } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Color " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " color " , " COLOR " ) , { " color " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2022-12-26 11:41:56 +01:00
add_options . push_back ( AddOption ( " Custom0 " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " custom0 " , " CUSTOM0 " ) , { " custom0 " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Custom1 " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " custom1 " , " CUSTOM1 " ) , { " custom1 " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Custom2 " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " custom2 " , " CUSTOM2 " ) , { " custom2 " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Custom3 " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " custom3 " , " CUSTOM3 " ) , { " custom3 " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " EyeOffset " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " eye_offset " , " EYE_OFFSET " ) , { " eye_offset " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " InstanceCustom " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " instance_custom " , " INSTANCE_CUSTOM " ) , { " instance_custom " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " InstanceId " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " instance_id " , " INSTANCE_ID " ) , { " instance_id " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " ModelViewMatrix " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " modelview_matrix " , " MODELVIEW_MATRIX " ) , { " modelview_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " NodePositionView " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " node_position_view " , " NODE_POSITION_VIEW " ) , { " node_position_view " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " NodePositionWorld " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " node_position_world " , " NODE_POSITION_WORLD " ) , { " node_position_world " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " PointSize " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " point_size " , " POINT_SIZE " ) , { " point_size " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Tangent " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_mode , " tangent " , " TANGENT " ) , { " tangent " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Vertex " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " vertex " , " VERTEX " ) , { " vertex " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " VertexId " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " vertex_id " , " VERTEX_ID " ) , { " vertex_id " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ViewIndex " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " view_index " , " VIEW_INDEX " ) , { " view_index " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ViewMonoLeft " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " view_mono_left " , " VIEW_MONO_LEFT " ) , { " view_mono_left " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ViewRight " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " view_right " , " VIEW_RIGHT " ) , { " view_right " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Binormal " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " binormal " , " BINORMAL " ) , { " binormal " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " CameraDirectionWorld " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " camera_direction_world " , " CAMERA_DIRECTION_WORLD " ) , { " camera_direction_world " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " CameraPositionWorld " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " camera_position_world " , " CAMERA_POSITION_WORLD " ) , { " camera_position_world " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " CameraVisibleLayers " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " camera_visible_layers " , " CAMERA_VISIBLE_LAYERS " ) , { " camera_visible_layers " } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Color " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " color " , " COLOR " ) , { " color " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " EyeOffset " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " eye_offset " , " EYE_OFFSET " ) , { " eye_offset " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " FragCoord " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " fragcoord " , " FRAGCOORD " ) , { " fragcoord " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " FrontFacing " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_shader_mode , " front_facing " , " FRONT_FACING " ) , { " front_facing " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " NodePositionView " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " node_position_view " , " NODE_POSITION_VIEW " ) , { " node_position_view " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " NodePositionWorld " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " node_position_world " , " NODE_POSITION_WORLD " ) , { " node_position_world " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " PointCoord " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_shader_mode , " point_coord " , " POINT_COORD " ) , { " point_coord " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ScreenUV " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_shader_mode , " screen_uv " , " SCREEN_UV " ) , { " screen_uv " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Tangent " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " tangent " , " TANGENT " ) , { " tangent " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Vertex " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " vertex " , " VERTEX " ) , { " vertex " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " View " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " view " , " VIEW " ) , { " view " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2022-09-13 09:06:34 +02:00
add_options . push_back ( AddOption ( " ViewIndex " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " view_index " , " VIEW_INDEX " ) , { " view_index " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ViewMonoLeft " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " view_mono_left " , " VIEW_MONO_LEFT " ) , { " view_mono_left " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ViewRight " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " view_right " , " VIEW_RIGHT " ) , { " view_right " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Albedo " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " albedo " , " ALBEDO " ) , { " albedo " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Attenuation " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " attenuation " , " ATTENUATION " ) , { " attenuation " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Backlight " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " backlight " , " BACKLIGHT " ) , { " backlight " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Diffuse " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " diffuse " , " DIFFUSE_LIGHT " ) , { " diffuse " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " FragCoord " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " fragcoord " , " FRAGCOORD " ) , { " fragcoord " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Light " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light " , " LIGHT " ) , { " light " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " LightColor " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light_color " , " LIGHT_COLOR " ) , { " light_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
2023-04-20 14:33:30 +02:00
add_options . push_back ( AddOption ( " LightIsDirectional " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light_is_directional " , " LIGHT_IS_DIRECTIONAL " ) , { " light_is_directional " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Metallic " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " metallic " , " METALLIC " ) , { " metallic " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Roughness " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " roughness " , " ROUGHNESS " ) , { " roughness " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Specular " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " specular " , " SPECULAR_LIGHT " ) , { " specular " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " View " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " view " , " VIEW " ) , { " view " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
2020-09-06 09:43:14 +02:00
2019-05-01 16:04:39 +02:00
// CANVASITEM INPUTS
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " AtLightPass " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " at_light_pass " , " AT_LIGHT_PASS " ) , { " at_light_pass " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " CanvasMatrix " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " canvas_matrix " , " CANVAS_MATRIX " ) , { " canvas_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
2023-12-27 21:58:50 +01:00
add_options . push_back ( AddOption ( " Custom0 " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " custom0 " , " CUSTOM0 " ) , { " custom0 " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Custom1 " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " custom1 " , " CUSTOM1 " ) , { " custom1 " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " InstanceCustom " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " instance_custom " , " INSTANCE_CUSTOM " ) , { " instance_custom " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " InstanceId " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " instance_id " , " INSTANCE_ID " ) , { " instance_id " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " ModelMatrix " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " model_matrix " , " MODEL_MATRIX " ) , { " model_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " PointSize " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " point_size " , " POINT_SIZE " ) , { " point_size " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " ScreenMatrix " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " screen_matrix " , " SCREEN_MATRIX " ) , { " screen_matrix " } , VisualShaderNode : : PORT_TYPE_TRANSFORM , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Vertex " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_mode , " vertex " , " VERTEX " ) , { " vertex " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " VertexId " , " Input/Vertex " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_shader_mode , " vertex_id " , " VERTEX_ID " ) , { " vertex_id " } , VisualShaderNode : : PORT_TYPE_SCALAR_INT , TYPE_FLAGS_VERTEX , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " AtLightPass " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_modes , " at_light_pass " , " AT_LIGHT_PASS " ) , { " at_light_pass " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " FragCoord " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " fragcoord " , " FRAGCOORD " ) , { " fragcoord " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " NormalTexture " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_shader_mode , " normal_texture " , " NORMAL_TEXTURE " ) , { " normal_texture " } , VisualShaderNode : : PORT_TYPE_SAMPLER , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " PointCoord " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " point_coord " , " POINT_COORD " ) , { " point_coord " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " ScreenPixelSize " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_shader_mode , " screen_pixel_size " , " SCREEN_PIXEL_SIZE " ) , { " screen_pixel_size " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " ScreenUV " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " screen_uv " , " SCREEN_UV " ) , { " screen_uv " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " SpecularShininess " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " specular_shininess " , " SPECULAR_SHININESS " ) , { " specular_shininess " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " SpecularShininessTexture " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_shader_mode , " specular_shininess_texture " , " SPECULAR_SHININESS_TEXTURE " ) , { " specular_shininess_texture " } , VisualShaderNode : : PORT_TYPE_SAMPLER , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Texture " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " texture " , " TEXTURE " ) , { " texture " } , VisualShaderNode : : PORT_TYPE_SAMPLER , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Vertex " , " Input/Fragment " , " VisualShaderNodeInput " , vformat ( input_param_for_vertex_and_fragment_shader_mode , " vertex " , " VERTEX " ) , { " vertex " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " FragCoord " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " fragcoord " , " FRAGCOORD " ) , { " fragcoord " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Light " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light " , " LIGHT " ) , { " light " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " LightColor " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light_color " , " LIGHT_COLOR " ) , { " light_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
2022-09-28 20:45:08 +02:00
add_options . push_back ( AddOption ( " LightDirection " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light_direction " , " LIGHT_DIRECTION " ) , { " light_direction " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " LightEnergy " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light_energy " , " LIGHT_ENERGY " ) , { " light_energy " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " LightIsDirectional " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light_is_directional " , " LIGHT_IS_DIRECTIONAL " ) , { " light_is_directional " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " LightPosition " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " light_position " , " LIGHT_POSITION " ) , { " light_position " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " LightVertex " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " light_vertex " , " LIGHT_VERTEX " ) , { " light_vertex " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Normal " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " normal " , " NORMAL " ) , { " normal " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " PointCoord " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " point_coord " , " POINT_COORD " ) , { " point_coord " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " ScreenUV " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " screen_uv " , " SCREEN_UV " ) , { " screen_uv " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Shadow " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_light_shader_mode , " shadow " , " SHADOW_MODULATE " ) , { " shadow " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " SpecularShininess " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " specular_shininess " , " SPECULAR_SHININESS " ) , { " specular_shininess " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " Texture " , " Input/Light " , " VisualShaderNodeInput " , vformat ( input_param_for_fragment_and_light_shader_modes , " texture " , " TEXTURE " ) , { " texture " } , VisualShaderNode : : PORT_TYPE_SAMPLER , TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
2020-09-06 09:43:14 +02:00
2020-03-25 10:22:29 +01:00
// SKY INPUTS
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " AtCubeMapPass " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " at_cubemap_pass " , " AT_CUBEMAP_PASS " ) , { " at_cubemap_pass " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " AtHalfResPass " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " at_half_res_pass " , " AT_HALF_RES_PASS " ) , { " at_half_res_pass " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " AtQuarterResPass " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " at_quarter_res_pass " , " AT_QUARTER_RES_PASS " ) , { " at_quarter_res_pass " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " EyeDir " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " eyedir " , " EYEDIR " ) , { " eyedir " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " FragCoord " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " fragcoord " , " FRAGCOORD " ) , { " fragcoord " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " HalfResColor " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " half_res_color " , " HALF_RES_COLOR " ) , { " half_res_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light0Color " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light0_color " , " LIGHT0_COLOR " ) , { " light0_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light0Direction " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light0_direction " , " LIGHT0_DIRECTION " ) , { " light0_direction " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light0Enabled " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light0_enabled " , " LIGHT0_ENABLED " ) , { " light0_enabled " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light0Energy " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light0_energy " , " LIGHT0_ENERGY " ) , { " light0_energy " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light1Color " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light1_color " , " LIGHT1_COLOR " ) , { " light1_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light1Direction " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light1_direction " , " LIGHT1_DIRECTION " ) , { " light1_direction " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light1Enabled " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light1_enabled " , " LIGHT1_ENABLED " ) , { " light1_enabled " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light1Energy " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light1_energy " , " LIGHT1_ENERGY " ) , { " light1_energy " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light2Color " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light2_color " , " LIGHT2_COLOR " ) , { " light2_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light2Direction " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light2_direction " , " LIGHT2_DIRECTION " ) , { " light2_direction " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light2Enabled " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light2_enabled " , " LIGHT2_ENABLED " ) , { " light2_enabled " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light2Energy " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light2_energy " , " LIGHT2_ENERGY " ) , { " light2_energy " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light3Color " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light3_color " , " LIGHT3_COLOR " ) , { " light3_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light3Direction " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light3_direction " , " LIGHT3_DIRECTION " ) , { " light3_direction " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light3Enabled " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light3_enabled " , " LIGHT3_ENABLED " ) , { " light3_enabled " } , VisualShaderNode : : PORT_TYPE_BOOLEAN , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Light3Energy " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " light3_energy " , " LIGHT3_ENERGY " ) , { " light3_energy " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Position " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " position " , " POSITION " ) , { " position " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " QuarterResColor " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " quarter_res_color " , " QUARTER_RES_COLOR " ) , { " quarter_res_color " } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Radiance " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " radiance " , " RADIANCE " ) , { " radiance " } , VisualShaderNode : : PORT_TYPE_SAMPLER , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " ScreenUV " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " screen_uv " , " SCREEN_UV " ) , { " screen_uv " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " SkyCoords " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " sky_coords " , " SKY_COORDS " ) , { " sky_coords " } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
add_options . push_back ( AddOption ( " Time " , " Input/Sky " , " VisualShaderNodeInput " , vformat ( input_param_for_sky_shader_mode , " time " , " TIME " ) , { " time " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_SKY , Shader : : MODE_SKY ) ) ;
2020-03-25 10:22:29 +01:00
2021-10-29 15:42:33 +02:00
// FOG INPUTS
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " ObjectPosition " , " Input/Fog " , " VisualShaderNodeInput " , vformat ( input_param_for_fog_shader_mode , " object_position " , " OBJECT_POSITION " ) , { " object_position " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FOG , Shader : : MODE_FOG ) ) ;
add_options . push_back ( AddOption ( " SDF " , " Input/Fog " , " VisualShaderNodeInput " , vformat ( input_param_for_fog_shader_mode , " sdf " , " SDF " ) , { " sdf " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FOG , Shader : : MODE_FOG ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " Size " , " Input/Fog " , " VisualShaderNodeInput " , vformat ( input_param_for_fog_shader_mode , " size " , " SIZE " ) , { " size " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FOG , Shader : : MODE_FOG ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Time " , " Input/Fog " , " VisualShaderNodeInput " , vformat ( input_param_for_fog_shader_mode , " time " , " TIME " ) , { " time " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FOG , Shader : : MODE_FOG ) ) ;
2023-10-16 15:09:02 +02:00
add_options . push_back ( AddOption ( " UVW " , " Input/Fog " , " VisualShaderNodeInput " , vformat ( input_param_for_fog_shader_mode , " uvw " , " UVW " ) , { " uvw " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FOG , Shader : : MODE_FOG ) ) ;
add_options . push_back ( AddOption ( " WorldPosition " , " Input/Fog " , " VisualShaderNodeInput " , vformat ( input_param_for_fog_shader_mode , " world_position " , " WORLD_POSITION " ) , { " world_position " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FOG , Shader : : MODE_FOG ) ) ;
2021-10-29 15:42:33 +02:00
2021-07-18 14:05:25 +02:00
// PARTICLES INPUTS
2020-09-15 09:57:40 +02:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " CollisionDepth " , " Input/Collide " , " VisualShaderNodeInput " , vformat ( input_param_for_collide_shader_mode , " collision_depth " , " COLLISION_DEPTH " ) , { " collision_depth " } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_COLLIDE , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " CollisionNormal " , " Input/Collide " , " VisualShaderNodeInput " , vformat ( input_param_for_collide_shader_mode , " collision_normal " , " COLLISION_NORMAL " ) , { " collision_normal " } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_COLLIDE , Shader : : MODE_PARTICLES ) ) ;
2020-09-15 09:57:40 +02:00
2021-07-18 14:05:25 +02:00
// PARTICLES
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " EmitParticle " , " Particles " , " VisualShaderNodeParticleEmit " , " " , { } , - 1 , TYPE_FLAGS_PROCESS | TYPE_FLAGS_PROCESS_CUSTOM | TYPE_FLAGS_COLLIDE , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " ParticleAccelerator " , " Particles " , " VisualShaderNodeParticleAccelerator " , " " , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_PROCESS , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " ParticleRandomness " , " Particles " , " VisualShaderNodeParticleRandomness " , " " , { } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_EMIT | TYPE_FLAGS_PROCESS | TYPE_FLAGS_COLLIDE , Shader : : MODE_PARTICLES ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " MultiplyByAxisAngle (*) " , " Particles/Transform " , " VisualShaderNodeParticleMultiplyByAxisAngle " , TTR ( " A node for help to multiply a position input vector by rotation using specific axis. Intended to work with emitters. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_EMIT | TYPE_FLAGS_PROCESS | TYPE_FLAGS_COLLIDE , Shader : : MODE_PARTICLES ) ) ;
2020-09-15 09:57:40 +02:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " BoxEmitter " , " Particles/Emitters " , " VisualShaderNodeParticleBoxEmitter " , " " , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_EMIT , Shader : : MODE_PARTICLES ) ) ;
2024-06-11 10:27:24 +02:00
mesh_emitter_option_idx = add_options . size ( ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " MeshEmitter " , " Particles/Emitters " , " VisualShaderNodeParticleMeshEmitter " , " " , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_EMIT , Shader : : MODE_PARTICLES ) ) ;
2024-06-11 10:27:24 +02:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " RingEmitter " , " Particles/Emitters " , " VisualShaderNodeParticleRingEmitter " , " " , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_EMIT , Shader : : MODE_PARTICLES ) ) ;
add_options . push_back ( AddOption ( " SphereEmitter " , " Particles/Emitters " , " VisualShaderNodeParticleSphereEmitter " , " " , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_EMIT , Shader : : MODE_PARTICLES ) ) ;
2020-09-15 09:57:40 +02:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " ConeVelocity " , " Particles/Velocity " , " VisualShaderNodeParticleConeVelocity " , " " , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_EMIT , Shader : : MODE_PARTICLES ) ) ;
2020-09-15 09:57:40 +02:00
2019-02-22 18:38:58 +01:00
// SCALAR
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " FloatFunc " , " Scalar/Common " , " VisualShaderNodeFloatFunc " , TTR ( " Float function. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " FloatOp " , " Scalar/Common " , " VisualShaderNodeFloatOp " , TTR ( " Float operator. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " IntFunc " , " Scalar/Common " , " VisualShaderNodeIntFunc " , TTR ( " Integer function. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
add_options . push_back ( AddOption ( " IntOp " , " Scalar/Common " , " VisualShaderNodeIntOp " , TTR ( " Integer operator. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " UIntFunc " , " Scalar/Common " , " VisualShaderNodeUIntFunc " , TTR ( " Unsigned integer function. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
add_options . push_back ( AddOption ( " UIntOp " , " Scalar/Common " , " VisualShaderNodeUIntOp " , TTR ( " Unsigned integer operator. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2019-02-22 18:38:58 +01:00
2021-07-18 14:05:25 +02:00
// CONSTANTS
2019-05-19 15:27:00 +02:00
2020-10-01 10:10:51 +02:00
for ( int i = 0 ; i < MAX_FLOAT_CONST_DEFS ; i + + ) {
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( float_constant_defs [ i ] . name , " Scalar/Constants " , " VisualShaderNodeFloatConstant " , float_constant_defs [ i ] . desc , { float_constant_defs [ i ] . value } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2020-10-01 10:10:51 +02:00
}
2019-05-19 15:27:00 +02:00
// FUNCTIONS
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Abs " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the absolute value of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ABS } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Abs " , " Scalar/Functions " , " VisualShaderNodeIntFunc " , TTR ( " Returns the absolute value of the parameter. " ) , { VisualShaderNodeIntFunc : : FUNC_ABS } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
add_options . push_back ( AddOption ( " ACos " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the arc-cosine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ACOS } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " ACosH " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the inverse hyperbolic cosine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ACOSH } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " ASin " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the arc-sine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ASIN } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " ASinH " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the inverse hyperbolic sine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ASINH } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " ATan " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the arc-tangent of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ATAN } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " ATan2 " , " Scalar/Functions " , " VisualShaderNodeFloatOp " , TTR ( " Returns the arc-tangent of the parameters. " ) , { VisualShaderNodeFloatOp : : OP_ATAN2 } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " ATanH " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the inverse hyperbolic tangent of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ATANH } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " BitwiseNOT " , " Scalar/Functions " , " VisualShaderNodeIntFunc " , TTR ( " Returns the result of bitwise NOT (~a) operation on the integer. " ) , { VisualShaderNodeIntFunc : : FUNC_BITWISE_NOT } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " BitwiseNOT " , " Scalar/Functions " , " VisualShaderNodeUIntFunc " , TTR ( " Returns the result of bitwise NOT (~a) operation on the unsigned integer. " ) , { VisualShaderNodeUIntFunc : : FUNC_BITWISE_NOT } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Ceil " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Finds the nearest integer that is greater than or equal to the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_CEIL } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Clamp " , " Scalar/Functions " , " VisualShaderNodeClamp " , TTR ( " Constrains a value to lie between two further values. " ) , { VisualShaderNodeClamp : : OP_TYPE_FLOAT } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Clamp " , " Scalar/Functions " , " VisualShaderNodeClamp " , TTR ( " Constrains a value to lie between two further values. " ) , { VisualShaderNodeClamp : : OP_TYPE_INT } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Clamp " , " Scalar/Functions " , " VisualShaderNodeClamp " , TTR ( " Constrains a value to lie between two further values. " ) , { VisualShaderNodeClamp : : OP_TYPE_UINT } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Cos " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the cosine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_COS } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " CosH " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the hyperbolic cosine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_COSH } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Degrees " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Converts a quantity in radians to degrees. " ) , { VisualShaderNodeFloatFunc : : FUNC_DEGREES } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " DFdX " , " Scalar/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Scalar) Derivative in 'x' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_X , VisualShaderNodeDerivativeFunc : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " DFdY " , " Scalar/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Scalar) Derivative in 'y' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_Y , VisualShaderNodeDerivativeFunc : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " Exp " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Base-e Exponential. " ) , { VisualShaderNodeFloatFunc : : FUNC_EXP } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Exp2 " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Base-2 Exponential. " ) , { VisualShaderNodeFloatFunc : : FUNC_EXP2 } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Floor " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Finds the nearest integer less than or equal to the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_FLOOR } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Fract " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Computes the fractional part of the argument. " ) , { VisualShaderNodeFloatFunc : : FUNC_FRACT } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " InverseSqrt " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the inverse of the square root of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_INVERSE_SQRT } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Log " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Natural logarithm. " ) , { VisualShaderNodeFloatFunc : : FUNC_LOG } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Log2 " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Base-2 logarithm. " ) , { VisualShaderNodeFloatFunc : : FUNC_LOG2 } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Max " , " Scalar/Functions " , " VisualShaderNodeFloatOp " , TTR ( " Returns the greater of two values. " ) , { VisualShaderNodeFloatOp : : OP_MAX } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Min " , " Scalar/Functions " , " VisualShaderNodeFloatOp " , TTR ( " Returns the lesser of two values. " ) , { VisualShaderNodeFloatOp : : OP_MIN } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Mix " , " Scalar/Functions " , " VisualShaderNodeMix " , TTR ( " Linear interpolation between two scalars. " ) , { VisualShaderNodeMix : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " MultiplyAdd (a * b + c) " , " Scalar/Functions " , " VisualShaderNodeMultiplyAdd " , TTR ( " Performs a fused multiply-add operation (a * b + c) on scalars. " ) , { VisualShaderNodeMultiplyAdd : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Negate (*-1) " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the opposite value of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_NEGATE } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Negate (*-1) " , " Scalar/Functions " , " VisualShaderNodeIntFunc " , TTR ( " Returns the opposite value of the parameter. " ) , { VisualShaderNodeIntFunc : : FUNC_NEGATE } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Negate (*-1) " , " Scalar/Functions " , " VisualShaderNodeUIntFunc " , TTR ( " Returns the opposite value of the parameter. " ) , { VisualShaderNodeUIntFunc : : FUNC_NEGATE } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " OneMinus (1-) " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " 1.0 - scalar " ) , { VisualShaderNodeFloatFunc : : FUNC_ONEMINUS } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Pow " , " Scalar/Functions " , " VisualShaderNodeFloatOp " , TTR ( " Returns the value of the first parameter raised to the power of the second. " ) , { VisualShaderNodeFloatOp : : OP_POW } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Radians " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Converts a quantity in degrees to radians. " ) , { VisualShaderNodeFloatFunc : : FUNC_RADIANS } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Reciprocal " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " 1.0 / scalar " ) , { VisualShaderNodeFloatFunc : : FUNC_RECIPROCAL } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2024-09-22 02:22:51 +02:00
add_options . push_back ( AddOption ( " Remap " , " Scalar/Functions " , " VisualShaderNodeRemap " , TTR ( " Remaps a value from the input range to the output range. " ) , { VisualShaderNodeRemap : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Round " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Finds the nearest integer to the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ROUND } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " RoundEven " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Finds the nearest even integer to the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_ROUNDEVEN } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Saturate " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Clamps the value between 0.0 and 1.0. " ) , { VisualShaderNodeFloatFunc : : FUNC_SATURATE } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Sign " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Extracts the sign of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_SIGN } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Sign " , " Scalar/Functions " , " VisualShaderNodeIntFunc " , TTR ( " Extracts the sign of the parameter. " ) , { VisualShaderNodeIntFunc : : FUNC_SIGN } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
add_options . push_back ( AddOption ( " Sin " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the sine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_SIN } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " SinH " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the hyperbolic sine of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_SINH } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Sqrt " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the square root of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_SQRT } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " SmoothStep " , " Scalar/Functions " , " VisualShaderNodeSmoothStep " , TTR ( " SmoothStep function( scalar(edge0), scalar(edge1), scalar(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge0' and 1.0 if x is larger than 'edge1'. Otherwise the return value is interpolated between 0.0 and 1.0 using Hermite polynomials. " ) , { VisualShaderNodeSmoothStep : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Step " , " Scalar/Functions " , " VisualShaderNodeStep " , TTR ( " Step function( scalar(edge), scalar(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge' and otherwise 1.0. " ) , { VisualShaderNodeStep : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Sum " , " Scalar/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Scalar) Sum of absolute derivative in 'x' and 'y'. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_SUM , VisualShaderNodeDerivativeFunc : : OP_TYPE_SCALAR } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " Tan " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the tangent of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_TAN } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " TanH " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Returns the hyperbolic tangent of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_TANH } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Trunc " , " Scalar/Functions " , " VisualShaderNodeFloatFunc " , TTR ( " Finds the truncated value of the parameter. " ) , { VisualShaderNodeFloatFunc : : FUNC_TRUNC } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Add (+) " , " Scalar/Operators " , " VisualShaderNodeFloatOp " , TTR ( " Sums two floating-point scalars. " ) , { VisualShaderNodeFloatOp : : OP_ADD } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Add (+) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Sums two integer scalars. " ) , { VisualShaderNodeIntOp : : OP_ADD } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Add (+) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Sums two unsigned integer scalars. " ) , { VisualShaderNodeUIntOp : : OP_ADD } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " BitwiseAND (&) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Returns the result of bitwise AND (a & b) operation for two integers. " ) , { VisualShaderNodeIntOp : : OP_BITWISE_AND } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " BitwiseAND (&) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Returns the result of bitwise AND (a & b) operation for two unsigned integers. " ) , { VisualShaderNodeUIntOp : : OP_BITWISE_AND } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " BitwiseLeftShift (<<) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Returns the result of bitwise left shift (a << b) operation on the integer. " ) , { VisualShaderNodeIntOp : : OP_BITWISE_LEFT_SHIFT } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " BitwiseLeftShift (<<) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Returns the result of bitwise left shift (a << b) operation on the unsigned integer. " ) , { VisualShaderNodeUIntOp : : OP_BITWISE_LEFT_SHIFT } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " BitwiseOR (|) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Returns the result of bitwise OR (a | b) operation for two integers. " ) , { VisualShaderNodeIntOp : : OP_BITWISE_OR } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " BitwiseOR (|) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Returns the result of bitwise OR (a | b) operation for two unsigned integers. " ) , { VisualShaderNodeUIntOp : : OP_BITWISE_OR } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " BitwiseRightShift (>>) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Returns the result of bitwise right shift (a >> b) operation on the integer. " ) , { VisualShaderNodeIntOp : : OP_BITWISE_RIGHT_SHIFT } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " BitwiseRightShift (>>) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Returns the result of bitwise right shift (a >> b) operation on the unsigned integer. " ) , { VisualShaderNodeIntOp : : OP_BITWISE_RIGHT_SHIFT } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " BitwiseXOR (^) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Returns the result of bitwise XOR (a ^ b) operation on the integer. " ) , { VisualShaderNodeIntOp : : OP_BITWISE_XOR } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " BitwiseXOR (^) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Returns the result of bitwise XOR (a ^ b) operation on the unsigned integer. " ) , { VisualShaderNodeUIntOp : : OP_BITWISE_XOR } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Divide (/) " , " Scalar/Operators " , " VisualShaderNodeFloatOp " , TTR ( " Divides two floating-point scalars. " ) , { VisualShaderNodeFloatOp : : OP_DIV } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Divide (/) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Divides two integer scalars. " ) , { VisualShaderNodeIntOp : : OP_DIV } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Divide (/) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Divides two unsigned integer scalars. " ) , { VisualShaderNodeUIntOp : : OP_DIV } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Multiply (*) " , " Scalar/Operators " , " VisualShaderNodeFloatOp " , TTR ( " Multiplies two floating-point scalars. " ) , { VisualShaderNodeFloatOp : : OP_MUL } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Multiply (*) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Multiplies two integer scalars. " ) , { VisualShaderNodeIntOp : : OP_MUL } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Multiply (*) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Multiplies two unsigned integer scalars. " ) , { VisualShaderNodeUIntOp : : OP_MUL } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2024-02-28 20:39:12 +01:00
add_options . push_back ( AddOption ( " Remainder (%) " , " Scalar/Operators " , " VisualShaderNodeFloatOp " , TTR ( " Returns the remainder of the two floating-point scalars. " ) , { VisualShaderNodeFloatOp : : OP_MOD } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Remainder (%) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Returns the remainder of the two integer scalars. " ) , { VisualShaderNodeIntOp : : OP_MOD } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
add_options . push_back ( AddOption ( " Remainder (%) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Returns the remainder of the two unsigned integer scalars. " ) , { VisualShaderNodeUIntOp : : OP_MOD } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Subtract (-) " , " Scalar/Operators " , " VisualShaderNodeFloatOp " , TTR ( " Subtracts two floating-point scalars. " ) , { VisualShaderNodeFloatOp : : OP_SUB } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Subtract (-) " , " Scalar/Operators " , " VisualShaderNodeIntOp " , TTR ( " Subtracts two integer scalars. " ) , { VisualShaderNodeIntOp : : OP_SUB } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " Subtract (-) " , " Scalar/Operators " , " VisualShaderNodeUIntOp " , TTR ( " Subtracts two unsigned integer scalars. " ) , { VisualShaderNodeUIntOp : : OP_SUB } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " FloatConstant " , " Scalar/Variables " , " VisualShaderNodeFloatConstant " , TTR ( " Scalar floating-point constant. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " IntConstant " , " Scalar/Variables " , " VisualShaderNodeIntConstant " , TTR ( " Scalar integer constant. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " UIntConstant " , " Scalar/Variables " , " VisualShaderNodeUIntConstant " , TTR ( " Scalar unsigned integer constant. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " FloatParameter " , " Scalar/Variables " , " VisualShaderNodeFloatParameter " , TTR ( " Scalar floating-point parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " IntParameter " , " Scalar/Variables " , " VisualShaderNodeIntParameter " , TTR ( " Scalar integer parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_INT ) ) ;
2022-12-27 18:49:11 +01:00
add_options . push_back ( AddOption ( " UIntParameter " , " Scalar/Variables " , " VisualShaderNodeUIntParameter " , TTR ( " Scalar unsigned integer parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR_UINT ) ) ;
2019-02-22 18:38:58 +01:00
2020-11-27 08:00:23 +01:00
// SDF
{
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " ScreenUVToSDF " , " SDF " , " VisualShaderNodeScreenUVToSDF " , TTR ( " Converts screen UV to a SDF. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " SDFRaymarch " , " SDF " , " VisualShaderNodeSDFRaymarch " , TTR ( " Casts a ray against the screen SDF and returns the distance travelled. " ) , { } , - 1 , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " SDFToScreenUV " , " SDF " , " VisualShaderNodeSDFToScreenUV " , TTR ( " Converts a SDF to screen UV. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " TextureSDF " , " SDF " , " VisualShaderNodeTextureSDF " , TTR ( " Performs a SDF texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " TextureSDFNormal " , " SDF " , " VisualShaderNodeTextureSDFNormal " , TTR ( " Performs a SDF normal texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
2020-11-27 08:00:23 +01:00
}
2019-02-22 18:38:58 +01:00
// TEXTURES
2020-11-27 08:00:23 +01:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " UVFunc " , " Textures/Common " , " VisualShaderNodeUVFunc " , TTR ( " Function to be applied on texture coordinates. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " UVPolarCoord " , " Textures/Common " , " VisualShaderNodeUVPolarCoord " , TTR ( " Polar coordinates conversion applied on texture coordinates. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
2021-06-05 14:53:53 +02:00
2020-09-29 14:27:36 +02:00
cubemap_node_option_idx = add_options . size ( ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " CubeMap " , " Textures/Functions " , " VisualShaderNodeCubemap " , TTR ( " Perform the cubic texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2020-10-04 11:11:58 +02:00
curve_node_option_idx = add_options . size ( ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " CurveTexture " , " Textures/Functions " , " VisualShaderNodeCurveTexture " , TTR ( " Perform the curve texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2021-07-14 00:06:44 +02:00
curve_xyz_node_option_idx = add_options . size ( ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " CurveXYZTexture " , " Textures/Functions " , " VisualShaderNodeCurveXYZTexture " , TTR ( " Perform the three components curve texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
2023-01-05 20:55:59 +01:00
add_options . push_back ( AddOption ( " LinearSceneDepth " , " Textures/Functions " , " VisualShaderNodeLinearSceneDepth " , TTR ( " Returns the depth value obtained from the depth prepass in a linear space. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
2020-09-29 14:27:36 +02:00
texture2d_node_option_idx = add_options . size ( ) ;
2023-07-25 22:04:21 +02:00
add_options . push_back ( AddOption ( " WorldPositionFromDepth " , " Textures/Functions " , " VisualShaderNodeWorldPositionFromDepth " , TTR ( " Reconstructs the World Position of the Node from the depth texture. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
texture2d_node_option_idx = add_options . size ( ) ;
add_options . push_back ( AddOption ( " ScreenNormalWorldSpace " , " Textures/Functions " , " VisualShaderNodeScreenNormalWorldSpace " , TTR ( " Unpacks the Screen Normal Texture in World Space " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
texture2d_node_option_idx = add_options . size ( ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Texture2D " , " Textures/Functions " , " VisualShaderNodeTexture " , TTR ( " Perform the 2D texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2020-09-29 14:27:36 +02:00
texture2d_array_node_option_idx = add_options . size ( ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Texture2DArray " , " Textures/Functions " , " VisualShaderNodeTexture2DArray " , TTR ( " Perform the 2D-array texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2020-09-29 14:27:36 +02:00
texture3d_node_option_idx = add_options . size ( ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Texture3D " , " Textures/Functions " , " VisualShaderNodeTexture3D " , TTR ( " Perform the 3D texture lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " UVPanning " , " Textures/Functions " , " VisualShaderNodeUVFunc " , TTR ( " Apply panning function on texture coordinates. " ) , { VisualShaderNodeUVFunc : : FUNC_PANNING } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " UVScaling " , " Textures/Functions " , " VisualShaderNodeUVFunc " , TTR ( " Apply scaling function on texture coordinates. " ) , { VisualShaderNodeUVFunc : : FUNC_SCALING } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
2020-09-10 05:47:09 +02:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " CubeMapParameter " , " Textures/Variables " , " VisualShaderNodeCubemapParameter " , TTR ( " Cubic texture parameter lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_SAMPLER ) ) ;
add_options . push_back ( AddOption ( " Texture2DParameter " , " Textures/Variables " , " VisualShaderNodeTexture2DParameter " , TTR ( " 2D texture parameter lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_SAMPLER ) ) ;
add_options . push_back ( AddOption ( " TextureParameterTriplanar " , " Textures/Variables " , " VisualShaderNodeTextureParameterTriplanar " , TTR ( " 2D texture parameter lookup with triplanar. " ) , { } , - 1 , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Texture2DArrayParameter " , " Textures/Variables " , " VisualShaderNodeTexture2DArrayParameter " , TTR ( " 2D array of textures parameter lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_SAMPLER ) ) ;
add_options . push_back ( AddOption ( " Texture3DParameter " , " Textures/Variables " , " VisualShaderNodeTexture3DParameter " , TTR ( " 3D texture parameter lookup. " ) , { } , VisualShaderNode : : PORT_TYPE_SAMPLER ) ) ;
2019-02-22 18:38:58 +01:00
// TRANSFORM
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " TransformFunc " , " Transform/Common " , " VisualShaderNodeTransformFunc " , TTR ( " Transform function. " ) , { } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " TransformOp " , " Transform/Common " , " VisualShaderNodeTransformOp " , TTR ( " Transform operator. " ) , { } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
2019-02-22 18:38:58 +01:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " OuterProduct " , " Transform/Composition " , " VisualShaderNodeOuterProduct " , TTR ( " Calculate the outer product of a pair of vectors. \n \n OuterProduct treats the first parameter 'c' as a column vector (matrix with one column) and the second parameter 'r' as a row vector (matrix with one row) and does a linear algebraic matrix multiply 'c * r', yielding a matrix whose number of rows is the number of components in 'c' and whose number of columns is the number of components in 'r'. " ) , { } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " TransformCompose " , " Transform/Composition " , " VisualShaderNodeTransformCompose " , TTR ( " Composes transform from four vectors. " ) , { } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " TransformDecompose " , " Transform/Composition " , " VisualShaderNodeTransformDecompose " , TTR ( " Decomposes transform to four vectors. " ) ) ) ;
2019-02-22 18:38:58 +01:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Determinant " , " Transform/Functions " , " VisualShaderNodeDeterminant " , TTR ( " Calculates the determinant of a transform. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " GetBillboardMatrix " , " Transform/Functions " , " VisualShaderNodeBillboard " , TTR ( " Calculates how the object should face the camera to be applied on Model View Matrix output port for 3D objects. " ) , { } , VisualShaderNode : : PORT_TYPE_TRANSFORM , TYPE_FLAGS_VERTEX , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " Inverse " , " Transform/Functions " , " VisualShaderNodeTransformFunc " , TTR ( " Calculates the inverse of a transform. " ) , { VisualShaderNodeTransformFunc : : FUNC_INVERSE } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " Transpose " , " Transform/Functions " , " VisualShaderNodeTransformFunc " , TTR ( " Calculates the transpose of a transform. " ) , { VisualShaderNodeTransformFunc : : FUNC_TRANSPOSE } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
2019-02-22 18:38:58 +01:00
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Add (+) " , " Transform/Operators " , " VisualShaderNodeTransformOp " , TTR ( " Sums two transforms. " ) , { VisualShaderNodeTransformOp : : OP_ADD } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " Divide (/) " , " Transform/Operators " , " VisualShaderNodeTransformOp " , TTR ( " Divides two transforms. " ) , { VisualShaderNodeTransformOp : : OP_A_DIV_B } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " Multiply (*) " , " Transform/Operators " , " VisualShaderNodeTransformOp " , TTR ( " Multiplies two transforms. " ) , { VisualShaderNodeTransformOp : : OP_AxB } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " MultiplyComp (*) " , " Transform/Operators " , " VisualShaderNodeTransformOp " , TTR ( " Performs per-component multiplication of two transforms. " ) , { VisualShaderNodeTransformOp : : OP_AxB_COMP } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " Subtract (-) " , " Transform/Operators " , " VisualShaderNodeTransformOp " , TTR ( " Subtracts two transforms. " ) , { VisualShaderNodeTransformOp : : OP_A_MINUS_B } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " TransformVectorMult (*) " , " Transform/Operators " , " VisualShaderNodeTransformVecMult " , TTR ( " Multiplies vector by transform. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
2019-02-22 18:38:58 +01:00
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " TransformConstant " , " Transform/Variables " , " VisualShaderNodeTransformConstant " , TTR ( " Transform constant. " ) , { } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
add_options . push_back ( AddOption ( " TransformParameter " , " Transform/Variables " , " VisualShaderNodeTransformParameter " , TTR ( " Transform parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_TRANSFORM ) ) ;
2019-02-22 18:38:58 +01:00
2022-08-28 08:14:38 +02:00
// UTILITY
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " DistanceFade " , " Utility " , " VisualShaderNodeDistanceFade " , TTR ( " The distance fade effect fades out each pixel based on its distance to another object. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " ProximityFade " , " Utility " , " VisualShaderNodeProximityFade " , TTR ( " The proximity fade effect fades out each pixel based on its distance to another object. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR , TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " RandomRange " , " Utility " , " VisualShaderNodeRandomRange " , TTR ( " Returns a random value between the minimum and maximum input values. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
2024-07-18 09:47:55 +02:00
add_options . push_back ( AddOption ( " RotationByAxis " , " Utility " , " VisualShaderNodeRotationByAxis " , TTR ( " Builds a rotation matrix from the given axis and angle, multiply the input vector by it and returns both this vector and a matrix. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
2022-08-28 08:14:38 +02:00
2019-02-22 18:38:58 +01:00
// VECTOR
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " VectorFunc " , " Vector/Common " , " VisualShaderNodeVectorFunc " , TTR ( " Vector function. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " VectorOp " , " Vector/Common " , " VisualShaderNodeVectorOp " , TTR ( " Vector operator. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " VectorCompose " , " Vector/Common " , " VisualShaderNodeVectorCompose " , TTR ( " Composes vector from scalars. " ) ) ) ;
add_options . push_back ( AddOption ( " VectorDecompose " , " Vector/Common " , " VisualShaderNodeVectorDecompose " , TTR ( " Decomposes vector to scalars. " ) ) ) ;
add_options . push_back ( AddOption ( " Vector2Compose " , " Vector/Composition " , " VisualShaderNodeVectorCompose " , TTR ( " Composes 2D vector from two scalars. " ) , { VisualShaderNodeVectorCompose : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Vector2Decompose " , " Vector/Composition " , " VisualShaderNodeVectorDecompose " , TTR ( " Decomposes 2D vector to two scalars. " ) , { VisualShaderNodeVectorDecompose : : OP_TYPE_VECTOR_2D } ) ) ;
add_options . push_back ( AddOption ( " Vector3Compose " , " Vector/Composition " , " VisualShaderNodeVectorCompose " , TTR ( " Composes 3D vector from three scalars. " ) , { VisualShaderNodeVectorCompose : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Vector3Decompose " , " Vector/Composition " , " VisualShaderNodeVectorDecompose " , TTR ( " Decomposes 3D vector to three scalars. " ) , { VisualShaderNodeVectorDecompose : : OP_TYPE_VECTOR_3D } ) ) ;
add_options . push_back ( AddOption ( " Vector4Compose " , " Vector/Composition " , " VisualShaderNodeVectorCompose " , TTR ( " Composes 4D vector from four scalars. " ) , { VisualShaderNodeVectorCompose : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Vector4Decompose " , " Vector/Composition " , " VisualShaderNodeVectorDecompose " , TTR ( " Decomposes 4D vector to four scalars. " ) , { VisualShaderNodeVectorDecompose : : OP_TYPE_VECTOR_4D } ) ) ;
add_options . push_back ( AddOption ( " Abs " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the absolute value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ABS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Abs " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the absolute value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ABS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Abs " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the absolute value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ABS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ACos " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ACOS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " ACos " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ACOS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ACos " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ACOS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ACosH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ACOSH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " ACosH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ACOSH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ACosH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ACOSH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ASin " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ASIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " ASin " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ASIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ASin " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ASIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ASinH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ASINH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " ASinH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ASINH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ASinH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ASINH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ATan " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ATAN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " ATan " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ATAN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ATan " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the arc-tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ATAN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ATan2 " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the arc-tangent of the parameters. " ) , { VisualShaderNodeVectorOp : : OP_ATAN2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " ATan2 " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the arc-tangent of the parameters. " ) , { VisualShaderNodeVectorOp : : OP_ATAN2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ATan2 " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the arc-tangent of the parameters. " ) , { VisualShaderNodeVectorOp : : OP_ATAN2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " ATanH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ATANH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " ATanH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ATANH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " ATanH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse hyperbolic tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ATANH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2023-04-08 06:30:11 +02:00
add_options . push_back ( AddOption ( " Ceil " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer that is greater than or equal to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_CEIL , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Ceil " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer that is greater than or equal to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_CEIL , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Ceil " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer that is greater than or equal to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_CEIL , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Clamp " , " Vector/Functions " , " VisualShaderNodeClamp " , TTR ( " Constrains a value to lie between two further values. " ) , { VisualShaderNodeClamp : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Clamp " , " Vector/Functions " , " VisualShaderNodeClamp " , TTR ( " Constrains a value to lie between two further values. " ) , { VisualShaderNodeClamp : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Clamp " , " Vector/Functions " , " VisualShaderNodeClamp " , TTR ( " Constrains a value to lie between two further values. " ) , { VisualShaderNodeClamp : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Cos " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_COS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Cos " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_COS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Cos " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_COS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " CosH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_COSH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " CosH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_COSH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " CosH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic cosine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_COSH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Cross " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Calculates the cross product of two vectors. " ) , { VisualShaderNodeVectorOp : : OP_CROSS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Degrees " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Converts a quantity in radians to degrees. " ) , { VisualShaderNodeVectorFunc : : FUNC_DEGREES , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Degrees " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Converts a quantity in radians to degrees. " ) , { VisualShaderNodeVectorFunc : : FUNC_DEGREES , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Degrees " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Converts a quantity in radians to degrees. " ) , { VisualShaderNodeVectorFunc : : FUNC_DEGREES , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " DFdX " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Derivative in 'x' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_X , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " DFdX " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Derivative in 'x' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_X , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " DFdX " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Derivative in 'x' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_X , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " DFdY " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Derivative in 'y' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_Y , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " DFdY " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Derivative in 'y' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_Y , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " DFdY " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Derivative in 'y' using local differencing. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_Y , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " Distance2D " , " Vector/Functions " , " VisualShaderNodeVectorDistance " , TTR ( " Returns the distance between two points. " ) , { VisualShaderNodeVectorDistance : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Distance3D " , " Vector/Functions " , " VisualShaderNodeVectorDistance " , TTR ( " Returns the distance between two points. " ) , { VisualShaderNodeVectorDistance : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Distance4D " , " Vector/Functions " , " VisualShaderNodeVectorDistance " , TTR ( " Returns the distance between two points. " ) , { VisualShaderNodeVectorDistance : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Dot " , " Vector/Functions " , " VisualShaderNodeDotProduct " , TTR ( " Calculates the dot product of two vectors. " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Exp " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-e Exponential. " ) , { VisualShaderNodeVectorFunc : : FUNC_EXP , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Exp " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-e Exponential. " ) , { VisualShaderNodeVectorFunc : : FUNC_EXP , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Exp " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-e Exponential. " ) , { VisualShaderNodeVectorFunc : : FUNC_EXP , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Exp2 " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-2 Exponential. " ) , { VisualShaderNodeVectorFunc : : FUNC_EXP2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Exp2 " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-2 Exponential. " ) , { VisualShaderNodeVectorFunc : : FUNC_EXP2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Exp2 " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-2 Exponential. " ) , { VisualShaderNodeVectorFunc : : FUNC_EXP2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " FaceForward " , " Vector/Functions " , " VisualShaderNodeFaceForward " , TTR ( " Returns the vector that points in the same direction as a reference vector. The function has three vector parameters : N, the vector to orient, I, the incident vector, and Nref, the reference vector. If the dot product of I and Nref is smaller than zero the return value is N. Otherwise -N is returned. " ) , { VisualShaderNodeFaceForward : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " FaceForward " , " Vector/Functions " , " VisualShaderNodeFaceForward " , TTR ( " Returns the vector that points in the same direction as a reference vector. The function has three vector parameters : N, the vector to orient, I, the incident vector, and Nref, the reference vector. If the dot product of I and Nref is smaller than zero the return value is N. Otherwise -N is returned. " ) , { VisualShaderNodeFaceForward : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " FaceForward " , " Vector/Functions " , " VisualShaderNodeFaceForward " , TTR ( " Returns the vector that points in the same direction as a reference vector. The function has three vector parameters : N, the vector to orient, I, the incident vector, and Nref, the reference vector. If the dot product of I and Nref is smaller than zero the return value is N. Otherwise -N is returned. " ) , { VisualShaderNodeFaceForward : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Floor " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer less than or equal to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_FLOOR , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Floor " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer less than or equal to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_FLOOR , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Floor " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer less than or equal to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_FLOOR , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Fract " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Computes the fractional part of the argument. " ) , { VisualShaderNodeVectorFunc : : FUNC_FRACT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Fract " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Computes the fractional part of the argument. " ) , { VisualShaderNodeVectorFunc : : FUNC_FRACT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Fract " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Computes the fractional part of the argument. " ) , { VisualShaderNodeVectorFunc : : FUNC_FRACT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Fresnel " , " Vector/Functions " , " VisualShaderNodeFresnel " , TTR ( " Returns falloff based on the dot product of surface normal and view direction of camera (pass associated inputs to it). " ) , { } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " InverseSqrt " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse of the square root of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_INVERSE_SQRT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " InverseSqrt " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse of the square root of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_INVERSE_SQRT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " InverseSqrt " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the inverse of the square root of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_INVERSE_SQRT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Length2D " , " Vector/Functions " , " VisualShaderNodeVectorLen " , TTR ( " Calculates the length of a vector. " ) , { VisualShaderNodeVectorLen : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Length3D " , " Vector/Functions " , " VisualShaderNodeVectorLen " , TTR ( " Calculates the length of a vector. " ) , { VisualShaderNodeVectorLen : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Length4D " , " Vector/Functions " , " VisualShaderNodeVectorLen " , TTR ( " Calculates the length of a vector. " ) , { VisualShaderNodeVectorLen : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_SCALAR ) ) ;
add_options . push_back ( AddOption ( " Log " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Natural logarithm. " ) , { VisualShaderNodeVectorFunc : : FUNC_LOG , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Log " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Natural logarithm. " ) , { VisualShaderNodeVectorFunc : : FUNC_LOG , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Log " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Natural logarithm. " ) , { VisualShaderNodeVectorFunc : : FUNC_LOG , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Log2 " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-2 logarithm. " ) , { VisualShaderNodeVectorFunc : : FUNC_LOG2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Log2 " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-2 logarithm. " ) , { VisualShaderNodeVectorFunc : : FUNC_LOG2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Log2 " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Base-2 logarithm. " ) , { VisualShaderNodeVectorFunc : : FUNC_LOG2 , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Max " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the greater of two values. " ) , { VisualShaderNodeVectorOp : : OP_MAX , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Max " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the greater of two values. " ) , { VisualShaderNodeVectorOp : : OP_MAX , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Max " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the greater of two values. " ) , { VisualShaderNodeVectorOp : : OP_MAX , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Min " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the lesser of two values. " ) , { VisualShaderNodeVectorOp : : OP_MIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Min " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the lesser of two values. " ) , { VisualShaderNodeVectorOp : : OP_MIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Min " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the lesser of two values. " ) , { VisualShaderNodeVectorOp : : OP_MIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Mix " , " Vector/Functions " , " VisualShaderNodeMix " , TTR ( " Linear interpolation between two vectors. " ) , { VisualShaderNodeMix : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Mix " , " Vector/Functions " , " VisualShaderNodeMix " , TTR ( " Linear interpolation between two vectors. " ) , { VisualShaderNodeMix : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Mix " , " Vector/Functions " , " VisualShaderNodeMix " , TTR ( " Linear interpolation between two vectors. " ) , { VisualShaderNodeMix : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " MixS " , " Vector/Functions " , " VisualShaderNodeMix " , TTR ( " Linear interpolation between two vectors using scalar. " ) , { VisualShaderNodeMix : : OP_TYPE_VECTOR_2D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " MixS " , " Vector/Functions " , " VisualShaderNodeMix " , TTR ( " Linear interpolation between two vectors using scalar. " ) , { VisualShaderNodeMix : : OP_TYPE_VECTOR_3D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " MixS " , " Vector/Functions " , " VisualShaderNodeMix " , TTR ( " Linear interpolation between two vectors using scalar. " ) , { VisualShaderNodeMix : : OP_TYPE_VECTOR_4D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " MultiplyAdd (a * b + c) " , " Vector/Functions " , " VisualShaderNodeMultiplyAdd " , TTR ( " Performs a fused multiply-add operation (a * b + c) on vectors. " ) , { VisualShaderNodeMultiplyAdd : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " MultiplyAdd (a * b + c) " , " Vector/Functions " , " VisualShaderNodeMultiplyAdd " , TTR ( " Performs a fused multiply-add operation (a * b + c) on vectors. " ) , { VisualShaderNodeMultiplyAdd : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " MultiplyAdd (a * b + c) " , " Vector/Functions " , " VisualShaderNodeMultiplyAdd " , TTR ( " Performs a fused multiply-add operation (a * b + c) on vectors. " ) , { VisualShaderNodeMultiplyAdd : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Negate (*-1) " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the opposite value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_NEGATE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Negate (*-1) " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the opposite value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_NEGATE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Negate (*-1) " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the opposite value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_NEGATE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Normalize " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Calculates the normalize product of vector. " ) , { VisualShaderNodeVectorFunc : : FUNC_NORMALIZE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Normalize " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Calculates the normalize product of vector. " ) , { VisualShaderNodeVectorFunc : : FUNC_NORMALIZE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Normalize " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Calculates the normalize product of vector. " ) , { VisualShaderNodeVectorFunc : : FUNC_NORMALIZE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " OneMinus (1-) " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " 1.0 - vector " ) , { VisualShaderNodeVectorFunc : : FUNC_ONEMINUS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " OneMinus (1-) " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " 1.0 - vector " ) , { VisualShaderNodeVectorFunc : : FUNC_ONEMINUS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " OneMinus (1-) " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " 1.0 - vector " ) , { VisualShaderNodeVectorFunc : : FUNC_ONEMINUS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Pow (^) " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the value of the first parameter raised to the power of the second. " ) , { VisualShaderNodeVectorOp : : OP_POW , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Pow (^) " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the value of the first parameter raised to the power of the second. " ) , { VisualShaderNodeVectorOp : : OP_POW , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Pow (^) " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the value of the first parameter raised to the power of the second. " ) , { VisualShaderNodeVectorOp : : OP_POW , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Radians " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Converts a quantity in degrees to radians. " ) , { VisualShaderNodeVectorFunc : : FUNC_RADIANS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Radians " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Converts a quantity in degrees to radians. " ) , { VisualShaderNodeVectorFunc : : FUNC_RADIANS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Radians " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Converts a quantity in degrees to radians. " ) , { VisualShaderNodeVectorFunc : : FUNC_RADIANS , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Reciprocal " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " 1.0 / vector " ) , { VisualShaderNodeVectorFunc : : FUNC_RECIPROCAL , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Reciprocal " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " 1.0 / vector " ) , { VisualShaderNodeVectorFunc : : FUNC_RECIPROCAL , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Reciprocal " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " 1.0 / vector " ) , { VisualShaderNodeVectorFunc : : FUNC_RECIPROCAL , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Reflect " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the vector that points in the direction of reflection ( a : incident vector, b : normal vector ). " ) , { VisualShaderNodeVectorOp : : OP_REFLECT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Reflect " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the vector that points in the direction of reflection ( a : incident vector, b : normal vector ). " ) , { VisualShaderNodeVectorOp : : OP_REFLECT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Reflect " , " Vector/Functions " , " VisualShaderNodeVectorOp " , TTR ( " Returns the vector that points in the direction of reflection ( a : incident vector, b : normal vector ). " ) , { VisualShaderNodeVectorOp : : OP_REFLECT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Refract " , " Vector/Functions " , " VisualShaderNodeVectorRefract " , TTR ( " Returns the vector that points in the direction of refraction. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Refract " , " Vector/Functions " , " VisualShaderNodeVectorRefract " , TTR ( " Returns the vector that points in the direction of refraction. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Refract " , " Vector/Functions " , " VisualShaderNodeVectorRefract " , TTR ( " Returns the vector that points in the direction of refraction. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2024-09-22 02:22:51 +02:00
add_options . push_back ( AddOption ( " Remap " , " Vector/Functions " , " VisualShaderNodeRemap " , TTR ( " Remaps a vector from the input range to the output range. " ) , { VisualShaderNodeRemap : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Remap " , " Vector/Functions " , " VisualShaderNodeRemap " , TTR ( " Remaps a vector from the input range to the output range. " ) , { VisualShaderNodeRemap : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Remap " , " Vector/Functions " , " VisualShaderNodeRemap " , TTR ( " Remaps a vector from the input range to the output range. " ) , { VisualShaderNodeRemap : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " RemapS " , " Vector/Functions " , " VisualShaderNodeRemap " , TTR ( " Remaps a vector from the input range to the output range. Ranges defined with scalars. " ) , { VisualShaderNodeRemap : : OP_TYPE_VECTOR_2D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " RemapS " , " Vector/Functions " , " VisualShaderNodeRemap " , TTR ( " Remaps a vector from the input range to the output range. Ranges defined with scalars. " ) , { VisualShaderNodeRemap : : OP_TYPE_VECTOR_3D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " RemapS " , " Vector/Functions " , " VisualShaderNodeRemap " , TTR ( " Remaps a vector from the input range to the output range. Ranges defined with scalars. " ) , { VisualShaderNodeRemap : : OP_TYPE_VECTOR_4D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Round " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ROUND , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Round " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ROUND , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Round " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest integer to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ROUND , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " RoundEven " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest even integer to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ROUNDEVEN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " RoundEven " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest even integer to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ROUNDEVEN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " RoundEven " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the nearest even integer to the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_ROUNDEVEN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Saturate " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Clamps the value between 0.0 and 1.0. " ) , { VisualShaderNodeVectorFunc : : FUNC_SATURATE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Saturate " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Clamps the value between 0.0 and 1.0. " ) , { VisualShaderNodeVectorFunc : : FUNC_SATURATE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Saturate " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Clamps the value between 0.0 and 1.0. " ) , { VisualShaderNodeVectorFunc : : FUNC_SATURATE , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Sign " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Extracts the sign of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SIGN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Sign " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Extracts the sign of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SIGN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Sign " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Extracts the sign of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SIGN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Sin " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Sin " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Sin " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SIN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " SinH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SINH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " SinH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SINH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " SinH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic sine of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SINH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Sqrt " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the square root of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SQRT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Sqrt " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the square root of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SQRT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Sqrt " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the square root of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_SQRT , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " SmoothStep " , " Vector/Functions " , " VisualShaderNodeSmoothStep " , TTR ( " SmoothStep function( vector(edge0), vector(edge1), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge0' and 1.0 if 'x' is larger than 'edge1'. Otherwise the return value is interpolated between 0.0 and 1.0 using Hermite polynomials. " ) , { VisualShaderNodeSmoothStep : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " SmoothStep " , " Vector/Functions " , " VisualShaderNodeSmoothStep " , TTR ( " SmoothStep function( vector(edge0), vector(edge1), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge0' and 1.0 if 'x' is larger than 'edge1'. Otherwise the return value is interpolated between 0.0 and 1.0 using Hermite polynomials. " ) , { VisualShaderNodeSmoothStep : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " SmoothStep " , " Vector/Functions " , " VisualShaderNodeSmoothStep " , TTR ( " SmoothStep function( vector(edge0), vector(edge1), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge0' and 1.0 if 'x' is larger than 'edge1'. Otherwise the return value is interpolated between 0.0 and 1.0 using Hermite polynomials. " ) , { VisualShaderNodeSmoothStep : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " SmoothStepS " , " Vector/Functions " , " VisualShaderNodeSmoothStep " , TTR ( " SmoothStep function( scalar(edge0), scalar(edge1), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge0' and 1.0 if 'x' is larger than 'edge1'. Otherwise the return value is interpolated between 0.0 and 1.0 using Hermite polynomials. " ) , { VisualShaderNodeSmoothStep : : OP_TYPE_VECTOR_2D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " SmoothStepS " , " Vector/Functions " , " VisualShaderNodeSmoothStep " , TTR ( " SmoothStep function( scalar(edge0), scalar(edge1), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge0' and 1.0 if 'x' is larger than 'edge1'. Otherwise the return value is interpolated between 0.0 and 1.0 using Hermite polynomials. " ) , { VisualShaderNodeSmoothStep : : OP_TYPE_VECTOR_3D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " SmoothStepS " , " Vector/Functions " , " VisualShaderNodeSmoothStep " , TTR ( " SmoothStep function( scalar(edge0), scalar(edge1), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge0' and 1.0 if 'x' is larger than 'edge1'. Otherwise the return value is interpolated between 0.0 and 1.0 using Hermite polynomials. " ) , { VisualShaderNodeSmoothStep : : OP_TYPE_VECTOR_4D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Step " , " Vector/Functions " , " VisualShaderNodeStep " , TTR ( " Step function( vector(edge), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge' and otherwise 1.0. " ) , { VisualShaderNodeStep : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Step " , " Vector/Functions " , " VisualShaderNodeStep " , TTR ( " Step function( vector(edge), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge' and otherwise 1.0. " ) , { VisualShaderNodeStep : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " StepS " , " Vector/Functions " , " VisualShaderNodeStep " , TTR ( " Step function( scalar(edge), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge' and otherwise 1.0. " ) , { VisualShaderNodeStep : : OP_TYPE_VECTOR_2D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " StepS " , " Vector/Functions " , " VisualShaderNodeStep " , TTR ( " Step function( scalar(edge), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge' and otherwise 1.0. " ) , { VisualShaderNodeStep : : OP_TYPE_VECTOR_3D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " StepS " , " Vector/Functions " , " VisualShaderNodeStep " , TTR ( " Step function( scalar(edge), vector(x) ). \n \n Returns 0.0 if 'x' is smaller than 'edge' and otherwise 1.0. " ) , { VisualShaderNodeStep : : OP_TYPE_VECTOR_4D_SCALAR } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Sum (+) " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Sum of absolute derivative in 'x' and 'y'. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_SUM , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " Sum (+) " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Sum of absolute derivative in 'x' and 'y'. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_SUM , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
add_options . push_back ( AddOption ( " Sum (+) " , " Vector/Functions " , " VisualShaderNodeDerivativeFunc " , TTR ( " (Fragment/Light mode only) (Vector) Sum of absolute derivative in 'x' and 'y'. " ) , { VisualShaderNodeDerivativeFunc : : FUNC_SUM , VisualShaderNodeDerivativeFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , - 1 , true ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Tan " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TAN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Tan " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TAN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Tan " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TAN , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " TanH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TANH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " TanH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TANH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " TanH " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Returns the hyperbolic tangent of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TANH , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Trunc " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the truncated value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TRUNC , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Trunc " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the truncated value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TRUNC , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Trunc " , " Vector/Functions " , " VisualShaderNodeVectorFunc " , TTR ( " Finds the truncated value of the parameter. " ) , { VisualShaderNodeVectorFunc : : FUNC_TRUNC , VisualShaderNodeVectorFunc : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Add (+) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Adds 2D vector to 2D vector. " ) , { VisualShaderNodeVectorOp : : OP_ADD , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Add (+) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Adds 3D vector to 3D vector. " ) , { VisualShaderNodeVectorOp : : OP_ADD , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Add (+) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Adds 4D vector to 4D vector. " ) , { VisualShaderNodeVectorOp : : OP_ADD , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Divide (/) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Divides 2D vector by 2D vector. " ) , { VisualShaderNodeVectorOp : : OP_DIV , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Divide (/) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Divides 3D vector by 3D vector. " ) , { VisualShaderNodeVectorOp : : OP_DIV , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Divide (/) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Divides 4D vector by 4D vector. " ) , { VisualShaderNodeVectorOp : : OP_DIV , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Multiply (*) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Multiplies 2D vector by 2D vector. " ) , { VisualShaderNodeVectorOp : : OP_MUL , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Multiply (*) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Multiplies 3D vector by 3D vector. " ) , { VisualShaderNodeVectorOp : : OP_MUL , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Multiply (*) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Multiplies 4D vector by 4D vector. " ) , { VisualShaderNodeVectorOp : : OP_MUL , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2024-02-28 20:39:12 +01:00
add_options . push_back ( AddOption ( " Remainder (%) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Returns the remainder of the two 2D vectors. " ) , { VisualShaderNodeVectorOp : : OP_MOD , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Remainder (%) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Returns the remainder of the two 3D vectors. " ) , { VisualShaderNodeVectorOp : : OP_MOD , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Remainder (%) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Returns the remainder of the two 4D vectors. " ) , { VisualShaderNodeVectorOp : : OP_MOD , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-10-26 17:20:58 +02:00
add_options . push_back ( AddOption ( " Subtract (-) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Subtracts 2D vector from 2D vector. " ) , { VisualShaderNodeVectorOp : : OP_SUB , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_2D } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Subtract (-) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Subtracts 3D vector from 3D vector. " ) , { VisualShaderNodeVectorOp : : OP_SUB , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_3D } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Subtract (-) " , " Vector/Operators " , " VisualShaderNodeVectorOp " , TTR ( " Subtracts 4D vector from 4D vector. " ) , { VisualShaderNodeVectorOp : : OP_SUB , VisualShaderNodeVectorOp : : OP_TYPE_VECTOR_4D } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Vector2Constant " , " Vector/Variables " , " VisualShaderNodeVec2Constant " , TTR ( " 2D vector constant. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Vector2Parameter " , " Vector/Variables " , " VisualShaderNodeVec2Parameter " , TTR ( " 2D vector parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_2D ) ) ;
add_options . push_back ( AddOption ( " Vector3Constant " , " Vector/Variables " , " VisualShaderNodeVec3Constant " , TTR ( " 3D vector constant. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Vector3Parameter " , " Vector/Variables " , " VisualShaderNodeVec3Parameter " , TTR ( " 3D vector parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_3D ) ) ;
add_options . push_back ( AddOption ( " Vector4Constant " , " Vector/Variables " , " VisualShaderNodeVec4Constant " , TTR ( " 4D vector constant. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
add_options . push_back ( AddOption ( " Vector4Parameter " , " Vector/Variables " , " VisualShaderNodeVec4Parameter " , TTR ( " 4D vector parameter. " ) , { } , VisualShaderNode : : PORT_TYPE_VECTOR_4D ) ) ;
2019-02-22 18:38:58 +01:00
// SPECIAL
2024-02-07 02:37:26 +01:00
add_options . push_back ( AddOption ( " Frame " , " Special " , " VisualShaderNodeFrame " , TTR ( " A rectangular area with a description string for better graph organization. " ) ) ) ;
2022-09-07 14:00:49 +02:00
add_options . push_back ( AddOption ( " Expression " , " Special " , " VisualShaderNodeExpression " , TTR ( " Custom Godot Shader Language expression, with custom amount of input and output ports. This is a direct injection of code into the vertex/fragment/light function, do not use it to write the function declarations inside. " ) ) ) ;
add_options . push_back ( AddOption ( " GlobalExpression " , " Special " , " VisualShaderNodeGlobalExpression " , TTR ( " Custom Godot Shader Language expression, which is placed on top of the resulted shader. You can place various function definitions inside and call it later in the Expressions. You can also declare varyings, parameters and constants. " ) ) ) ;
add_options . push_back ( AddOption ( " ParameterRef " , " Special " , " VisualShaderNodeParameterRef " , TTR ( " A reference to an existing parameter. " ) ) ) ;
add_options . push_back ( AddOption ( " VaryingGetter " , " Special " , " VisualShaderNodeVaryingGetter " , TTR ( " Get varying parameter. " ) , { } , - 1 , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " VaryingSetter " , " Special " , " VisualShaderNodeVaryingSetter " , TTR ( " Set varying parameter. " ) , { } , - 1 , TYPE_FLAGS_VERTEX | TYPE_FLAGS_FRAGMENT , Shader : : MODE_SPATIAL ) ) ;
add_options . push_back ( AddOption ( " VaryingGetter " , " Special " , " VisualShaderNodeVaryingGetter " , TTR ( " Get varying parameter. " ) , { } , - 1 , TYPE_FLAGS_FRAGMENT | TYPE_FLAGS_LIGHT , Shader : : MODE_CANVAS_ITEM ) ) ;
add_options . push_back ( AddOption ( " VaryingSetter " , " Special " , " VisualShaderNodeVaryingSetter " , TTR ( " Set varying parameter. " ) , { } , - 1 , TYPE_FLAGS_VERTEX | TYPE_FLAGS_FRAGMENT , Shader : : MODE_CANVAS_ITEM ) ) ;
2024-05-07 16:48:03 +02:00
add_options . push_back ( AddOption ( " Reroute " , " Special " , " VisualShaderNodeReroute " , TTR ( " Reroute connections freely, can be used to connect multiple input ports to single output port. " ) ) ) ;
2019-05-19 12:07:00 +02:00
2019-10-02 22:26:56 +02:00
custom_node_option_idx = add_options . size ( ) ;
2019-02-22 18:38:58 +01:00
/////////////////////////////////////////////////////////////////////
2018-07-14 23:15:42 +02:00
Ref < VisualShaderNodePluginDefault > default_plugin ;
2021-06-18 00:03:09 +02:00
default_plugin . instantiate ( ) ;
2022-07-16 08:59:20 +02:00
default_plugin - > set_editor ( this ) ;
2018-07-14 23:15:42 +02:00
add_plugin ( default_plugin ) ;
2021-06-18 00:03:09 +02:00
graph_plugin . instantiate ( ) ;
2022-07-16 08:59:20 +02:00
graph_plugin - > set_editor ( this ) ;
2020-09-09 16:40:27 +02:00
2022-08-01 20:01:48 +02:00
property_editor_popup = memnew ( PopupPanel ) ;
2024-03-05 13:27:33 +01:00
property_editor_popup - > set_min_size ( Size2 ( 360 , 0 ) * EDSCALE ) ;
2022-08-01 20:01:48 +02:00
add_child ( property_editor_popup ) ;
2018-07-14 23:15:42 +02:00
2022-08-01 20:01:48 +02:00
edited_property_holder . instantiate ( ) ;
2018-07-14 23:15:42 +02:00
}
class VisualShaderNodePluginInputEditor : public OptionButton {
2019-03-19 19:35:57 +01:00
GDCLASS ( VisualShaderNodePluginInputEditor , OptionButton ) ;
2018-07-14 23:15:42 +02:00
2022-07-16 08:59:20 +02:00
VisualShaderEditor * editor = nullptr ;
2018-07-14 23:15:42 +02:00
Ref < VisualShaderNodeInput > input ;
public :
void _notification ( int p_what ) {
2022-02-16 15:17:55 +01:00
switch ( p_what ) {
case NOTIFICATION_READY : {
2024-05-14 14:21:31 +02:00
connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderNodePluginInputEditor : : _item_selected ) ) ;
2022-02-16 15:17:55 +01:00
} break ;
2018-07-14 23:15:42 +02:00
}
}
void _item_selected ( int p_item ) {
2022-07-16 08:59:20 +02:00
editor - > call_deferred ( SNAME ( " _input_select_item " ) , input , get_item_text ( p_item ) ) ;
2018-07-14 23:15:42 +02:00
}
2022-07-16 08:59:20 +02:00
void setup ( VisualShaderEditor * p_editor , const Ref < VisualShaderNodeInput > & p_input ) {
editor = p_editor ;
2018-07-14 23:15:42 +02:00
input = p_input ;
2022-04-12 19:09:29 +02:00
Ref < Texture2D > type_icon [ ] = {
2023-09-13 13:14:07 +02:00
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " float " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " int " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " uint " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector2 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector3 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector4 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " bool " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Transform3D " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " ImageTexture " ) , EditorStringName ( EditorIcons ) ) ,
2018-07-14 23:15:42 +02:00
} ;
add_item ( " [None] " ) ;
int to_select = - 1 ;
for ( int i = 0 ; i < input - > get_input_index_count ( ) ; i + + ) {
if ( input - > get_input_name ( ) = = input - > get_input_index_name ( i ) ) {
to_select = i + 1 ;
}
add_icon_item ( type_icon [ input - > get_input_index_type ( i ) ] , input - > get_input_index_name ( i ) ) ;
}
if ( to_select > = 0 ) {
select ( to_select ) ;
}
}
} ;
2020-07-28 10:02:57 +02:00
////////////////
2022-01-09 15:02:13 +01:00
class VisualShaderNodePluginVaryingEditor : public OptionButton {
GDCLASS ( VisualShaderNodePluginVaryingEditor , OptionButton ) ;
2022-07-16 08:59:20 +02:00
VisualShaderEditor * editor = nullptr ;
2022-01-09 15:02:13 +01:00
Ref < VisualShaderNodeVarying > varying ;
public :
void _notification ( int p_what ) {
if ( p_what = = NOTIFICATION_READY ) {
2024-05-14 14:21:31 +02:00
connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderNodePluginVaryingEditor : : _item_selected ) ) ;
2022-01-09 15:02:13 +01:00
}
}
void _item_selected ( int p_item ) {
2022-07-16 08:59:20 +02:00
editor - > call_deferred ( SNAME ( " _varying_select_item " ) , varying , get_item_text ( p_item ) ) ;
2022-01-09 15:02:13 +01:00
}
2022-07-16 08:59:20 +02:00
void setup ( VisualShaderEditor * p_editor , const Ref < VisualShaderNodeVarying > & p_varying , VisualShader : : Type p_type ) {
editor = p_editor ;
2022-01-09 15:02:13 +01:00
varying = p_varying ;
Ref < Texture2D > type_icon [ ] = {
2023-09-13 13:14:07 +02:00
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " float " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " int " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " uint " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector2 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector3 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector4 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " bool " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Transform3D " ) , EditorStringName ( EditorIcons ) ) ,
2022-01-09 15:02:13 +01:00
} ;
bool is_getter = Ref < VisualShaderNodeVaryingGetter > ( p_varying . ptr ( ) ) . is_valid ( ) ;
add_item ( " [None] " ) ;
int to_select = - 1 ;
for ( int i = 0 , j = 0 ; i < varying - > get_varyings_count ( ) ; i + + ) {
VisualShader : : VaryingMode mode = varying - > get_varying_mode_by_index ( i ) ;
if ( is_getter ) {
if ( mode = = VisualShader : : VARYING_MODE_FRAG_TO_LIGHT ) {
if ( p_type ! = VisualShader : : TYPE_LIGHT ) {
j + + ;
continue ;
}
} else {
if ( p_type ! = VisualShader : : TYPE_FRAGMENT & & p_type ! = VisualShader : : TYPE_LIGHT ) {
j + + ;
continue ;
}
}
} else {
if ( mode = = VisualShader : : VARYING_MODE_FRAG_TO_LIGHT ) {
if ( p_type ! = VisualShader : : TYPE_FRAGMENT ) {
j + + ;
continue ;
}
} else {
if ( p_type ! = VisualShader : : TYPE_VERTEX ) {
j + + ;
continue ;
}
}
}
if ( varying - > get_varying_name ( ) = = varying - > get_varying_name_by_index ( i ) ) {
to_select = i - j + 1 ;
}
add_icon_item ( type_icon [ varying - > get_varying_type_by_index ( i ) ] , varying - > get_varying_name_by_index ( i ) ) ;
}
if ( to_select > = 0 ) {
select ( to_select ) ;
}
}
} ;
////////////////
2022-08-27 11:22:43 +02:00
class VisualShaderNodePluginParameterRefEditor : public OptionButton {
GDCLASS ( VisualShaderNodePluginParameterRefEditor , OptionButton ) ;
2020-07-28 10:02:57 +02:00
2022-07-16 08:59:20 +02:00
VisualShaderEditor * editor = nullptr ;
2022-08-27 11:22:43 +02:00
Ref < VisualShaderNodeParameterRef > parameter_ref ;
2020-07-28 10:02:57 +02:00
public :
void _notification ( int p_what ) {
2022-02-16 15:17:55 +01:00
switch ( p_what ) {
case NOTIFICATION_READY : {
2024-05-14 14:21:31 +02:00
connect ( SceneStringName ( item_selected ) , callable_mp ( this , & VisualShaderNodePluginParameterRefEditor : : _item_selected ) ) ;
2022-02-16 15:17:55 +01:00
} break ;
2020-07-28 10:02:57 +02:00
}
}
void _item_selected ( int p_item ) {
2022-08-27 11:22:43 +02:00
editor - > call_deferred ( SNAME ( " _parameter_ref_select_item " ) , parameter_ref , get_item_text ( p_item ) ) ;
2020-07-28 10:02:57 +02:00
}
2022-08-27 11:22:43 +02:00
void setup ( VisualShaderEditor * p_editor , const Ref < VisualShaderNodeParameterRef > & p_parameter_ref ) {
2022-07-16 08:59:20 +02:00
editor = p_editor ;
2022-08-27 11:22:43 +02:00
parameter_ref = p_parameter_ref ;
2020-07-28 10:02:57 +02:00
2022-04-12 19:09:29 +02:00
Ref < Texture2D > type_icon [ ] = {
2023-09-13 13:14:07 +02:00
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " float " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " int " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " uint " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " bool " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector2 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector3 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Vector4 " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Transform3D " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " Color " ) , EditorStringName ( EditorIcons ) ) ,
EditorNode : : get_singleton ( ) - > get_editor_theme ( ) - > get_icon ( SNAME ( " ImageTexture " ) , EditorStringName ( EditorIcons ) ) ,
2020-07-28 10:02:57 +02:00
} ;
add_item ( " [None] " ) ;
int to_select = - 1 ;
2022-08-27 11:22:43 +02:00
for ( int i = 0 ; i < p_parameter_ref - > get_parameters_count ( ) ; i + + ) {
if ( p_parameter_ref - > get_parameter_name ( ) = = p_parameter_ref - > get_parameter_name_by_index ( i ) ) {
2020-07-28 10:02:57 +02:00
to_select = i + 1 ;
}
2022-08-27 11:22:43 +02:00
add_icon_item ( type_icon [ p_parameter_ref - > get_parameter_type_by_index ( i ) ] , p_parameter_ref - > get_parameter_name_by_index ( i ) ) ;
2020-07-28 10:02:57 +02:00
}
if ( to_select > = 0 ) {
select ( to_select ) ;
}
}
} ;
////////////////
2018-07-14 23:15:42 +02:00
class VisualShaderNodePluginDefaultEditor : public VBoxContainer {
2019-03-19 19:35:57 +01:00
GDCLASS ( VisualShaderNodePluginDefaultEditor , VBoxContainer ) ;
2022-07-16 08:59:20 +02:00
VisualShaderEditor * editor = nullptr ;
2019-08-05 16:13:02 +02:00
Ref < Resource > parent_resource ;
2022-05-02 16:28:25 +02:00
int node_id = 0 ;
2020-09-10 07:31:07 +02:00
VisualShader : : Type shader_type ;
2019-03-19 19:35:57 +01:00
2018-07-14 23:15:42 +02:00
public :
2020-03-05 15:33:01 +01:00
void _property_changed ( const String & p_property , const Variant & p_value , const String & p_field = " " , bool p_changing = false ) {
2020-05-14 16:41:43 +02:00
if ( p_changing ) {
2018-09-15 08:47:38 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2018-07-14 23:15:42 +02:00
updating = true ;
2023-09-12 12:15:44 +02:00
undo_redo - > create_action ( vformat ( TTR ( " Edit Visual Property: %s " ) , p_property ) , UndoRedo : : MERGE_ENDS ) ;
2020-03-03 10:46:03 +01:00
undo_redo - > add_do_property ( node . ptr ( ) , p_property , p_value ) ;
undo_redo - > add_undo_property ( node . ptr ( ) , p_property , node - > get ( p_property ) ) ;
2019-08-05 16:13:02 +02:00
2024-04-08 15:31:27 +02:00
Ref < VisualShaderNode > vsnode = editor - > get_visual_shader ( ) - > get_node ( shader_type , node_id ) ;
ERR_FAIL_COND ( vsnode . is_null ( ) ) ;
// Check for invalid connections due to removed ports.
// We need to know the new state of the node to generate the proper undo/redo instructions.
// Quite hacky but the best way I could come up with for now.
Ref < VisualShaderNode > vsnode_new = vsnode - > duplicate ( ) ;
vsnode_new - > set ( p_property , p_value ) ;
const int input_port_count = vsnode_new - > get_input_port_count ( ) ;
2024-07-28 14:53:09 +02:00
const int output_port_count = vsnode_new - > get_expanded_output_port_count ( ) ;
2024-04-08 15:31:27 +02:00
List < VisualShader : : Connection > conns ;
editor - > get_visual_shader ( ) - > get_node_connections ( shader_type , & conns ) ;
VisualShaderGraphPlugin * graph_plugin = editor - > get_graph_plugin ( ) ;
bool undo_node_already_updated = false ;
for ( const VisualShader : : Connection & c : conns ) {
if ( ( c . from_node = = node_id & & c . from_port > = output_port_count ) | | ( c . to_node = = node_id & & c . to_port > = input_port_count ) ) {
undo_redo - > add_do_method ( editor - > get_visual_shader ( ) . ptr ( ) , " disconnect_nodes " , shader_type , c . from_node , c . from_port , c . to_node , c . to_port ) ;
undo_redo - > add_do_method ( graph_plugin , " disconnect_nodes " , shader_type , c . from_node , c . from_port , c . to_node , c . to_port ) ;
// We need to update the node before reconnecting to avoid accessing a non-existing port.
undo_redo - > add_undo_method ( graph_plugin , " update_node_deferred " , shader_type , node_id ) ;
undo_node_already_updated = true ;
undo_redo - > add_undo_method ( editor - > get_visual_shader ( ) . ptr ( ) , " connect_nodes " , shader_type , c . from_node , c . from_port , c . to_node , c . to_port ) ;
undo_redo - > add_undo_method ( graph_plugin , " connect_nodes " , shader_type , c . from_node , c . from_port , c . to_node , c . to_port ) ;
}
}
2019-08-05 16:13:02 +02:00
if ( p_value . get_type ( ) = = Variant : : OBJECT ) {
2024-04-08 15:31:27 +02:00
Ref < Resource > prev_res = vsnode - > get ( p_property ) ;
2022-05-03 01:43:50 +02:00
Ref < Resource > curr_res = p_value ;
2019-08-05 16:13:02 +02:00
if ( curr_res . is_null ( ) ) {
2022-05-03 01:43:50 +02:00
undo_redo - > add_do_method ( this , " _open_inspector " , ( Ref < Resource > ) parent_resource . ptr ( ) ) ;
2019-08-05 16:13:02 +02:00
} else {
2022-05-03 01:43:50 +02:00
undo_redo - > add_do_method ( this , " _open_inspector " , ( Ref < Resource > ) curr_res . ptr ( ) ) ;
2019-08-05 16:13:02 +02:00
}
if ( ! prev_res . is_null ( ) ) {
2022-05-03 01:43:50 +02:00
undo_redo - > add_undo_method ( this , " _open_inspector " , ( Ref < Resource > ) prev_res . ptr ( ) ) ;
2019-08-05 16:13:02 +02:00
} else {
2022-05-03 01:43:50 +02:00
undo_redo - > add_undo_method ( this , " _open_inspector " , ( Ref < Resource > ) parent_resource . ptr ( ) ) ;
2019-08-05 16:13:02 +02:00
}
2020-09-10 07:31:07 +02:00
}
if ( p_property ! = " constant " ) {
2022-07-16 08:59:20 +02:00
if ( graph_plugin ) {
2023-02-03 13:09:51 +01:00
undo_redo - > add_do_method ( editor , " _update_next_previews " , node_id ) ;
undo_redo - > add_undo_method ( editor , " _update_next_previews " , node_id ) ;
2022-07-16 08:59:20 +02:00
undo_redo - > add_do_method ( graph_plugin , " update_node_deferred " , shader_type , node_id ) ;
2024-04-08 15:31:27 +02:00
if ( ! undo_node_already_updated ) {
undo_redo - > add_undo_method ( graph_plugin , " update_node_deferred " , shader_type , node_id ) ;
}
2022-01-07 08:59:15 +01:00
}
2019-08-05 16:13:02 +02:00
}
2024-04-08 15:31:27 +02:00
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
2019-08-05 16:13:02 +02:00
2018-07-14 23:15:42 +02:00
updating = false ;
}
void _node_changed ( ) {
2020-05-14 16:41:43 +02:00
if ( updating ) {
2018-07-14 23:15:42 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
for ( int i = 0 ; i < properties . size ( ) ; i + + ) {
properties [ i ] - > update_property ( ) ;
}
}
2022-05-03 01:43:50 +02:00
void _resource_selected ( const String & p_path , Ref < Resource > p_resource ) {
2019-08-05 16:13:02 +02:00
_open_inspector ( p_resource ) ;
}
2022-05-03 01:43:50 +02:00
void _open_inspector ( Ref < Resource > p_resource ) {
2021-11-17 21:08:55 +01:00
InspectorDock : : get_inspector_singleton ( ) - > edit ( p_resource . ptr ( ) ) ;
2019-08-05 16:13:02 +02:00
}
2022-05-02 16:28:25 +02:00
bool updating = false ;
2018-07-14 23:15:42 +02:00
Ref < VisualShaderNode > node ;
Vector < EditorProperty * > properties ;
2020-02-06 13:11:03 +01:00
Vector < Label * > prop_names ;
void _show_prop_names ( bool p_show ) {
for ( int i = 0 ; i < prop_names . size ( ) ; i + + ) {
prop_names [ i ] - > set_visible ( p_show ) ;
}
}
2018-07-14 23:15:42 +02:00
2024-02-15 17:25:58 +01:00
void setup ( VisualShaderEditor * p_editor , Ref < Resource > p_parent_resource , const Vector < EditorProperty * > & p_properties , const Vector < StringName > & p_names , const HashMap < StringName , String > & p_overrided_names , Ref < VisualShaderNode > p_node ) {
2022-07-16 08:59:20 +02:00
editor = p_editor ;
2019-08-05 16:13:02 +02:00
parent_resource = p_parent_resource ;
2018-07-14 23:15:42 +02:00
updating = false ;
node = p_node ;
properties = p_properties ;
2020-09-10 07:31:07 +02:00
node_id = ( int ) p_node - > get_meta ( " id " ) ;
shader_type = VisualShader : : Type ( ( int ) p_node - > get_meta ( " shader_type " ) ) ;
2018-07-14 23:15:42 +02:00
for ( int i = 0 ; i < p_properties . size ( ) ; i + + ) {
2020-02-06 13:11:03 +01:00
HBoxContainer * hbox = memnew ( HBoxContainer ) ;
hbox - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
add_child ( hbox ) ;
Label * prop_name = memnew ( Label ) ;
String prop_name_str = p_names [ i ] ;
2021-11-04 16:42:57 +01:00
if ( p_overrided_names . has ( p_names [ i ] ) ) {
prop_name_str = p_overrided_names [ p_names [ i ] ] + " : " ;
} else {
prop_name_str = prop_name_str . capitalize ( ) + " : " ;
}
2024-01-23 22:29:45 +01:00
prop_name - > set_auto_translate_mode ( AUTO_TRANSLATE_MODE_DISABLED ) ; // TODO: Implement proper translation switch.
2020-02-06 13:11:03 +01:00
prop_name - > set_text ( prop_name_str ) ;
prop_name - > set_visible ( false ) ;
hbox - > add_child ( prop_name ) ;
prop_names . push_back ( prop_name ) ;
p_properties [ i ] - > set_h_size_flags ( SIZE_EXPAND_FILL ) ;
hbox - > add_child ( p_properties [ i ] ) ;
2018-07-14 23:15:42 +02:00
2019-08-05 16:13:02 +02:00
bool res_prop = Object : : cast_to < EditorPropertyResource > ( p_properties [ i ] ) ;
if ( res_prop ) {
2020-02-21 23:26:13 +01:00
p_properties [ i ] - > connect ( " resource_selected " , callable_mp ( this , & VisualShaderNodePluginDefaultEditor : : _resource_selected ) ) ;
2019-08-05 16:13:02 +02:00
}
2020-03-05 15:33:01 +01:00
properties [ i ] - > connect ( " property_changed " , callable_mp ( this , & VisualShaderNodePluginDefaultEditor : : _property_changed ) ) ;
2018-07-14 23:15:42 +02:00
properties [ i ] - > set_object_and_property ( node . ptr ( ) , p_names [ i ] ) ;
properties [ i ] - > update_property ( ) ;
properties [ i ] - > set_name_split_ratio ( 0 ) ;
}
2023-07-03 21:29:37 +02:00
node - > connect_changed ( callable_mp ( this , & VisualShaderNodePluginDefaultEditor : : _node_changed ) ) ;
2018-07-14 23:15:42 +02:00
}
static void _bind_methods ( ) {
2020-02-21 23:26:13 +01:00
ClassDB : : bind_method ( " _open_inspector " , & VisualShaderNodePluginDefaultEditor : : _open_inspector ) ; // Used by UndoRedo.
ClassDB : : bind_method ( " _show_prop_names " , & VisualShaderNodePluginDefaultEditor : : _show_prop_names ) ; // Used with call_deferred.
2018-07-14 23:15:42 +02:00
}
} ;
2019-08-05 16:13:02 +02:00
Control * VisualShaderNodePluginDefault : : create_editor ( const Ref < Resource > & p_parent_resource , const Ref < VisualShaderNode > & p_node ) {
2022-01-09 15:02:13 +01:00
Ref < VisualShader > p_shader = Ref < VisualShader > ( p_parent_resource . ptr ( ) ) ;
if ( p_shader . is_valid ( ) & & ( p_node - > is_class ( " VisualShaderNodeVaryingGetter " ) | | p_node - > is_class ( " VisualShaderNodeVaryingSetter " ) ) ) {
VisualShaderNodePluginVaryingEditor * editor = memnew ( VisualShaderNodePluginVaryingEditor ) ;
2022-07-16 08:59:20 +02:00
editor - > setup ( vseditor , p_node , p_shader - > get_shader_type ( ) ) ;
2022-01-09 15:02:13 +01:00
return editor ;
}
2022-08-27 11:22:43 +02:00
if ( p_node - > is_class ( " VisualShaderNodeParameterRef " ) ) {
VisualShaderNodePluginParameterRefEditor * editor = memnew ( VisualShaderNodePluginParameterRefEditor ) ;
2022-07-16 08:59:20 +02:00
editor - > setup ( vseditor , p_node ) ;
2022-01-09 15:02:13 +01:00
return editor ;
2020-07-28 10:02:57 +02:00
}
2018-07-14 23:15:42 +02:00
if ( p_node - > is_class ( " VisualShaderNodeInput " ) ) {
2022-01-09 15:02:13 +01:00
VisualShaderNodePluginInputEditor * editor = memnew ( VisualShaderNodePluginInputEditor ) ;
2022-07-16 08:59:20 +02:00
editor - > setup ( vseditor , p_node ) ;
2022-01-09 15:02:13 +01:00
return editor ;
2018-07-14 23:15:42 +02:00
}
Vector < StringName > properties = p_node - > get_editable_properties ( ) ;
if ( properties . size ( ) = = 0 ) {
2020-04-02 01:20:12 +02:00
return nullptr ;
2018-07-14 23:15:42 +02:00
}
List < PropertyInfo > props ;
p_node - > get_property_list ( & props ) ;
Vector < PropertyInfo > pinfo ;
2021-07-24 15:46:25 +02:00
for ( const PropertyInfo & E : props ) {
2018-07-14 23:15:42 +02:00
for ( int i = 0 ; i < properties . size ( ) ; i + + ) {
2021-07-16 05:45:57 +02:00
if ( E . name = = String ( properties [ i ] ) ) {
pinfo . push_back ( E ) ;
2018-07-14 23:15:42 +02:00
}
}
}
2020-05-14 16:41:43 +02:00
if ( pinfo . size ( ) = = 0 ) {
2020-04-02 01:20:12 +02:00
return nullptr ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
properties . clear ( ) ;
Ref < VisualShaderNode > node = p_node ;
Vector < EditorProperty * > editors ;
for ( int i = 0 ; i < pinfo . size ( ) ; i + + ) {
EditorProperty * prop = EditorInspector : : instantiate_property_editor ( node . ptr ( ) , pinfo [ i ] . type , pinfo [ i ] . name , pinfo [ i ] . hint , pinfo [ i ] . hint_string , pinfo [ i ] . usage ) ;
2020-05-14 16:41:43 +02:00
if ( ! prop ) {
2020-04-02 01:20:12 +02:00
return nullptr ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
if ( Object : : cast_to < EditorPropertyResource > ( prop ) ) {
Object : : cast_to < EditorPropertyResource > ( prop ) - > set_use_sub_inspector ( false ) ;
prop - > set_custom_minimum_size ( Size2 ( 100 * EDSCALE , 0 ) ) ;
2021-06-04 03:58:26 +02:00
} else if ( Object : : cast_to < EditorPropertyTransform3D > ( prop ) | | Object : : cast_to < EditorPropertyVector3 > ( prop ) ) {
2018-07-14 23:15:42 +02:00
prop - > set_custom_minimum_size ( Size2 ( 250 * EDSCALE , 0 ) ) ;
2022-04-12 19:09:29 +02:00
} else if ( Object : : cast_to < EditorPropertyQuaternion > ( prop ) ) {
prop - > set_custom_minimum_size ( Size2 ( 320 * EDSCALE , 0 ) ) ;
2019-04-23 20:21:17 +02:00
} else if ( Object : : cast_to < EditorPropertyFloat > ( prop ) ) {
2018-07-14 23:15:42 +02:00
prop - > set_custom_minimum_size ( Size2 ( 100 * EDSCALE , 0 ) ) ;
} else if ( Object : : cast_to < EditorPropertyEnum > ( prop ) ) {
prop - > set_custom_minimum_size ( Size2 ( 100 * EDSCALE , 0 ) ) ;
Object : : cast_to < EditorPropertyEnum > ( prop ) - > set_option_button_clip ( false ) ;
2024-02-23 01:01:28 +01:00
} else if ( Object : : cast_to < EditorPropertyColor > ( prop ) ) {
Object : : cast_to < EditorPropertyColor > ( prop ) - > set_live_changes_enabled ( false ) ;
2018-07-14 23:15:42 +02:00
}
editors . push_back ( prop ) ;
properties . push_back ( pinfo [ i ] . name ) ;
}
VisualShaderNodePluginDefaultEditor * editor = memnew ( VisualShaderNodePluginDefaultEditor ) ;
2022-07-16 08:59:20 +02:00
editor - > setup ( vseditor , p_parent_resource , editors , properties , p_node - > get_editable_properties_names ( ) , p_node ) ;
2018-07-14 23:15:42 +02:00
return editor ;
}
2022-08-15 21:39:53 +02:00
void EditorPropertyVisualShaderMode : : _option_selected ( int p_which ) {
2022-07-16 08:59:20 +02:00
Ref < VisualShader > visual_shader ( Object : : cast_to < VisualShader > ( get_edited_object ( ) ) ) ;
if ( visual_shader - > get_mode ( ) = = p_which ) {
2022-01-07 08:59:15 +01:00
return ;
}
2023-08-11 15:55:47 +02:00
ShaderEditorPlugin * shader_editor = Object : : cast_to < ShaderEditorPlugin > ( EditorNode : : get_editor_data ( ) . get_editor_by_name ( " Shader " ) ) ;
2022-07-16 08:59:20 +02:00
if ( ! shader_editor ) {
return ;
}
2024-07-12 20:56:49 +02:00
VisualShaderEditor * editor = Object : : cast_to < VisualShaderEditor > ( shader_editor - > get_shader_editor ( visual_shader ) ) ;
2022-07-16 08:59:20 +02:00
if ( ! editor ) {
2018-07-14 23:15:42 +02:00
return ;
2020-05-14 16:41:43 +02:00
}
2018-07-14 23:15:42 +02:00
2022-12-23 23:53:16 +01:00
EditorUndoRedoManager * undo_redo = EditorUndoRedoManager : : get_singleton ( ) ;
2019-02-21 20:41:01 +01:00
undo_redo - > create_action ( TTR ( " Visual Shader Mode Changed " ) ) ;
2018-07-14 23:15:42 +02:00
//do is easy
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " set_mode " , p_which ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " set_mode " , visual_shader - > get_mode ( ) ) ;
2020-09-12 10:01:48 +02:00
2022-01-07 08:59:15 +01:00
undo_redo - > add_do_method ( editor , " _set_mode " , p_which ) ;
undo_redo - > add_undo_method ( editor , " _set_mode " , visual_shader - > get_mode ( ) ) ;
2020-09-12 10:01:48 +02:00
2018-07-14 23:15:42 +02:00
//now undo is hell
//1. restore connections to output
for ( int i = 0 ; i < VisualShader : : TYPE_MAX ; i + + ) {
VisualShader : : Type type = VisualShader : : Type ( i ) ;
List < VisualShader : : Connection > conns ;
visual_shader - > get_node_connections ( type , & conns ) ;
2021-07-24 15:46:25 +02:00
for ( const VisualShader : : Connection & E : conns ) {
2021-07-16 05:45:57 +02:00
if ( E . to_node = = VisualShader : : NODE_ID_OUTPUT ) {
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " connect_nodes " , type , E . from_node , E . from_port , E . to_node , E . to_port ) ;
2018-07-14 23:15:42 +02:00
}
}
}
//2. restore input indices
for ( int i = 0 ; i < VisualShader : : TYPE_MAX ; i + + ) {
VisualShader : : Type type = VisualShader : : Type ( i ) ;
Vector < int > nodes = visual_shader - > get_node_list ( type ) ;
2019-02-12 21:10:08 +01:00
for ( int j = 0 ; j < nodes . size ( ) ; j + + ) {
Ref < VisualShaderNodeInput > input = visual_shader - > get_node ( type , nodes [ j ] ) ;
2018-07-14 23:15:42 +02:00
if ( ! input . is_valid ( ) ) {
continue ;
}
undo_redo - > add_undo_method ( input . ptr ( ) , " set_input_name " , input - > get_input_name ( ) ) ;
}
}
//3. restore enums and flags
List < PropertyInfo > props ;
visual_shader - > get_property_list ( & props ) ;
2021-07-24 15:46:25 +02:00
for ( const PropertyInfo & E : props ) {
2021-07-16 05:45:57 +02:00
if ( E . name . begins_with ( " flags/ " ) | | E . name . begins_with ( " modes/ " ) ) {
undo_redo - > add_undo_property ( visual_shader . ptr ( ) , E . name , visual_shader - > get ( E . name ) ) ;
2018-07-14 23:15:42 +02:00
}
}
2022-01-09 15:02:13 +01:00
//4. delete varyings (if needed)
if ( p_which = = VisualShader : : MODE_PARTICLES | | p_which = = VisualShader : : MODE_SKY | | p_which = = VisualShader : : MODE_FOG ) {
int var_count = visual_shader - > get_varyings_count ( ) ;
if ( var_count > 0 ) {
for ( int i = 0 ; i < var_count ; i + + ) {
const VisualShader : : Varying * var = visual_shader - > get_varying_by_index ( i ) ;
undo_redo - > add_do_method ( visual_shader . ptr ( ) , " remove_varying " , var - > name ) ;
undo_redo - > add_undo_method ( visual_shader . ptr ( ) , " add_varying " , var - > name , var - > mode , var - > type ) ;
}
2022-03-07 08:26:09 +01:00
undo_redo - > add_do_method ( editor , " _update_varyings " ) ;
undo_redo - > add_undo_method ( editor , " _update_varyings " ) ;
2022-01-09 15:02:13 +01:00
}
}
2022-02-07 20:58:37 +01:00
undo_redo - > add_do_method ( editor , " _update_nodes " ) ;
undo_redo - > add_undo_method ( editor , " _update_nodes " ) ;
2019-05-01 16:04:39 +02:00
2022-01-07 08:59:15 +01:00
undo_redo - > add_do_method ( editor , " _update_graph " ) ;
undo_redo - > add_undo_method ( editor , " _update_graph " ) ;
2018-07-14 23:15:42 +02:00
undo_redo - > commit_action ( ) ;
}
2022-08-15 21:39:53 +02:00
void EditorPropertyVisualShaderMode : : update_property ( ) {
2023-05-26 09:13:24 +02:00
int which = get_edited_property_value ( ) ;
2018-07-14 23:15:42 +02:00
options - > select ( which ) ;
}
2022-08-15 21:39:53 +02:00
void EditorPropertyVisualShaderMode : : setup ( const Vector < String > & p_options ) {
2018-07-14 23:15:42 +02:00
for ( int i = 0 ; i < p_options . size ( ) ; i + + ) {
options - > add_item ( p_options [ i ] , i ) ;
}
}
2022-08-15 21:39:53 +02:00
void EditorPropertyVisualShaderMode : : set_option_button_clip ( bool p_enable ) {
2018-07-14 23:15:42 +02:00
options - > set_clip_text ( p_enable ) ;
}
2022-08-15 21:39:53 +02:00
EditorPropertyVisualShaderMode : : EditorPropertyVisualShaderMode ( ) {
2018-07-14 23:15:42 +02:00
options = memnew ( OptionButton ) ;
options - > set_clip_text ( true ) ;
add_child ( options ) ;
add_focusable ( options ) ;
2024-05-14 14:21:31 +02:00
options - > connect ( SceneStringName ( item_selected ) , callable_mp ( this , & EditorPropertyVisualShaderMode : : _option_selected ) ) ;
2018-07-14 23:15:42 +02:00
}
2022-08-15 21:39:53 +02:00
bool EditorInspectorVisualShaderModePlugin : : can_handle ( Object * p_object ) {
2021-11-10 15:49:19 +01:00
return true ; // Can handle everything.
2018-07-14 23:15:42 +02:00
}
2023-01-31 19:08:46 +01:00
bool EditorInspectorVisualShaderModePlugin : : parse_property ( Object * p_object , const Variant : : Type p_type , const String & p_path , const PropertyHint p_hint , const String & p_hint_text , const BitField < PropertyUsageFlags > p_usage , const bool p_wide ) {
2018-07-14 23:15:42 +02:00
if ( p_path = = " mode " & & p_object - > is_class ( " VisualShader " ) & & p_type = = Variant : : INT ) {
2022-08-15 21:39:53 +02:00
EditorPropertyVisualShaderMode * mode_editor = memnew ( EditorPropertyVisualShaderMode ) ;
2018-07-14 23:15:42 +02:00
Vector < String > options = p_hint_text . split ( " , " ) ;
2022-07-16 08:59:20 +02:00
mode_editor - > setup ( options ) ;
add_property_editor ( p_path , mode_editor ) ;
2018-07-14 23:15:42 +02:00
return true ;
}
2021-11-10 15:49:19 +01:00
return false ;
2018-07-14 23:15:42 +02:00
}
2020-05-14 14:29:06 +02:00
2018-07-14 23:15:42 +02:00
//////////////////////////////////
void VisualShaderNodePortPreview : : _shader_changed ( ) {
2023-02-03 13:09:51 +01:00
if ( ! is_valid | | shader . is_null ( ) ) {
2018-07-14 23:15:42 +02:00
return ;
}
Vector < VisualShader : : DefaultTextureParam > default_textures ;
String shader_code = shader - > generate_preview_shader ( type , node , port , default_textures ) ;
Ref < Shader > preview_shader ;
2021-06-18 00:03:09 +02:00
preview_shader . instantiate ( ) ;
2018-07-14 23:15:42 +02:00
preview_shader - > set_code ( shader_code ) ;
for ( int i = 0 ; i < default_textures . size ( ) ; i + + ) {
2024-04-15 15:18:34 +02:00
int j = 0 ;
2024-08-04 13:43:55 +02:00
for ( List < Ref < Texture > > : : ConstIterator itr = default_textures [ i ] . params . begin ( ) ; itr ! = default_textures [ i ] . params . end ( ) ; + + itr , + + j ) {
2024-04-15 15:18:34 +02:00
preview_shader - > set_default_texture_parameter ( default_textures [ i ] . name , * itr , j ) ;
2021-10-17 13:38:26 +02:00
}
2018-07-14 23:15:42 +02:00
}
2022-09-29 11:53:28 +02:00
Ref < ShaderMaterial > mat ;
mat . instantiate ( ) ;
mat - > set_shader ( preview_shader ) ;
2018-07-14 23:15:42 +02:00
2024-07-11 15:20:25 +02:00
if ( preview_mat . is_valid ( ) & & preview_mat - > get_shader ( ) . is_valid ( ) ) {
List < PropertyInfo > params ;
preview_mat - > get_shader ( ) - > get_shader_uniform_list ( & params ) ;
for ( const PropertyInfo & E : params ) {
mat - > set_shader_parameter ( E . name , preview_mat - > get_shader_parameter ( E . name ) ) ;
2018-07-14 23:15:42 +02:00
}
}
2022-09-29 11:53:28 +02:00
set_material ( mat ) ;
2018-07-14 23:15:42 +02:00
}
2024-07-11 15:20:25 +02:00
void VisualShaderNodePortPreview : : setup ( const Ref < VisualShader > & p_shader , Ref < ShaderMaterial > & p_preview_material , VisualShader : : Type p_type , int p_node , int p_port , bool p_is_valid ) {
2018-07-14 23:15:42 +02:00
shader = p_shader ;
2023-07-03 21:29:37 +02:00
shader - > connect_changed ( callable_mp ( this , & VisualShaderNodePortPreview : : _shader_changed ) , CONNECT_DEFERRED ) ;
2024-07-11 15:20:25 +02:00
preview_mat = p_preview_material ;
2018-07-14 23:15:42 +02:00
type = p_type ;
port = p_port ;
node = p_node ;
2023-02-03 13:09:51 +01:00
is_valid = p_is_valid ;
2022-08-13 23:21:24 +02:00
queue_redraw ( ) ;
2018-07-14 23:15:42 +02:00
_shader_changed ( ) ;
}
Size2 VisualShaderNodePortPreview : : get_minimum_size ( ) const {
2022-10-18 16:43:37 +02:00
int port_preview_size = EDITOR_GET ( " editors/visual_editors/visual_shader/port_preview_size " ) ;
2022-04-30 03:56:57 +02:00
return Size2 ( port_preview_size , port_preview_size ) * EDSCALE ;
2018-07-14 23:15:42 +02:00
}
void VisualShaderNodePortPreview : : _notification ( int p_what ) {
2022-02-16 15:17:55 +01:00
switch ( p_what ) {
case NOTIFICATION_DRAW : {
Vector < Vector2 > points = {
Vector2 ( ) ,
Vector2 ( get_size ( ) . width , 0 ) ,
get_size ( ) ,
Vector2 ( 0 , get_size ( ) . height )
} ;
Vector < Vector2 > uvs = {
Vector2 ( 0 , 0 ) ,
Vector2 ( 1 , 0 ) ,
Vector2 ( 1 , 1 ) ,
Vector2 ( 0 , 1 )
} ;
2023-02-03 13:09:51 +01:00
if ( is_valid ) {
Vector < Color > colors = {
Color ( 1 , 1 , 1 , 1 ) ,
Color ( 1 , 1 , 1 , 1 ) ,
Color ( 1 , 1 , 1 , 1 ) ,
Color ( 1 , 1 , 1 , 1 )
} ;
draw_primitive ( points , colors , uvs ) ;
} else {
Vector < Color > colors = {
Color ( 0 , 0 , 0 , 1 ) ,
Color ( 0 , 0 , 0 , 1 ) ,
Color ( 0 , 0 , 0 , 1 ) ,
Color ( 0 , 0 , 0 , 1 )
} ;
draw_primitive ( points , colors , uvs ) ;
}
2022-02-16 15:17:55 +01:00
} break ;
2018-07-14 23:15:42 +02:00
}
}
2019-06-28 13:51:51 +02:00
//////////////////////////////////
String VisualShaderConversionPlugin : : converts_to ( ) const {
return " Shader " ;
}
bool VisualShaderConversionPlugin : : handles ( const Ref < Resource > & p_resource ) const {
Ref < VisualShader > vshader = p_resource ;
return vshader . is_valid ( ) ;
}
Ref < Resource > VisualShaderConversionPlugin : : convert ( const Ref < Resource > & p_resource ) const {
Ref < VisualShader > vshader = p_resource ;
ERR_FAIL_COND_V ( ! vshader . is_valid ( ) , Ref < Resource > ( ) ) ;
Ref < Shader > shader ;
2021-06-18 00:03:09 +02:00
shader . instantiate ( ) ;
2019-06-28 13:51:51 +02:00
String code = vshader - > get_code ( ) ;
shader - > set_code ( code ) ;
return shader ;
}