|
@@ -105,6 +105,7 @@ const char *VisualScriptBuiltinFunc::func_name[VisualScriptBuiltinFunc::FUNC_MAX
|
|
|
"color_named",
|
|
|
"smoothstep",
|
|
|
"posmod",
|
|
|
+ "lerp_angle",
|
|
|
};
|
|
|
|
|
|
VisualScriptBuiltinFunc::BuiltinFunc VisualScriptBuiltinFunc::find_function(const String &p_string) {
|
|
@@ -207,6 +208,7 @@ int VisualScriptBuiltinFunc::get_func_argument_count(BuiltinFunc p_func) {
|
|
|
case COLORN:
|
|
|
return 2;
|
|
|
case MATH_LERP:
|
|
|
+ case MATH_LERP_ANGLE:
|
|
|
case MATH_INVERSE_LERP:
|
|
|
case MATH_SMOOTHSTEP:
|
|
|
case MATH_MOVE_TOWARD:
|
|
@@ -318,7 +320,9 @@ PropertyInfo VisualScriptBuiltinFunc::get_input_value_port_info(int p_idx) const
|
|
|
return PropertyInfo(Variant::REAL, "steps");
|
|
|
} break;
|
|
|
case MATH_LERP:
|
|
|
- case MATH_INVERSE_LERP: {
|
|
|
+ case MATH_LERP_ANGLE:
|
|
|
+ case MATH_INVERSE_LERP:
|
|
|
+ case MATH_SMOOTHSTEP: {
|
|
|
if (p_idx == 0)
|
|
|
return PropertyInfo(Variant::REAL, "from");
|
|
|
else if (p_idx == 1)
|
|
@@ -338,14 +342,6 @@ PropertyInfo VisualScriptBuiltinFunc::get_input_value_port_info(int p_idx) const
|
|
|
else
|
|
|
return PropertyInfo(Variant::REAL, "ostop");
|
|
|
} break;
|
|
|
- case MATH_SMOOTHSTEP: {
|
|
|
- if (p_idx == 0)
|
|
|
- return PropertyInfo(Variant::REAL, "from");
|
|
|
- else if (p_idx == 1)
|
|
|
- return PropertyInfo(Variant::REAL, "to");
|
|
|
- else
|
|
|
- return PropertyInfo(Variant::REAL, "weight");
|
|
|
- } break;
|
|
|
case MATH_MOVE_TOWARD: {
|
|
|
if (p_idx == 0)
|
|
|
return PropertyInfo(Variant::REAL, "from");
|
|
@@ -532,6 +528,7 @@ PropertyInfo VisualScriptBuiltinFunc::get_output_value_port_info(int p_idx) cons
|
|
|
} break;
|
|
|
case MATH_STEPIFY:
|
|
|
case MATH_LERP:
|
|
|
+ case MATH_LERP_ANGLE:
|
|
|
case MATH_INVERSE_LERP:
|
|
|
case MATH_RANGE_LERP:
|
|
|
case MATH_SMOOTHSTEP:
|
|
@@ -856,6 +853,13 @@ void VisualScriptBuiltinFunc::exec_func(BuiltinFunc p_func, const Variant **p_in
|
|
|
VALIDATE_ARG_NUM(2);
|
|
|
*r_return = Math::lerp((double)*p_inputs[0], (double)*p_inputs[1], (double)*p_inputs[2]);
|
|
|
} break;
|
|
|
+ case VisualScriptBuiltinFunc::MATH_LERP_ANGLE: {
|
|
|
+
|
|
|
+ VALIDATE_ARG_NUM(0);
|
|
|
+ VALIDATE_ARG_NUM(1);
|
|
|
+ VALIDATE_ARG_NUM(2);
|
|
|
+ *r_return = Math::lerp_angle((double)*p_inputs[0], (double)*p_inputs[1], (double)*p_inputs[2]);
|
|
|
+ } break;
|
|
|
case VisualScriptBuiltinFunc::MATH_INVERSE_LERP: {
|
|
|
|
|
|
VALIDATE_ARG_NUM(0);
|
|
@@ -1369,6 +1373,7 @@ void VisualScriptBuiltinFunc::_bind_methods() {
|
|
|
BIND_ENUM_CONSTANT(BYTES_TO_VAR);
|
|
|
BIND_ENUM_CONSTANT(COLORN);
|
|
|
BIND_ENUM_CONSTANT(MATH_SMOOTHSTEP);
|
|
|
+ BIND_ENUM_CONSTANT(MATH_LERP_ANGLE);
|
|
|
BIND_ENUM_CONSTANT(FUNC_MAX);
|
|
|
}
|
|
|
|
|
@@ -1422,6 +1427,7 @@ void register_visual_script_builtin_func_node() {
|
|
|
VisualScriptLanguage::singleton->add_register_func("functions/built_in/decimals", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_DECIMALS>);
|
|
|
VisualScriptLanguage::singleton->add_register_func("functions/built_in/stepify", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_STEPIFY>);
|
|
|
VisualScriptLanguage::singleton->add_register_func("functions/built_in/lerp", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_LERP>);
|
|
|
+ VisualScriptLanguage::singleton->add_register_func("functions/built_in/lerp_angle", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_LERP_ANGLE>);
|
|
|
VisualScriptLanguage::singleton->add_register_func("functions/built_in/inverse_lerp", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_INVERSE_LERP>);
|
|
|
VisualScriptLanguage::singleton->add_register_func("functions/built_in/range_lerp", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_RANGE_LERP>);
|
|
|
VisualScriptLanguage::singleton->add_register_func("functions/built_in/smoothstep", create_builtin_func_node<VisualScriptBuiltinFunc::MATH_SMOOTHSTEP>);
|