diff options
author | Brecht Van Lommel <brechtvanlommel@pandora.be> | 2008-11-30 21:39:49 +0300 |
---|---|---|
committer | Brecht Van Lommel <brechtvanlommel@pandora.be> | 2008-11-30 21:39:49 +0300 |
commit | 9cb9bf7da311ca22b62efdee63ca4c0e76371f1a (patch) | |
tree | 86bcb2dcca44c768e12dfad16361195a2dd051bb /source/blender/makesrna | |
parent | a141e44e55a95ce698f0abc23e247f03b420371a (diff) |
RNA:
* DNA_image_types.h done, except for some properties not being editable.
Diffstat (limited to 'source/blender/makesrna')
-rw-r--r-- | source/blender/makesrna/RNA_access.h | 5 | ||||
-rw-r--r-- | source/blender/makesrna/intern/makesrna.c | 1 | ||||
-rw-r--r-- | source/blender/makesrna/intern/rna_ID.c | 1 | ||||
-rw-r--r-- | source/blender/makesrna/intern/rna_image.c | 230 | ||||
-rw-r--r-- | source/blender/makesrna/intern/rna_internal.h | 3 | ||||
-rw-r--r-- | source/blender/makesrna/intern/rna_main.c | 4 |
6 files changed, 239 insertions, 5 deletions
diff --git a/source/blender/makesrna/RNA_access.h b/source/blender/makesrna/RNA_access.h index b4c68ffcb3d..143d59c4cff 100644 --- a/source/blender/makesrna/RNA_access.h +++ b/source/blender/makesrna/RNA_access.h @@ -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: diff --git a/source/blender/makesrna/intern/makesrna.c b/source/blender/makesrna/intern/makesrna.c index 8e75fcdbd04..fd2cbd7c996 100644 --- a/source/blender/makesrna/intern/makesrna.c +++ b/source/blender/makesrna/intern/makesrna.c @@ -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}, diff --git a/source/blender/makesrna/intern/rna_ID.c b/source/blender/makesrna/intern/rna_ID.c index cf0fe9e35ab..2c294c4cc7b 100644 --- a/source/blender/makesrna/intern/rna_ID.c +++ b/source/blender/makesrna/intern/rna_ID.c @@ -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 index 00000000000..8166d0aa11e --- /dev/null +++ b/source/blender/makesrna/intern/rna_image.c @@ -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 + diff --git a/source/blender/makesrna/intern/rna_internal.h b/source/blender/makesrna/intern/rna_internal.h index eaaa15d2109..6a0a18d5672 100644 --- a/source/blender/makesrna/intern/rna_internal.h +++ b/source/blender/makesrna/intern/rna_internal.h @@ -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 */ diff --git a/source/blender/makesrna/intern/rna_main.c b/source/blender/makesrna/intern/rna_main.c index 6eeb7a875d0..fe13409cee6 100644 --- a/source/blender/makesrna/intern/rna_main.c +++ b/source/blender/makesrna/intern/rna_main.c @@ -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."}, |