[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [58725] trunk/blender/source/blender/ collada: Added Scene scale calculator to UnitConverter for future usage ( wip)

Gaia Clary gaia.clary at machinimatrix.org
Mon Jul 29 23:23:00 CEST 2013


Revision: 58725
          http://projects.blender.org/scm/viewvc.php?view=rev&root=bf-blender&revision=58725
Author:   gaiaclary
Date:     2013-07-29 21:22:59 +0000 (Mon, 29 Jul 2013)
Log Message:
-----------
Added Scene scale calculator to UnitConverter for future usage (wip)

Modified Paths:
--------------
    trunk/blender/source/blender/collada/collada_internal.cpp
    trunk/blender/source/blender/collada/collada_internal.h

Modified: trunk/blender/source/blender/collada/collada_internal.cpp
===================================================================
--- trunk/blender/source/blender/collada/collada_internal.cpp	2013-07-29 20:28:18 UTC (rev 58724)
+++ trunk/blender/source/blender/collada/collada_internal.cpp	2013-07-29 21:22:59 UTC (rev 58725)
@@ -27,7 +27,7 @@
 
 /* COLLADABU_ASSERT, may be able to remove later */
 #include "COLLADABUPlatform.h"
-#include "collada_internal.h"
+#include "collada_utils.h"
 
 #include "BLI_linklist.h"
 
@@ -40,7 +40,7 @@
 	rotate_m4(y_up_mat4, 'X', 0.5 * M_PI);
 
 	unit_m4(z_up_mat4);
-
+	unit_m4(size_mat4);
 }
 
 void UnitConverter::read_asset(const COLLADAFW::FileInfo *asset)
@@ -124,6 +124,51 @@
 	}
 }
 
+
+float(&UnitConverter::get_scale())[4][4]
+{
+	return size_mat4;
+}
+
+void UnitConverter::calculate_scale(Scene &sce)
+{
+	PointerRNA scene_ptr, unit_settings;
+	PropertyRNA *system_ptr, *scale_ptr;
+	RNA_id_pointer_create(&sce.id, &scene_ptr);
+
+	unit_settings = RNA_pointer_get(&scene_ptr, "unit_settings");
+	system_ptr    = RNA_struct_find_property(&unit_settings, "system");
+	scale_ptr     = RNA_struct_find_property(&unit_settings, "scale_length");
+
+	int   type    = RNA_property_enum_get(&unit_settings, system_ptr);
+
+	float bl_scale;
+
+	switch (type) {
+		case USER_UNIT_NONE:
+			bl_scale = 1.0; // map 1 Blender unit to 1 Meter
+			break;
+
+		case USER_UNIT_METRIC:
+			bl_scale = RNA_property_float_get(&unit_settings, scale_ptr);
+			break;
+
+		default :
+			bl_scale = RNA_property_float_get(&unit_settings, scale_ptr);
+			// it looks like the conversion to Imperial is done implicitly.
+			// So nothing to do here.
+			break;
+	}
+
+	float axis_mat4[4][4];
+	unit_m4(axis_mat4);
+
+	float rescale[3];
+	rescale[0] = rescale[1] = rescale[2] = getLinearMeter() / bl_scale;
+
+	size_to_mat4(size_mat4, rescale);
+}
+
 void TransformBase::decompose(float mat[4][4], float *loc, float eul[3], float quat[4], float *size)
 {
 	mat4_to_size(size, mat);

Modified: trunk/blender/source/blender/collada/collada_internal.h
===================================================================
--- trunk/blender/source/blender/collada/collada_internal.h	2013-07-29 20:28:18 UTC (rev 58724)
+++ trunk/blender/source/blender/collada/collada_internal.h	2013-07-29 21:22:59 UTC (rev 58725)
@@ -50,7 +50,8 @@
 	float x_up_mat4[4][4];
 	float y_up_mat4[4][4];
 	float z_up_mat4[4][4];
-
+	float size_mat4[4][4];
+	
 public:
 
 	enum UnitSystem {
@@ -79,8 +80,9 @@
 	void mat4_to_dae_double(double out[4][4], float in[4][4]);
 
 	float(&get_rotation())[4][4];
+	float(&get_scale())[4][4];
+	void calculate_scale(Scene &sce);
 
-
 };
 
 class TransformBase




More information about the Bf-blender-cvs mailing list