Revision: 18297
          
http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=18297
Author:   nicholasbishop
Date:     2009-01-03 21:20:09 +0100 (Sat, 03 Jan 2009)

Log Message:
-----------
Added some sub-structs to Material RNA for halo and ray transp/mirror 
settings. Material RNA shows much cleaner in the RNA viewer now.

Modified Paths:
--------------
    branches/blender2.5/blender/source/blender/makesrna/RNA_access.h
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_material.c

Modified: branches/blender2.5/blender/source/blender/makesrna/RNA_access.h
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/RNA_access.h    
2009-01-03 20:12:12 UTC (rev 18296)
+++ branches/blender2.5/blender/source/blender/makesrna/RNA_access.h    
2009-01-03 20:20:09 UTC (rev 18297)
@@ -126,6 +126,9 @@
 extern StructRNA RNA_Main;
 extern StructRNA RNA_MaskModifier;
 extern StructRNA RNA_Material;
+extern StructRNA RNA_MaterialHalo;
+extern StructRNA RNA_MaterialRaytraceMirror;
+extern StructRNA RNA_MaterialRaytraceTransparency;
 extern StructRNA RNA_Mesh;
 extern StructRNA RNA_MeshDeformModifier;
 extern StructRNA RNA_MeshEdge;

Modified: 
branches/blender2.5/blender/source/blender/makesrna/intern/rna_material.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_material.c   
2009-01-03 20:12:12 UTC (rev 18296)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_material.c   
2009-01-03 20:20:09 UTC (rev 18297)
@@ -36,6 +36,21 @@
 
 #ifdef RNA_RUNTIME
 
+static void *rna_Material_raytrace_mirror_get(PointerRNA *ptr)
+{
+       return ptr->id.data;
+}
+
+static void *rna_Material_raytrace_transparency_get(PointerRNA *ptr)
+{
+       return ptr->id.data;
+}
+
+static void *rna_Material_halo_get(PointerRNA *ptr)
+{
+       return ptr->id.data;
+}
+
 static void rna_Material_mode_halo_set(PointerRNA *ptr, int value)
 {
        Material *mat= (Material*)ptr->data;
@@ -139,12 +154,24 @@
        RNA_def_property_update(prop, NC_MATERIAL|ND_SHADING, NULL);
 }
 
-static void rna_def_material_raymirror(StructRNA *srna, PropertyRNA *prop)
+static void rna_def_material_raymirror(BlenderRNA *brna, StructRNA *parent)
 {
+       StructRNA *srna;
+       PropertyRNA *prop;
+
        static EnumPropertyItem prop_fadeto_mir_items[] = {
                {MA_RAYMIR_FADETOSKY, "RAYMIR_FADETOSKY", "Fade to sky color", 
""},
                {MA_RAYMIR_FADETOMAT, "RAYMIR_FADETOMAT", "Fade to material 
color", ""},
                {0, NULL, NULL, NULL}};
+
+       srna= RNA_def_struct(brna, "MaterialRaytraceMirror", NULL);
+       RNA_def_struct_sdna(srna, "Material");
+       RNA_def_struct_ui_text(srna, "Raytrace Mirror", "");
+
+       prop= RNA_def_property(parent, "raytrace_mirror", PROP_POINTER, 
PROP_NONE);
+       RNA_def_property_struct_type(prop, "MaterialRaytraceMirror");
+       RNA_def_property_pointer_funcs(prop, 
"rna_Material_raytrace_mirror_get", NULL, NULL);
+       RNA_def_property_ui_text(prop, "Raytrace Mirror", "");
        
        prop= RNA_def_property(srna, "mode_ray_mirror", PROP_BOOLEAN, 
PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", MA_RAYMIRROR); /* use 
bitflags */
@@ -211,8 +238,20 @@
        RNA_def_property_update(prop, NC_MATERIAL|ND_SHADING, NULL);
 }
 
-static void rna_def_material_raytra(StructRNA *srna, PropertyRNA *prop)
+static void rna_def_material_raytra(BlenderRNA *brna, StructRNA *parent)
 {
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna= RNA_def_struct(brna, "MaterialRaytraceTransparency", NULL);
+       RNA_def_struct_sdna(srna, "Material");
+       RNA_def_struct_ui_text(srna, "Raytrace Transparency", "");
+
+       prop= RNA_def_property(parent, "raytrace_transparency", PROP_POINTER, 
PROP_NONE);
+       RNA_def_property_struct_type(prop, "MaterialRaytraceTransparency");
+       RNA_def_property_pointer_funcs(prop, 
"rna_Material_raytrace_transparency_get", NULL, NULL);
+       RNA_def_property_ui_text(prop, "Raytrace Transparency", "");
+
        prop= RNA_def_property(srna, "mode_ray_transparency", PROP_BOOLEAN, 
PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", MA_RAYTRANSP); /* use 
bitflags */
        RNA_def_property_ui_text(prop, "Ray Transparency Mode", "Enables 
raytracing for transparent refraction rendering.");
@@ -285,8 +324,20 @@
        RNA_def_property_update(prop, NC_MATERIAL|ND_SHADING, NULL);
 }
 
-static void rna_def_material_halo(StructRNA *srna, PropertyRNA *prop)
+static void rna_def_material_halo(BlenderRNA *brna, StructRNA *parent)
 {
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna= RNA_def_struct(brna, "MaterialHalo", NULL);
+       RNA_def_struct_sdna(srna, "Material");
+       RNA_def_struct_ui_text(srna, "Halo", "");
+
+       prop= RNA_def_property(parent, "halo", PROP_POINTER, PROP_NONE);
+       RNA_def_property_struct_type(prop, "MaterialHalo");
+       RNA_def_property_pointer_funcs(prop, "rna_Material_halo_get", NULL, 
NULL);
+       RNA_def_property_ui_text(prop, "Halo", "");
+
        prop= RNA_def_property(srna, "mode_halo", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", MA_HALO); /* use 
bitflags */
        RNA_def_property_ui_text(prop, "Halo Mode", "Enables halo rendering of 
material.");
@@ -430,11 +481,11 @@
        /* diffuse shaders */
        rna_def_material_diffuse(srna, prop);
        /* raytrace mirror */
-       rna_def_material_raymirror(srna, prop);
+       rna_def_material_raymirror(brna, srna);
        /* raytrace transparency */
-       rna_def_material_raytra(srna, prop);
+       rna_def_material_raytra(brna, srna);
        /* Halo settings */
-       rna_def_material_halo(srna, prop);
+       rna_def_material_halo(brna, srna);
        
        /* nodetree */
        prop= RNA_def_property(srna, "nodetree", PROP_POINTER, PROP_NONE);


_______________________________________________
Bf-blender-cvs mailing list
Bf-blender-cvs@blender.org
http://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to