[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [17709] branches/blender2.5/blender/source /blender/makesrna/intern/rna_key.c: RNA:

Brecht Van Lommel brecht at blender.org
Thu Dec 4 02:58:14 CET 2008


Revision: 17709
          http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=17709
Author:   blendix
Date:     2008-12-04 02:58:14 +0100 (Thu, 04 Dec 2008)

Log Message:
-----------
RNA:
* DNA_key_types.h: wrapped KeyBlock.data, and added back position
  and current value, now done.

Modified Paths:
--------------
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_key.c

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_key.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_key.c	2008-12-04 00:07:47 UTC (rev 17708)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_key.c	2008-12-04 01:58:14 UTC (rev 17709)
@@ -62,13 +62,190 @@
 	return NULL;
 }
 
+static float rna_ShapeKeyPoint_co_get(PointerRNA *ptr, int index)
+{
+	float *vec= (float*)ptr->data;
+	return vec[index];
+}
+
+static void rna_ShapeKeyPoint_co_set(PointerRNA *ptr, int index, float value)
+{
+	float *vec= (float*)ptr->data;
+	vec[index]= value;
+}
+
+static float rna_ShapeKeyCurvePoint_tilt_get(PointerRNA *ptr)
+{
+	float *vec= (float*)ptr->data;
+	return vec[3];
+}
+
+static void rna_ShapeKeyCurvePoint_tilt_set(PointerRNA *ptr, float value)
+{
+	float *vec= (float*)ptr->data;
+	vec[3]= value;
+}
+
+static float rna_ShapeKeyBezierPoint_co_get(PointerRNA *ptr, int index)
+{
+	float *vec= (float*)ptr->data;
+	return vec[index+3];
+}
+
+static void rna_ShapeKeyBezierPoint_co_set(PointerRNA *ptr, int index, float value)
+{
+	float *vec= (float*)ptr->data;
+	vec[index+3]= value;
+}
+
+static float rna_ShapeKeyBezierPoint_handle_1_co_get(PointerRNA *ptr, int index)
+{
+	float *vec= (float*)ptr->data;
+	return vec[index];
+}
+
+static void rna_ShapeKeyBezierPoint_handle_1_co_set(PointerRNA *ptr, int index, float value)
+{
+	float *vec= (float*)ptr->data;
+	vec[index]= value;
+}
+
+static float rna_ShapeKeyBezierPoint_handle_2_co_get(PointerRNA *ptr, int index)
+{
+	float *vec= (float*)ptr->data;
+	return vec[6+index];
+}
+
+static void rna_ShapeKeyBezierPoint_handle_2_co_set(PointerRNA *ptr, int index, float value)
+{
+	float *vec= (float*)ptr->data;
+	vec[6+index]= value;
+}
+
+/*static float rna_ShapeKeyBezierPoint_tilt_get(PointerRNA *ptr)
+{
+	float *vec= (float*)ptr->data;
+	return vec[10];
+}
+
+static void rna_ShapeKeyBezierPoint_tilt_set(PointerRNA *ptr, float value)
+{
+	float *vec= (float*)ptr->data;
+	vec[10]= value;
+}*/
+
+static void rna_ShapeKey_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
+{
+	Key *key= rna_ShapeKey_find_key(ptr->id.data);
+	KeyBlock *kb= (KeyBlock*)ptr->data;
+	Curve *cu;
+	Nurb *nu;
+	int tot= kb->totelem, size= key->elemsize;
+
+    if(GS(key->from->name) == ID_CU) {
+		cu= (Curve*)key->from;
+		nu= cu->nurb.first;
+
+		if(nu->bezt) {
+			tot /= 3;
+			size *= 3;
+		}
+	}
+
+	rna_iterator_array_begin(iter, (void*)kb->data, size, tot, NULL);
+}
+
+static int rna_ShapeKey_data_length(PointerRNA *ptr)
+{
+	Key *key= rna_ShapeKey_find_key(ptr->id.data);
+	KeyBlock *kb= (KeyBlock*)ptr->data;
+	Curve *cu;
+	Nurb *nu;
+	int tot= kb->totelem;
+
+    if(GS(key->from->name) == ID_CU) {
+		cu= (Curve*)key->from;
+		nu= cu->nurb.first;
+
+		if(nu->bezt)
+			tot /= 3;
+	}
+
+	return tot;
+}
+
+static StructRNA *rna_ShapeKey_data_type(CollectionPropertyIterator *iter)
+{
+	Key *key= rna_ShapeKey_find_key(iter->parent.id.data);
+	Curve *cu;
+	Nurb *nu;
+
+	if(GS(key->from->name) == ID_CU) {
+		cu= (Curve*)key->from;
+		nu= cu->nurb.first;
+
+		if(nu->bezt)
+			return &RNA_ShapeKeyBezierPoint;
+		else
+			return &RNA_ShapeKeyCurvePoint;
+	}
+	else
+		return &RNA_ShapeKeyPoint;
+}
+
 #else
 
-void RNA_def_keyblock(BlenderRNA *brna)
+static void rna_def_keydata(BlenderRNA *brna)
 {
 	StructRNA *srna;
 	PropertyRNA *prop;
 
+	srna= RNA_def_struct(brna, "ShapeKeyPoint", NULL, "Shape Key Point");
+
+	prop= RNA_def_property(srna, "co", PROP_FLOAT, PROP_VECTOR);
+	RNA_def_property_array(prop, 3);
+	RNA_def_property_float_funcs(prop, "rna_ShapeKeyPoint_co_get", "rna_ShapeKeyPoint_co_set", NULL);
+	RNA_def_property_ui_text(prop, "Location", "");
+
+	srna= RNA_def_struct(brna, "ShapeKeyCurvePoint", NULL, "Shape Key Curve Point");
+
+	prop= RNA_def_property(srna, "co", PROP_FLOAT, PROP_VECTOR);
+	RNA_def_property_array(prop, 3);
+	RNA_def_property_float_funcs(prop, "rna_ShapeKeyPoint_co_get", "rna_ShapeKeyPoint_co_set", NULL);
+	RNA_def_property_ui_text(prop, "Location", "");
+
+	prop= RNA_def_property(srna, "tilt", PROP_FLOAT, PROP_NONE);
+	RNA_def_property_float_funcs(prop, "rna_ShapeKeyCurvePoint_tilt_get", "rna_ShapeKeyCurvePoint_tilt_set", NULL);
+	RNA_def_property_ui_text(prop, "Tilt", "");
+
+	srna= RNA_def_struct(brna, "ShapeKeyBezierPoint", NULL, "Shape Key Bezier Point");
+
+	prop= RNA_def_property(srna, "co", PROP_FLOAT, PROP_VECTOR);
+	RNA_def_property_array(prop, 3);
+	RNA_def_property_float_funcs(prop, "rna_ShapeKeyBezierPoint_co_get", "rna_ShapeKeyBezierPoint_co_set", NULL);
+	RNA_def_property_ui_text(prop, "Location", "");
+
+	prop= RNA_def_property(srna, "handle_1_co", PROP_FLOAT, PROP_VECTOR);
+	RNA_def_property_array(prop, 3);
+	RNA_def_property_float_funcs(prop, "rna_ShapeKeyBezierPoint_handle_1_co_get", "rna_ShapeKeyBezierPoint_handle_1_co_set", NULL);
+	RNA_def_property_ui_text(prop, "Handle 1 Location", "");
+
+	prop= RNA_def_property(srna, "handle_2_co", PROP_FLOAT, PROP_VECTOR);
+	RNA_def_property_array(prop, 3);
+	RNA_def_property_float_funcs(prop, "rna_ShapeKeyBezierPoint_handle_2_co_get", "rna_ShapeKeyBezierPoint_handle_2_co_set", NULL);
+	RNA_def_property_ui_text(prop, "Handle 2 Location", "");
+
+	/* appears to be unused currently
+	prop= RNA_def_property(srna, "tilt", PROP_FLOAT, PROP_NONE);
+	RNA_def_property_float_funcs(prop, "rna_ShapeKeyBezierPoint_tilt_get", "rna_ShapeKeyBezierPoint_tilt_set", NULL);
+	RNA_def_property_ui_text(prop, "Tilt", "");*/
+}
+
+static void rna_def_keyblock(BlenderRNA *brna)
+{
+	StructRNA *srna;
+	PropertyRNA *prop;
+
 	static EnumPropertyItem prop_keyblock_type_items[] = {
 		{KEY_LINEAR, "KEY_LINEAR", "Linear", ""},
 		{KEY_CARDINAL, "KEY_CARDINAL", "Cardinal", ""},
@@ -82,14 +259,18 @@
 	RNA_def_property_ui_text(prop, "Name", "");
 	RNA_def_struct_name_property(srna, prop);
 
-	/* the current value isn't easily editable this way, it's linked to an IPO.
-	prop= RNA_def_property(srna, "current_position", PROP_FLOAT, PROP_NONE);
+	/* keys need to be sorted to edit this */
+	prop= RNA_def_property(srna, "frame", PROP_FLOAT, PROP_NONE);
+	RNA_def_property_flag(prop, PROP_NOT_EDITABLE);
 	RNA_def_property_float_sdna(prop, NULL, "pos");
-	RNA_def_property_ui_text(prop, "Current Position", "");
+	RNA_def_property_ui_text(prop, "Frame", "Frame for absolute keys.");
 
-	prop= RNA_def_property(srna, "current_value", PROP_FLOAT, PROP_NONE);
+	/* the current value isn't easily editable this way, it's linked to an IPO.
+	 * these seem to be mostly the values that are being written to, not edited */
+	prop= RNA_def_property(srna, "value", PROP_FLOAT, PROP_NONE);
+	RNA_def_property_flag(prop, PROP_NOT_EDITABLE);
 	RNA_def_property_float_sdna(prop, NULL, "curval");
-	RNA_def_property_ui_text(prop, "Current Value", "");*/
+	RNA_def_property_ui_text(prop, "Value", "Value of shape key at the current frame.");
 
 	prop= RNA_def_property(srna, "interpolation", PROP_ENUM, PROP_NONE);
 	RNA_def_property_enum_sdna(prop, NULL, "type");
@@ -120,16 +301,17 @@
 	RNA_def_property_range(prop, -10.0f, 10.0f);
 	RNA_def_property_ui_text(prop, "Slider Max", "Maximum for slider.");
 
-	/* KeyBlock.data has to be wrapped still */
+	prop= RNA_def_property(srna, "data", PROP_COLLECTION, PROP_NONE);
+	RNA_def_property_collection_sdna(prop, NULL, "data", "totelem");
+	RNA_def_property_ui_text(prop, "Data", "");
+	RNA_def_property_collection_funcs(prop, "rna_ShapeKey_data_begin", 0, 0, 0, "rna_ShapeKey_data_type", "rna_ShapeKey_data_length", 0, 0);
 }
 
-void RNA_def_key(BlenderRNA *brna)
+static void rna_def_key(BlenderRNA *brna)
 {
 	StructRNA *srna;
 	PropertyRNA *prop;
 
-	RNA_def_keyblock(brna);
-
 	srna= RNA_def_struct(brna, "Key", "ID", "Key");
 
 	prop= RNA_def_property(srna, "reference_key", PROP_POINTER, PROP_NONE);
@@ -157,5 +339,12 @@
 	RNA_def_property_ui_text(prop, "Slurph", "Creates a delay in amount of frames in applying keypositions, first vertex goes first.");
 }
 
+void RNA_def_key(BlenderRNA *brna)
+{
+	rna_def_key(brna);
+	rna_def_keyblock(brna);
+	rna_def_keydata(brna);
+}
+
 #endif
 





More information about the Bf-blender-cvs mailing list