Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLukas Tönne <lukas.toenne@gmail.com>2014-02-17 18:40:42 +0400
committerLukas Tönne <lukas.toenne@gmail.com>2014-02-17 18:44:21 +0400
commitecd0565f28cb6cb5bc09455e05db6692a6fcf826 (patch)
tree8049e76ced72bbcfefce9c0283590a707927fdcb /source/blender/makesrna/intern/rna_nodetree.c
parenta5cfd3f518af0f9cf1f3db3d87609fe30b0532b7 (diff)
Fix T38651: Compositor Normal Node Sphere unchangable when Reset All To
Default Values is used on it. The default for the socket value was always 0. Now the default value for node socket default_value properties is chosen based on the socket subtype to give some more sensible values. NOTE: this may still be different from the values specified in the socket templates! It is not possible to directly use these template values, because all sockets share the same RNA types. At least it should work reasonably well in the majority of cases now.
Diffstat (limited to 'source/blender/makesrna/intern/rna_nodetree.c')
-rw-r--r--source/blender/makesrna/intern/rna_nodetree.c46
1 files changed, 46 insertions, 0 deletions
diff --git a/source/blender/makesrna/intern/rna_nodetree.c b/source/blender/makesrna/intern/rna_nodetree.c
index 92b8c935bd1..c00c93484d5 100644
--- a/source/blender/makesrna/intern/rna_nodetree.c
+++ b/source/blender/makesrna/intern/rna_nodetree.c
@@ -6453,6 +6453,20 @@ static void rna_def_node_socket_float(BlenderRNA *brna, const char *idname, cons
{
StructRNA *srna;
PropertyRNA *prop;
+ float value_default;
+
+ /* choose sensible common default based on subtype */
+ switch (subtype) {
+ case PROP_FACTOR:
+ value_default = 1.0f;
+ break;
+ case PROP_PERCENTAGE:
+ value_default = 100.0f;
+ break;
+ default:
+ value_default = 0.0f;
+ break;
+ }
srna = RNA_def_struct(brna, idname, "NodeSocketStandard");
RNA_def_struct_ui_text(srna, "Float Node Socket", "Floating point number socket of a node");
@@ -6478,6 +6492,7 @@ static void rna_def_node_socket_float(BlenderRNA *brna, const char *idname, cons
prop = RNA_def_property(srna, "default_value", PROP_FLOAT, subtype);
RNA_def_property_float_sdna(prop, NULL, "value");
+ RNA_def_property_float_default(prop, value_default);
RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocketStandard_float_range");
RNA_def_property_ui_text(prop, "Default Value", "Input value used for unconnected socket");
RNA_def_property_update(prop, NC_NODE | NA_EDITED, "rna_NodeSocketInterface_update");
@@ -6499,6 +6514,20 @@ static void rna_def_node_socket_int(BlenderRNA *brna, const char *identifier, co
{
StructRNA *srna;
PropertyRNA *prop;
+ int value_default;
+
+ /* choose sensible common default based on subtype */
+ switch (subtype) {
+ case PROP_FACTOR:
+ value_default = 1;
+ break;
+ case PROP_PERCENTAGE:
+ value_default = 100;
+ break;
+ default:
+ value_default = 0;
+ break;
+ }
srna = RNA_def_struct(brna, identifier, "NodeSocketStandard");
RNA_def_struct_ui_text(srna, "Integer Node Socket", "Integer number socket of a node");
@@ -6508,6 +6537,7 @@ static void rna_def_node_socket_int(BlenderRNA *brna, const char *identifier, co
prop = RNA_def_property(srna, "default_value", PROP_INT, subtype);
RNA_def_property_int_sdna(prop, NULL, "value");
+ RNA_def_property_int_default(prop, value_default);
RNA_def_property_int_funcs(prop, NULL, NULL, "rna_NodeSocketStandard_int_range");
RNA_def_property_ui_text(prop, "Default Value", "Input value used for unconnected socket");
RNA_def_property_update(prop, NC_NODE | NA_EDITED, "rna_NodeSocketStandard_value_update");
@@ -6579,6 +6609,21 @@ static void rna_def_node_socket_vector(BlenderRNA *brna, const char *identifier,
{
StructRNA *srna;
PropertyRNA *prop;
+ const float *value_default;
+
+ /* choose sensible common default based on subtype */
+ switch (subtype) {
+ case PROP_DIRECTION: {
+ static const float default_direction[3] = {0.0f, 0.0f, 1.0f};
+ value_default = default_direction;
+ break;
+ }
+ default: {
+ static const float default_vector[3] = {0.0f, 0.0f, 0.0f};
+ value_default = default_vector;
+ break;
+ }
+ }
srna = RNA_def_struct(brna, identifier, "NodeSocketStandard");
RNA_def_struct_ui_text(srna, "Vector Node Socket", "3D vector socket of a node");
@@ -6588,6 +6633,7 @@ static void rna_def_node_socket_vector(BlenderRNA *brna, const char *identifier,
prop = RNA_def_property(srna, "default_value", PROP_FLOAT, subtype);
RNA_def_property_float_sdna(prop, NULL, "value");
+ RNA_def_property_float_array_default(prop, value_default);
RNA_def_property_float_funcs(prop, NULL, NULL, "rna_NodeSocketStandard_vector_range");
RNA_def_property_ui_text(prop, "Default Value", "Input value used for unconnected socket");
RNA_def_property_update(prop, NC_NODE | NA_EDITED, "rna_NodeSocketStandard_value_update");