Revision: 18392 http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=18392 Author: harkyman Date: 2009-01-07 05:06:52 +0100 (Wed, 07 Jan 2009)
Log Message: ----------- Finally committing useful rna for action types. This includes actions, action channels and action groups. I broke both pose channels and pose off into their own rna. Links also updated in Object rna for both Action and Pose stuff. Modified Paths: -------------- branches/blender2.5/blender/source/blender/makesrna/RNA_access.h branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h branches/blender2.5/blender/source/blender/makesrna/intern/rna_main.c branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c Added Paths: ----------- branches/blender2.5/blender/source/blender/makesrna/intern/rna_pose.c Modified: branches/blender2.5/blender/source/blender/makesrna/RNA_access.h =================================================================== --- branches/blender2.5/blender/source/blender/makesrna/RNA_access.h 2009-01-07 03:34:12 UTC (rev 18391) +++ branches/blender2.5/blender/source/blender/makesrna/RNA_access.h 2009-01-07 04:06:52 UTC (rev 18392) @@ -176,6 +176,8 @@ extern StructRNA RNA_PluginSequence; extern StructRNA RNA_PointCache; extern StructRNA RNA_PointerProperty; +extern StructRNA RNA_Pose; +extern StructRNA RNA_PoseChannel; extern StructRNA RNA_Property; extern StructRNA RNA_PropertySensor; extern StructRNA RNA_PythonController; Modified: branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c =================================================================== --- branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c 2009-01-07 03:34:12 UTC (rev 18391) +++ branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c 2009-01-07 04:06:52 UTC (rev 18392) @@ -925,6 +925,7 @@ {"rna_object_force.c", RNA_def_object_force}, {"rna_packedfile.c", RNA_def_packedfile}, {"rna_particle.c", RNA_def_particle}, + {"rna_pose.c", RNA_def_pose}, {"rna_property.c", RNA_def_gameproperty}, {"rna_radio.c", RNA_def_radio}, {"rna_rna.c", RNA_def_rna}, Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h =================================================================== --- branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h 2009-01-07 03:34:12 UTC (rev 18391) +++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h 2009-01-07 04:06:52 UTC (rev 18392) @@ -123,6 +123,7 @@ void RNA_def_object_force(struct BlenderRNA *brna); void RNA_def_packedfile(struct BlenderRNA *brna); void RNA_def_particle(struct BlenderRNA *brna); +void RNA_def_pose(struct BlenderRNA *brna); void RNA_def_radio(struct BlenderRNA *brna); void RNA_def_rna(struct BlenderRNA *brna); void RNA_def_scene(struct BlenderRNA *brna); Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_main.c =================================================================== --- branches/blender2.5/blender/source/blender/makesrna/intern/rna_main.c 2009-01-07 03:34:12 UTC (rev 18391) +++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_main.c 2009-01-07 04:06:52 UTC (rev 18392) @@ -246,7 +246,7 @@ {"texts", "Text", "rna_Main_text_begin", "Texts", "Text datablocks."}, {"sounds", "ID", "rna_Main_sound_begin", "Sounds", "Sound datablocks."}, {"armatures", "Armature", "rna_Main_armature_begin", "Armatures", "Armature datablocks."}, - {"actions", "ID", "rna_Main_action_begin", "Actions", "Action datablocks."}, + {"actions", "Action", "rna_Main_action_begin", "Actions", "Action datablocks."}, {"particles", "ID", "rna_Main_particle_begin", "Particles", "Particle datablocks."}, {NULL, NULL, NULL, NULL, NULL}}; int i; Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c =================================================================== --- branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c 2009-01-07 03:34:12 UTC (rev 18391) +++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c 2009-01-07 04:06:52 UTC (rev 18392) @@ -861,17 +861,17 @@ /* action / pose / nla */ prop= RNA_def_property(srna, "action", PROP_POINTER, PROP_NONE); - RNA_def_property_struct_type(prop, "UnknownType"); //action + RNA_def_property_struct_type(prop, "Action"); RNA_def_property_ui_text(prop, "Action", "Action used by object to define Ipo curves."); prop= RNA_def_property(srna, "pose_library", PROP_POINTER, PROP_NONE); RNA_def_property_pointer_sdna(prop, NULL, "poselib"); - RNA_def_property_struct_type(prop, "UnknownType"); // action + RNA_def_property_struct_type(prop, "Action"); RNA_def_property_ui_text(prop, "Pose Library", "Action used as a pose library for armatures."); prop= RNA_def_property(srna, "pose", PROP_POINTER, PROP_NONE); RNA_def_property_pointer_sdna(prop, NULL, "pose"); - RNA_def_property_struct_type(prop, "UnknownType"); + RNA_def_property_struct_type(prop, "Pose"); RNA_def_property_ui_text(prop, "Pose", "Current pose for armatures."); prop= RNA_def_property(srna, "pose_mode", PROP_BOOLEAN, PROP_NONE); Added: branches/blender2.5/blender/source/blender/makesrna/intern/rna_pose.c =================================================================== --- branches/blender2.5/blender/source/blender/makesrna/intern/rna_pose.c (rev 0) +++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_pose.c 2009-01-07 04:06:52 UTC (rev 18392) @@ -0,0 +1,204 @@ +/** + * $Id$ + * + * ***** BEGIN GPL LICENSE BLOCK ***** + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * + * Contributor(s): Blender Foundation (2008), Roland Hess + * + * ***** END GPL LICENSE BLOCK ***** + */ + +#include <stdlib.h> + +#include "RNA_define.h" +#include "RNA_types.h" + +#include "rna_internal.h" + +#include "DNA_action_types.h" +#include "DNA_armature_types.h" +#include "DNA_constraint_types.h" +#include "DNA_scene_types.h" + +#ifdef RNA_RUNTIME + +#else + +/* users shouldn't be editing pose channel data directly -- better to set ipos and let blender calc pose_channel stuff */ +/* it's going to be weird for users to find IK flags and other such here, instead of in bone where they would expect them + -- is there any way to put a doc in bone, pointing them here? */ + +static void rna_def_pose_channel(BlenderRNA *brna) +{ + StructRNA *srna; + PropertyRNA *prop; + + srna= RNA_def_struct(brna, "PoseChannel", NULL); + RNA_def_struct_sdna(srna, "bPoseChannel"); + RNA_def_struct_ui_text(srna, "Pose Channel", "Member of the 'Pose' type."); + + prop= RNA_def_property(srna, "constraints", PROP_COLLECTION, PROP_NONE); + RNA_def_property_collection_sdna(prop, NULL, "constraints", NULL); + RNA_def_property_struct_type(prop, "Constraint"); + RNA_def_property_ui_text(prop, "Constraints", "Constraints that act on this PoseChannel."); + + prop= RNA_def_property(srna, "name", PROP_STRING, PROP_NONE); + RNA_def_property_flag(prop, PROP_NOT_EDITABLE); + RNA_def_property_ui_text(prop, "Name", ""); + RNA_def_struct_name_property(srna, prop); + + prop= RNA_def_property(srna, "ik_dof_x", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "ikflag", BONE_IK_NO_XDOF); + RNA_def_property_ui_text(prop, "IK X DoF", "Allow movement around the X axis."); + + prop= RNA_def_property(srna, "ik_dof_y", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "ikflag", BONE_IK_NO_YDOF); + RNA_def_property_ui_text(prop, "IK Y DoF", "Allow movement around the Y axis."); + + prop= RNA_def_property(srna, "ik_dof_z", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "ikflag", BONE_IK_NO_ZDOF); + RNA_def_property_ui_text(prop, "IK Z DoF", "Allow movement around the Z axis."); + + prop= RNA_def_property(srna, "ik_limit_x", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "ikflag", BONE_IK_XLIMIT); + RNA_def_property_ui_text(prop, "IK X Limit", "Limit movement around the X axis."); + + prop= RNA_def_property(srna, "ik_limit_y", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "ikflag", BONE_IK_YLIMIT); + RNA_def_property_ui_text(prop, "IK Y Limit", "Limit movement around the Y axis."); + + prop= RNA_def_property(srna, "ik_limit_z", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "ikflag", BONE_IK_ZLIMIT); + RNA_def_property_ui_text(prop, "IK Z Limit", "Limit movement around the Z axis."); + + prop= RNA_def_property(srna, "selected", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "selectflag", BONE_SELECTED); + RNA_def_property_ui_text(prop, "Selected", ""); + + prop= RNA_def_property(srna, "protected", PROP_BOOLEAN, PROP_NONE); + RNA_def_property_boolean_sdna(prop, NULL, "protectflag", POSE_LOCKED); + RNA_def_property_ui_text(prop, "Protected", "Protect channel from being transformed."); + + prop= RNA_def_property(srna, "action_group_index", PROP_INT, PROP_NONE); + RNA_def_property_int_sdna(prop, NULL, "agrp_index"); + RNA_def_property_ui_text(prop, "Action Group Index", "Action Group this pose channel belogs to (0=no group)."); + + prop= RNA_def_property(srna, "path_start_frame", PROP_INT, PROP_NONE); + RNA_def_property_int_sdna(prop, NULL, "pathsf"); + RNA_def_property_flag(prop, PROP_NOT_EDITABLE); + RNA_def_property_ui_text(prop, "Bone Paths Calculation Start Frame", "Starting frame of range of frames to use for Bone Path calculations."); + + prop= RNA_def_property(srna, "path_end_frame", PROP_INT, PROP_NONE); + RNA_def_property_int_sdna(prop, NULL, "pathef"); + RNA_def_property_flag(prop, PROP_NOT_EDITABLE); + RNA_def_property_ui_text(prop, "Bone Paths Calculation End Frame", "End frame of range of frames to use for Bone Path calculations."); + + prop= RNA_def_property(srna, "bone", PROP_POINTER, PROP_NONE); + RNA_def_property_struct_type(prop, "Bone"); + RNA_def_property_flag(prop, PROP_NOT_EDITABLE); + RNA_def_property_ui_text(prop, "Bone", "Bone associated with this Pose Channel."); + + prop= RNA_def_property(srna, "parent", PROP_POINTER, PROP_NONE); + RNA_def_property_struct_type(prop, "PoseChannel"); + RNA_def_property_flag(prop, PROP_NOT_EDITABLE); + RNA_def_property_ui_text(prop, "Parent", "Parent of this pose channel."); + + prop= RNA_def_property(srna, "child", PROP_POINTER, PROP_NONE); + RNA_def_property_struct_type(prop, "PoseChannel"); + RNA_def_property_flag(prop, PROP_NOT_EDITABLE); + RNA_def_property_ui_text(prop, "Parent", "Child of this pose channel."); + @@ Diff output truncated at 10240 characters. @@ _______________________________________________ Bf-blender-cvs mailing list Bf-blender-cvs@blender.org http://lists.blender.org/mailman/listinfo/bf-blender-cvs