RNA:
authorBrecht Van Lommel <brechtvanlommel@pandora.be>
Sun, 30 Nov 2008 18:39:49 +0000 (18:39 +0000)
committerBrecht Van Lommel <brechtvanlommel@pandora.be>
Sun, 30 Nov 2008 18:39:49 +0000 (18:39 +0000)
* DNA_image_types.h done, except for some properties not being editable.

source/blender/makesrna/RNA_access.h
source/blender/makesrna/intern/makesrna.c
source/blender/makesrna/intern/rna_ID.c
source/blender/makesrna/intern/rna_image.c [new file with mode: 0644]
source/blender/makesrna/intern/rna_internal.h
source/blender/makesrna/intern/rna_main.c

index b4c68ffcb3dc6cbfb210ecc98a75a85063f5251d..143d59c4cff5587dbee1a08d04357f37ee86d192 100644 (file)
@@ -51,10 +51,13 @@ extern StructRNA RNA_Group;
 extern StructRNA RNA_ID;
 extern StructRNA RNA_IDProperty;
 extern StructRNA RNA_IDPropertyGroup;
+extern StructRNA RNA_Image;
+extern StructRNA RNA_ImageUser;
 extern StructRNA RNA_IntProperty;
 extern StructRNA RNA_JoystickSensor;
 extern StructRNA RNA_KeyboardSensor;
 extern StructRNA RNA_Lamp;
+extern StructRNA RNA_Lattice;
 extern StructRNA RNA_Library;
 extern StructRNA RNA_MCol;
 extern StructRNA RNA_MColLayer;
@@ -103,8 +106,6 @@ extern StructRNA RNA_TouchSensor;
 extern StructRNA RNA_UnknownType;
 extern StructRNA RNA_WindowManager;
 
-extern StructRNA RNA_Lattice;
-
 /* Pointer
  *
  * These functions will fill in RNA pointers, this can be done in three ways:
index 8e75fcdbd040b7b55b67083ec2069b05ae23ee7f..fd2cbd7c9960376cd100fd78376a4c86cdb578ef 100644 (file)
@@ -880,6 +880,7 @@ RNAProcessItem PROCESS_ITEMS[]= {
        {"rna_color.c", RNA_def_color},
        {"rna_controller.c", RNA_def_controller},
        {"rna_group.c", RNA_def_group},
+       {"rna_image.c", RNA_def_image},
        {"rna_lamp.c", RNA_def_lamp},
        {"rna_lattice.c", RNA_def_lattice},
        {"rna_main.c", RNA_def_main},
index cf0fe9e35abe55f3320861c3ea832ad6212bb227..2c294c4cc7b3adb4250edf46631ea1856e0f44bc 100644 (file)
@@ -60,6 +60,7 @@ static StructRNA *rna_ID_refine(PointerRNA *ptr)
        switch(GS(id->name)) {
                case ID_CA: return &RNA_Camera;
                case ID_GR: return &RNA_Group;
+               case ID_IM: return &RNA_Image;
                case ID_LA: return &RNA_Lamp;
                case ID_LI: return &RNA_Library;
                case ID_LT: return &RNA_Lattice;
diff --git a/source/blender/makesrna/intern/rna_image.c b/source/blender/makesrna/intern/rna_image.c
new file mode 100644 (file)
index 0000000..8166d0a
--- /dev/null
@@ -0,0 +1,230 @@
+/**
+ * $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): Brecht Van Lommel
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include <stdlib.h>
+
+#include "RNA_define.h"
+#include "RNA_types.h"
+
+#include "rna_internal.h"
+
+#include "DNA_image_types.h"
+#include "DNA_scene_types.h"
+
+#include "BKE_image.h"
+
+#ifdef RNA_RUNTIME
+
+#else
+
+static void rna_def_imageuser(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna= RNA_def_struct(brna, "ImageUser", NULL, "ImageUser");
+
+       prop= RNA_def_property(srna, "auto_refresh", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", IMA_ANIM_ALWAYS);
+       RNA_def_property_ui_text(prop, "Auto Refresh", "Always refresh image on frame changes.");
+
+       /* animation */
+       prop= RNA_def_property(srna, "cyclic", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "cycl", 0);
+       RNA_def_property_ui_text(prop, "Cyclic", "Cycle the images in the movie.");
+
+       prop= RNA_def_property(srna, "frames", PROP_INT, PROP_NONE);
+       RNA_def_property_range(prop, 0, MAXFRAMEF);
+       RNA_def_property_ui_text(prop, "Frames", "Sets the number of images of a movie to use.");
+
+       prop= RNA_def_property(srna, "offset", PROP_INT, PROP_NONE);
+       RNA_def_property_range(prop, -MAXFRAMEF, MAXFRAMEF);
+       RNA_def_property_ui_text(prop, "Offset", "Offsets the number of the frame to use in the animation.");
+
+       prop= RNA_def_property(srna, "start_frame", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "sfra");
+       RNA_def_property_range(prop, 1.0f, MAXFRAMEF);
+       RNA_def_property_ui_text(prop, "Start Frame", "Sets the global starting frame of the movie.");
+
+       prop= RNA_def_property(srna, "fields_per_frame", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "fie_ima");
+       RNA_def_property_range(prop, -MAXFRAMEF, MAXFRAMEF);
+       RNA_def_property_ui_text(prop, "Fields per Frame", "The number of fields per rendered frame (2 fields is 1 image).");
+
+       prop= RNA_def_property(srna, "layer", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* image_multi_cb */
+       RNA_def_property_ui_text(prop, "Layer", "Layer in multilayer image.");
+
+       prop= RNA_def_property(srna, "pass", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* image_multi_cb */
+       RNA_def_property_ui_text(prop, "Pass", "Pass in multilayer image.");
+}
+
+static void rna_def_image(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+       static const EnumPropertyItem prop_type_items[]= {
+               {IMA_TYPE_IMAGE, "IMAGE", "Image", ""},
+               {IMA_TYPE_MULTILAYER, "MULTILAYER", "Multilayer", ""},
+               {IMA_TYPE_UV_TEST, "UVTEST", "UV Test", ""},
+               //{IMA_TYPE_VERSE, "VERSE", "Verse", ""},
+               {IMA_TYPE_R_RESULT, "RENDERRESULT", "Render Result", ""},
+               {IMA_TYPE_COMPOSITE, "COMPOSITING", "Compositing", ""},
+               {0, NULL, NULL, NULL}};
+       static const EnumPropertyItem prop_source_items[]= {
+               {IMA_SRC_FILE, "FILE", "File", "Single image file"},
+               {IMA_SRC_SEQUENCE, "SEQUENCE", "Sequence", "Multiple image files, as a sequence"},
+               {IMA_SRC_MOVIE, "MOVIE", "Movie", "Movie file"},
+               {IMA_SRC_GENERATED, "GENERATED", "Generated", "Generated image"},
+               {IMA_SRC_VIEWER, "VIEWER", "Viewer", "Compositing node viewer"},
+               {0, NULL, NULL, NULL}};
+       static const EnumPropertyItem prop_generated_type_items[]= {
+               {0, "BLANK", "Blank", "Generate a blank image"},
+               {1, "UVTESTGRID", "UV Test Grid", "Generated grid to test UV mappings"},
+               {0, NULL, NULL, NULL}};
+       static const EnumPropertyItem prop_mapping_items[]= {
+               {0, "UV", "UV Coordinates", "Use UV coordinates for mapping the image"},
+               {IMA_REFLECT, "REFLECTION", "Reflection", "Use reflection mapping for mapping the image"},
+               {0, NULL, NULL, NULL}};
+
+       srna= RNA_def_struct(brna, "Image", "ID", "Image");
+
+       prop= RNA_def_property(srna, "filename", PROP_STRING, PROP_FILEPATH);
+       RNA_def_property_string_sdna(prop, NULL, "name");
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* imagechanged */
+       RNA_def_property_ui_text(prop, "Filename", "Image/Movie file name.");
+
+       prop= RNA_def_property(srna, "source", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_items(prop, prop_source_items);
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* imagechanged */
+       RNA_def_property_ui_text(prop, "Source", "Where the image comes from.");
+
+       prop= RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_items(prop, prop_type_items);
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* imagechanged */
+       RNA_def_property_ui_text(prop, "Type", "How to generate the image.");
+
+       prop= RNA_def_property(srna, "packed_file", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "packedfile");
+       RNA_def_property_struct_type(prop, "UnknownType");
+       RNA_def_property_ui_text(prop, "Packed File", "");
+
+       /* booleans */
+       prop= RNA_def_property(srna, "fields", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", IMA_FIELDS);
+       RNA_def_property_ui_text(prop, "Fields", "Use fields of the image.");
+
+       prop= RNA_def_property(srna, "odd_fields", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", IMA_STD_FIELD);
+       RNA_def_property_ui_text(prop, "Odd Fields", "Standard field toggle.");
+
+       prop= RNA_def_property(srna, "antialias", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", IMA_ANTIALI);
+       RNA_def_property_ui_text(prop, "Anti-alias", "Toggles image anti-aliasing, only works with solid colors");
+
+       prop= RNA_def_property(srna, "premultiply", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", IMA_DO_PREMUL);
+       RNA_def_property_ui_text(prop, "Premultiply", "Convert from key alpha to premultiplied alpha.");
+
+       /* generated image (image_generated_change_cb) */
+       prop= RNA_def_property(srna, "generated_type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "gen_type", 0);
+       RNA_def_property_enum_items(prop, prop_generated_type_items);
+       RNA_def_property_ui_text(prop, "Generated Type", "Generated image type.");
+
+       prop= RNA_def_property(srna, "generated_width", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "gen_x");
+       RNA_def_property_range(prop, 1, 5000);
+       RNA_def_property_ui_text(prop, "Generated Width", "Generated image width.");
+
+       prop= RNA_def_property(srna, "generated_height", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "gen_y");
+       RNA_def_property_range(prop, 1, 5000);
+       RNA_def_property_ui_text(prop, "Generated Height", "Generated image height.");
+
+       /* realtime properties */
+       prop= RNA_def_property(srna, "mapping", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "flag", PROP_DEF_ENUM_BITFLAGS);
+       RNA_def_property_enum_items(prop, prop_mapping_items);
+       RNA_def_property_ui_text(prop, "Mapping", "Mapping type to use for this image in the game engine.");
+
+       prop= RNA_def_property(srna, "display_aspect", PROP_FLOAT, PROP_VECTOR);
+       RNA_def_property_float_sdna(prop, NULL, "aspx");
+       RNA_def_property_array(prop, 2);
+       RNA_def_property_range(prop, 0.1f, 5000.0f);
+       RNA_def_property_ui_text(prop, "Display Aspect", "Display Aspect for this image, does not affect rendering.");
+
+       prop= RNA_def_property(srna, "animated", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* B_TWINANIM */
+       RNA_def_property_boolean_sdna(prop, NULL, "tpageflag", IMA_TWINANIM);
+       RNA_def_property_ui_text(prop, "Animated", "Use as animated texture in the game engine.");
+
+       prop= RNA_def_property(srna, "animation_start", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "twsta");
+       RNA_def_property_range(prop, 0, 128);
+       RNA_def_property_ui_text(prop, "Animation Start", "Start frame of an animated texture.");
+
+       prop= RNA_def_property(srna, "animation_end", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "twend");
+       RNA_def_property_range(prop, 0, 128);
+       RNA_def_property_ui_text(prop, "Animation End", "End frame of an animated texture.");
+
+       prop= RNA_def_property(srna, "animation_speed", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "animspeed");
+       RNA_def_property_range(prop, 1.0f, 100.0f);
+       RNA_def_property_ui_text(prop, "Animation Speed", "Speed of the animation in frames per second.");
+
+       prop= RNA_def_property(srna, "tiles", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE); /* B_SIMAGETILE */
+       RNA_def_property_boolean_sdna(prop, NULL, "tpageflag", IMA_TILES);
+       RNA_def_property_ui_text(prop, "Tiles", "Use of tilemode for faces (default shift-LMB to pick the tile for selected faces).");
+
+       prop= RNA_def_property(srna, "tiles_x", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "xrep");
+       RNA_def_property_range(prop, 1, 16);
+       RNA_def_property_ui_text(prop, "Tiles X", "Degree of repetition in the X direction.");
+
+       prop= RNA_def_property(srna, "tiles_y", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "yrep");
+       RNA_def_property_range(prop, 1, 16);
+       RNA_def_property_ui_text(prop, "Tiles Y", "Degree of repetition in the Y direction.");
+
+       prop= RNA_def_property(srna, "clamp_x", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "tpageflag", IMA_CLAMP_U);
+       RNA_def_property_ui_text(prop, "Clamp X", "Disable texture repeating horizontally.");
+
+       prop= RNA_def_property(srna, "clamp_y", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "tpageflag", IMA_CLAMP_V);
+       RNA_def_property_ui_text(prop, "Clamp y", "Disable texture repeating vertically.");
+}
+
+void RNA_def_image(BlenderRNA *brna)
+{
+       rna_def_image(brna);
+       rna_def_imageuser(brna);
+}
+
+#endif
+
index eaaa15d2109c692b005c59dd3f7cd52731ce7397..6a0a18d567226c33cc6dfcdaac4de41af0640fe0 100644 (file)
@@ -85,7 +85,9 @@ void RNA_def_camera(struct BlenderRNA *brna);
 void RNA_def_color(struct BlenderRNA *brna);
 void RNA_def_controller(struct BlenderRNA *brna);
 void RNA_def_group(struct BlenderRNA *brna);
+void RNA_def_image(struct BlenderRNA *brna);
 void RNA_def_lamp(struct BlenderRNA *brna);
+void RNA_def_lattice(struct BlenderRNA *brna);
 void RNA_def_main(struct BlenderRNA *brna);
 void RNA_def_material(struct BlenderRNA *brna);
 void RNA_def_mesh(struct BlenderRNA *brna);
@@ -97,7 +99,6 @@ void RNA_def_scene(struct BlenderRNA *brna);
 void RNA_def_screen(struct BlenderRNA *brna);
 void RNA_def_sensor(struct BlenderRNA *brna);
 void RNA_def_wm(struct BlenderRNA *brna);
-void RNA_def_lattice(struct BlenderRNA *brna);
 
 /* ID Properties */
 
index 6eeb7a875d0bc1f9ef88ec330f3e23c836645222..fe13409cee68bd794abccc53580398ad9cd1d817 100644 (file)
@@ -231,11 +231,11 @@ void RNA_def_main(BlenderRNA *brna)
                {"libraries", "Library", "rna_Main_library_begin", "Libraries", "Library datablocks."},
                {"screens", "Screen", "rna_Main_screen_begin", "Screens", "Screen datablocks."},
                {"windowmanagers", "WindowManager", "rna_Main_wm_begin", "Window Managers", "Window manager datablocks."},
+               {"images", "Image", "rna_Main_image_begin", "Images", "Image datablocks."},
+               {"lattices", "Lattice", "rna_Main_latt_begin", "Lattices", "Lattice datablocks."},
                {"curves", "ID", "rna_Main_curve_begin", "Curves", "Curve datablocks."}, 
                {"metaballs", "ID", "rna_Main_mball_begin", "Metaballs", "Metaball datablocks."},
                {"textures", "ID", "rna_Main_tex_begin", "Textures", "Texture datablocks."},
-               {"images", "ID", "rna_Main_image_begin", "Images", "Image datablocks."},
-               {"lattices", "ID", "rna_Main_latt_begin", "Lattices", "Lattice datablocks."},
                {"ipos", "ID", "rna_Main_ipo_begin", "Ipos", "Ipo datablocks."},
                {"keys", "ID", "rna_Main_key_begin", "Keys", "Key datablocks."},
                {"worlds", "ID", "rna_Main_world_begin", "Worlds", "World datablocks."},