Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Genrich <daniel.genrich@gmx.net>2012-07-25 03:49:50 +0400
committerDaniel Genrich <daniel.genrich@gmx.net>2012-07-25 03:49:50 +0400
commite9d3a54a4069ec2c59b9ed31ef2b2af2da94f94d (patch)
tree41d7e65ae3d17045947a486b9566eb47c748a21b
parent7f793b35b2c3a49d5a3ee617b2a5417022157aa0 (diff)
Smoke + Cycles:
- Reorganize code a bit - Use RNA function to directly copy density over TODO: - Fix scons to include blender_smoke.cpp - "use_volume": Need flags to differ between "no density found" (can happen at frame 1) and "not a volume" (objects which have nothing to do with volume). - Actually render something - handle rendering (ignoring) of Smoke Domain + Flow
-rw-r--r--intern/cycles/blender/CMakeLists.txt1
-rw-r--r--intern/cycles/blender/blender_object.cpp28
-rw-r--r--intern/cycles/blender/blender_smoke.cpp100
-rw-r--r--intern/cycles/blender/blender_sync.h1
-rw-r--r--intern/cycles/blender/blender_util.h8
-rw-r--r--intern/cycles/render/object.h2
-rw-r--r--source/blender/makesrna/intern/rna_smoke.c4
7 files changed, 116 insertions, 28 deletions
diff --git a/intern/cycles/blender/CMakeLists.txt b/intern/cycles/blender/CMakeLists.txt
index a8c7eef89fa..6e77daf6f8d 100644
--- a/intern/cycles/blender/CMakeLists.txt
+++ b/intern/cycles/blender/CMakeLists.txt
@@ -23,6 +23,7 @@ set(SRC
blender_mesh.cpp
blender_object.cpp
blender_particles.cpp
+ blender_smoke.cpp
blender_python.cpp
blender_session.cpp
blender_shader.cpp
diff --git a/intern/cycles/blender/blender_object.cpp b/intern/cycles/blender/blender_object.cpp
index 2a34da078ea..f3184ca0989 100644
--- a/intern/cycles/blender/blender_object.cpp
+++ b/intern/cycles/blender/blender_object.cpp
@@ -53,26 +53,6 @@ bool BlenderSync::BKE_object_is_modified(BL::Object b_ob)
return false;
}
-/* Only looking for Smoke domains */
-// TODO DG: disable rendering of smoke flow??
-bool BlenderSync::BKE_modifiers_isSmokeEnabled(BL::Object b_ob)
-{
- BL::Object::modifiers_iterator b_modifiers;
- for(b_ob.modifiers.begin(b_modifiers); b_modifiers != b_ob.modifiers.end(); ++b_modifiers) {
- BL::Modifier mod = (*b_modifiers);
-
- if (mod.is_a(&RNA_SmokeModifier)) {
- BL::SmokeModifier smd(mod);
-
- if(smd.smoke_type() == BL::SmokeModifier::smoke_type_DOMAIN) {
- return true;
- }
- }
- }
-
- return false;
-}
-
bool BlenderSync::object_is_mesh(BL::Object b_ob)
{
BL::ID b_ob_data = b_ob.data();
@@ -262,11 +242,6 @@ void BlenderSync::sync_object(BL::Object b_parent, int b_index, BL::Object b_ob,
/* mesh sync */
object->mesh = sync_mesh(b_ob, object_updated);
- if(BKE_modifiers_isSmokeEnabled(b_ob))
- {
- // TODO DG sync_volume(b_ob);
- }
-
if(use_holdout != object->use_holdout) {
object->use_holdout = use_holdout;
scene->object_manager->tag_update(scene);
@@ -302,6 +277,9 @@ void BlenderSync::sync_object(BL::Object b_parent, int b_index, BL::Object b_ob,
/* particle sync */
if (object_use_particles(b_ob))
sync_particles(object, b_ob);
+
+ // if(BKE_modifiers_isSmokeEnabled(b_ob))
+ // sync_smoke(object, b_ob);
object->tag_update(scene);
}
diff --git a/intern/cycles/blender/blender_smoke.cpp b/intern/cycles/blender/blender_smoke.cpp
new file mode 100644
index 00000000000..61e6282771f
--- /dev/null
+++ b/intern/cycles/blender/blender_smoke.cpp
@@ -0,0 +1,100 @@
+/*
+ * Copyright 2011, Blender Foundation.
+ *
+ * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ */
+
+#include "object.h"
+
+#include "mesh.h"
+#include "blender_sync.h"
+#include "blender_util.h"
+
+#include "util_foreach.h"
+
+CCL_NAMESPACE_BEGIN
+
+/* Utilities */
+
+
+/* Smoke Sync */
+
+/* Only looking for Smoke domains */
+// TODO DG: disable rendering of smoke flow??
+bool BlenderSync::BKE_modifiers_isSmokeEnabled(BL::Object b_ob)
+{
+ BL::Object::modifiers_iterator b_modifiers;
+ for(b_ob.modifiers.begin(b_modifiers); b_modifiers != b_ob.modifiers.end(); ++b_modifiers) {
+ BL::Modifier mod = (*b_modifiers);
+
+ if (mod.is_a(&RNA_SmokeModifier)) {
+ BL::SmokeModifier smd(mod);
+
+ if(smd.smoke_type() == BL::SmokeModifier::smoke_type_DOMAIN) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+}
+
+static BL::SmokeModifier *get_smoke(BL::Object b_ob)
+{
+ BL::Object::modifiers_iterator b_modifiers;
+ for(b_ob.modifiers.begin(b_modifiers); b_modifiers != b_ob.modifiers.end(); ++b_modifiers) {
+ BL::Modifier mod = (*b_modifiers);
+
+ if (mod.is_a(&RNA_SmokeModifier)) {
+ BL::SmokeModifier *smd = (BL::SmokeModifier *)(&mod);
+
+ if(smd->smoke_type() == BL::SmokeModifier::smoke_type_DOMAIN) {
+ return smd;
+ }
+ }
+ }
+
+ return NULL;
+}
+
+void BlenderSync::sync_smoke(Object *ob, BL::Object b_ob)
+{
+ BL::SmokeModifier *smd = get_smoke(b_ob);
+ BL::SmokeDomainSettings sds = smd->domain_settings();
+
+ ob->resolution = get_int3(sds.domain_resolution());
+
+ // int rna_SmokeModifier_density_get_length(PointerRNA *ptr, int length[RNA_MAX_ARRAY_DIMENSION]);
+ // void rna_SmokeModifier_density_get(PointerRNA *ptr, float *values);
+
+ int length[3];
+ int numcells = rna_SmokeModifier_density_get_length(&sds.ptr, length);
+
+ ob->grid.clear();
+
+ if(numcells == 0)
+ ob->use_volume = false; // still needs to be rendered transparent!
+ else
+ {
+ ob->use_volume = true;
+
+ vector<float> &grid = ob->grid;
+ grid.reserve(numcells);
+ grid.resize(numcells);
+ rna_SmokeModifier_density_get(&sds.ptr, &grid[0]);
+ }
+}
+
+CCL_NAMESPACE_END
diff --git a/intern/cycles/blender/blender_sync.h b/intern/cycles/blender/blender_sync.h
index b614fca6363..0ecd60c4dc0 100644
--- a/intern/cycles/blender/blender_sync.h
+++ b/intern/cycles/blender/blender_sync.h
@@ -86,6 +86,7 @@ private:
void sync_mesh_motion(BL::Object b_ob, Mesh *mesh, int motion);
void sync_camera_motion(BL::Object b_ob, int motion);
void sync_particles(Object *ob, BL::Object b_ob);
+ void sync_smoke(Object *ob, BL::Object b_ob);
/* util */
void find_shader(BL::ID id, vector<uint>& used_shaders, int default_shader);
diff --git a/intern/cycles/blender/blender_util.h b/intern/cycles/blender/blender_util.h
index ebbd4e1221c..3639d85c03a 100644
--- a/intern/cycles/blender/blender_util.h
+++ b/intern/cycles/blender/blender_util.h
@@ -56,6 +56,9 @@ void rna_Scene_frame_set(void *scene, int frame, float subframe);
void BKE_image_user_frame_calc(void *iuser, int cfra, int fieldnr);
void BKE_image_user_file_path(void *iuser, void *ima, char *path);
+int rna_SmokeModifier_density_get_length(PointerRNA *ptr, int length[3]);
+void rna_SmokeModifier_density_get(PointerRNA *ptr, float *values);
+
}
CCL_NAMESPACE_BEGIN
@@ -155,6 +158,11 @@ static inline int4 get_int4(BL::Array<int, 4> array)
return make_int4(array[0], array[1], array[2], array[3]);
}
+static inline int3 get_int3(BL::Array<int, 3> array)
+{
+ return make_int3(array[0], array[1], array[2]);
+}
+
static inline uint get_layer(BL::Array<int, 20> array)
{
uint layer = 0;
diff --git a/intern/cycles/render/object.h b/intern/cycles/render/object.h
index bacfb8f18a4..0a4ad8d8d07 100644
--- a/intern/cycles/render/object.h
+++ b/intern/cycles/render/object.h
@@ -60,7 +60,7 @@ public:
/* Voxel / 3D volume data */
bool use_volume;
int3 resolution;
- vector<float3> grid;
+ vector<float> grid;
Object();
~Object();
diff --git a/source/blender/makesrna/intern/rna_smoke.c b/source/blender/makesrna/intern/rna_smoke.c
index e8818248609..48d69149a45 100644
--- a/source/blender/makesrna/intern/rna_smoke.c
+++ b/source/blender/makesrna/intern/rna_smoke.c
@@ -113,7 +113,7 @@ static char *rna_SmokeCollSettings_path(PointerRNA *ptr)
return BLI_sprintfN("modifiers[\"%s\"].coll_settings", md->name);
}
-static int rna_SmokeModifier_density_get_length(PointerRNA *ptr, int length[RNA_MAX_ARRAY_DIMENSION])
+int rna_SmokeModifier_density_get_length(PointerRNA *ptr, int length[3])
{
SmokeDomainSettings *settings = (SmokeDomainSettings *)ptr->data;
@@ -133,7 +133,7 @@ static int rna_SmokeModifier_density_get_length(PointerRNA *ptr, int length[RNA_
return length[0];
}
-static void rna_SmokeModifier_density_get(PointerRNA *ptr, float *values)
+void rna_SmokeModifier_density_get(PointerRNA *ptr, float *values)
{
SmokeDomainSettings *settings = (SmokeDomainSettings *)ptr->data;
float *density = smoke_get_density(settings->fluid);