RNA: brush wrapping
authorJuho Vepsalainen <bebraw@gmail.com>
Mon, 1 Dec 2008 06:52:18 +0000 (06:52 +0000)
committerJuho Vepsalainen <bebraw@gmail.com>
Mon, 1 Dec 2008 06:52:18 +0000 (06:52 +0000)
Wrapped most of brush. Brush is still missing a link to texture and to
BrushClone. Also PAINT_TOOL_DRAW etc. flags found on DNA_brush_types.h
need to be associated to a brush somehow. Currently they are linked
to a brush via ImagePaintSettings.

Also changed identifiers in metaball wrapping to conform with the
standards.

source/blender/makesrna/RNA_access.h
source/blender/makesrna/intern/makesrna.c
source/blender/makesrna/intern/rna_ID.c
source/blender/makesrna/intern/rna_brush.c [new file with mode: 0755]
source/blender/makesrna/intern/rna_internal.h
source/blender/makesrna/intern/rna_meta.c

index 43c66b2f2fb23c42cb7435d77f91393589f7336c..bdd469f1b98c647ce3061d3b6766247536464a9c 100644 (file)
@@ -38,6 +38,8 @@ extern BlenderRNA BLENDER_RNA;
 extern StructRNA RNA_Actuator;
 extern StructRNA RNA_ActuatorSensor;
 extern StructRNA RNA_BooleanProperty;
+extern StructRNA RNA_Brush;
+extern StructRNA RNA_BrushClone;
 extern StructRNA RNA_Camera;
 extern StructRNA RNA_CollectionProperty;
 extern StructRNA RNA_CollisionSensor;
index 3b2957e386bcc99ead71cb7c6d5a587426084859..76b6307156f3183f1066b2eabf589d66b68be60a 100644 (file)
@@ -877,6 +877,8 @@ typedef struct RNAProcessItem {
 RNAProcessItem PROCESS_ITEMS[]= {
        {"rna_ID.c", RNA_def_ID},
        {"rna_actuator.c", RNA_def_actuator},
+       {"rna_brush.c", RNA_def_brush},
+       {"rna_brush.c", RNA_def_brushclone},
        {"rna_camera.c", RNA_def_camera},
        {"rna_color.c", RNA_def_color},
        {"rna_controller.c", RNA_def_controller},
index 13577e62cfe91354f5f7835546e4f276b8f3da79..050995435ef6a978ab6701ce16031a6b1d266a21 100644 (file)
@@ -58,6 +58,7 @@ static StructRNA *rna_ID_refine(PointerRNA *ptr)
        ID *id= (ID*)ptr->data;
 
        switch(GS(id->name)) {
+               case ID_BR: return &RNA_Brush;
                case ID_CA: return &RNA_Camera;
                case ID_GR: return &RNA_Group;
                case ID_IM: return &RNA_Image;
diff --git a/source/blender/makesrna/intern/rna_brush.c b/source/blender/makesrna/intern/rna_brush.c
new file mode 100755 (executable)
index 0000000..d241269
--- /dev/null
@@ -0,0 +1,161 @@
+/**
+ * $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), Juho Vepsäläinen
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include <stdlib.h>
+
+#include "RNA_define.h"
+#include "RNA_types.h"
+
+#include "rna_internal.h"
+
+#include "DNA_brush_types.h"
+
+#ifdef RNA_RUNTIME
+
+#else
+
+void RNA_def_brushclone(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna= RNA_def_struct(brna, "BrushClone", "ID", "BrushClone");
+       
+       /* pointers */
+       prop= RNA_def_property(srna, "image", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "image");
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE);
+       RNA_def_property_ui_text(prop, "Image", "Image for clone tool.");
+       
+       /* Number values */
+       /* NOTE: This did not appear to be exposed in the 2.48a user interface. */
+       /*
+       prop= RNA_def_property(srna, "offset", PROP_FLOAT, PROP_COLOR);
+       RNA_def_property_float_sdna(prop, NULL, "offset");
+       RNA_def_property_array(prop, 2);
+       RNA_def_property_ui_text(prop, "Offset", "");
+       RNA_def_property_ui_range(prop, 0.0f , 1.0f, 10.0f, 3.0f);
+       */
+       
+       prop= RNA_def_property(srna, "opacity", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "alpha");
+       RNA_def_property_range(prop, 0.0f, 1.0f);
+       RNA_def_property_ui_text(prop, "Opacity", "The amount of opacity of the clone image.");
+}
+
+void RNA_def_brush(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+       static EnumPropertyItem prop_blend_items[] = {
+               {BRUSH_BLEND_MIX, "MIX", "Mix", "Use mix blending mode while painting."},
+               {BRUSH_BLEND_ADD, "ADD", "Add", "Use add blending mode while painting."},
+               {BRUSH_BLEND_SUB, "SUB", "Subtract", "Use subtract blending mode while painting."},
+               {BRUSH_BLEND_MUL, "MUL", "Multiply", "Use multiply blending mode while painting."},
+               {BRUSH_BLEND_LIGHTEN, "LIGHTEN", "Lighten", "Use lighten blending mode while painting."},
+               {BRUSH_BLEND_DARKEN, "DARKEN", "Darken", "Use darken blending mode while painting."},
+               {BRUSH_BLEND_ERASE_ALPHA, "ERASE_ALPHA", "Erase Alpha", "Erase alpha while painting."},
+               {BRUSH_BLEND_ADD_ALPHA, "ADD_ALPHA", "Add Alpha", "Add alpha while painting."},
+               {0, NULL, NULL, NULL}};
+       
+       srna= RNA_def_struct(brna, "Brush", "ID", "Brush");
+       
+       /* Enums */
+       prop= RNA_def_property(srna, "blend", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_items(prop, prop_blend_items);
+       RNA_def_property_ui_text(prop, "Blending mode", "Brush blending mode.");
+       
+       /* Number values */
+       prop= RNA_def_property(srna, "brush_diameter", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "size");
+       RNA_def_property_range(prop, 1, 200);
+       RNA_def_property_ui_text(prop, "Brush diameter", "Diameter of the brush.");
+       
+       prop= RNA_def_property(srna, "falloff", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "innerradius");
+       RNA_def_property_range(prop, 0.0f, 1.0f);
+       RNA_def_property_ui_text(prop, "Falloff", "Falloff radius of the brush");
+       
+       prop= RNA_def_property(srna, "spacing", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "spacing");
+       RNA_def_property_range(prop, 1.0f, 100.0f);
+       RNA_def_property_ui_text(prop, "Spacing", "Spacing between brush stamps.");
+       
+       prop= RNA_def_property(srna, "rate", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "rate");
+       RNA_def_property_range(prop, 0.010f, 1.0f);
+       RNA_def_property_ui_text(prop, "Rate", "Number of paints per second for Airbrush.");
+       
+       prop= RNA_def_property(srna, "color", PROP_FLOAT, PROP_COLOR);
+       RNA_def_property_float_sdna(prop, NULL, "rgb");
+       RNA_def_property_array(prop, 3);
+       RNA_def_property_ui_text(prop, "Color", "");
+       RNA_def_property_ui_range(prop, 0.0f , 1.0f, 10.0f, 3.0f);
+       
+       prop= RNA_def_property(srna, "opacity", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "alpha");
+       RNA_def_property_range(prop, 0.0f, 1.0f);
+       RNA_def_property_ui_text(prop, "Opacity", "The amount of pressure on the brush.");
+       
+       /* pointers */
+       /* XXX: figure out how to link to tex (texact?) */      
+       
+       /*
+       prop= RNA_def_property(srna, "clone", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "clone");
+       RNA_def_property_flag(prop, PROP_NOT_EDITABLE);
+       RNA_def_property_ui_text(prop, "Clone", "Clone tool linked to the brush.");
+       */
+       
+       /* flag */
+       prop= RNA_def_property(srna, "airbrush", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BRUSH_AIRBRUSH);
+       RNA_def_property_ui_text(prop, "Airbrush", "Set brush into airbrush mode.");
+       
+       prop= RNA_def_property(srna, "torus", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BRUSH_TORUS);
+       RNA_def_property_ui_text(prop, "Torus", "Set brush into torus mapping mode.");
+       
+       prop= RNA_def_property(srna, "alpha_pressure", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BRUSH_ALPHA_PRESSURE);
+       RNA_def_property_ui_text(prop, "Opacity Pressure", "Set pressure sensitivity for opacity.");
+       
+       prop= RNA_def_property(srna, "size_pressure", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BRUSH_SIZE_PRESSURE);
+       RNA_def_property_ui_text(prop, "Size Pressure", "Set pressure sensitivity for size.");
+       
+       prop= RNA_def_property(srna, "falloff_pressure", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BRUSH_RAD_PRESSURE);
+       RNA_def_property_ui_text(prop, "Falloff Pressure", "Set pressure sensitivity for falloff.");
+       
+       prop= RNA_def_property(srna, "spacing_pressure", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BRUSH_SPACING_PRESSURE);
+       RNA_def_property_ui_text(prop, "Spacing Pressure", "Set pressure sensitivity for spacing.");
+       
+       prop= RNA_def_property(srna, "fixed_tex", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BRUSH_FIXED_TEX);
+       RNA_def_property_ui_text(prop, "Fixed Texture", "Keep texture origin in fixed position.");
+}
+
+#endif
index cca5a5ec492a54c7370a662595847909ac23e159..71aad3caeb3473980af1f9f1f9e4c7cd2a9e8c71 100644 (file)
@@ -82,6 +82,8 @@ extern BlenderRNA BLENDER_RNA;
 
 void RNA_def_ID(struct BlenderRNA *brna);
 void RNA_def_actuator(struct BlenderRNA *brna);
+void RNA_def_brush(struct BlenderRNA *brna);
+void RNA_def_brushclone(struct BlenderRNA *brna);
 void RNA_def_camera(struct BlenderRNA *brna);
 void RNA_def_color(struct BlenderRNA *brna);
 void RNA_def_controller(struct BlenderRNA *brna);
index 5c6e6c16fe93b39e2b5d569f917ea0157fd5a228..d37df339713abf05434362c1bfe6466d3131852b 100755 (executable)
@@ -108,17 +108,17 @@ void RNA_def_metaball(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Update", "Metaball edit update option.");
        
        /* Number values */
-       prop= RNA_def_property(srna, "Wiresize", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "wiresize", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "wiresize");
        RNA_def_property_range(prop, 0.050f, 1.0f);
        RNA_def_property_ui_text(prop, "Wiresize", "Polygonization resolution in the 3D viewport.");
        
-       prop= RNA_def_property(srna, "Rendersize", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "rendersize", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "rendersize");
        RNA_def_property_range(prop, 0.050f, 1.0f);
        RNA_def_property_ui_text(prop, "Rendersize", "Polygonization resolution in rendering.");
        
-       prop= RNA_def_property(srna, "Threshold", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "threshold", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "thresh");
        RNA_def_property_range(prop, 0.0f, 5.0f);
        RNA_def_property_ui_text(prop, "Threshold", "Influence of metaelements.");