[Bf-blender-cvs] [e48cdf3d0d8] blender-v2.93-release: Fix T88216: Cycles persistent data fails with animated object transform in instance
Brecht Van Lommel
noreply at git.blender.org
Mon May 17 19:41:58 CEST 2021
Commit: e48cdf3d0d87cd393412007c33ba48b10a802426
Author: Brecht Van Lommel
Date: Mon May 17 15:43:42 2021 +0200
Branches: blender-v2.93-release
https://developer.blender.org/rBe48cdf3d0d87cd393412007c33ba48b10a802426
Fix T88216: Cycles persistent data fails with animated object transform in instance
===================================================================
M intern/cycles/blender/blender_object.cpp
===================================================================
diff --git a/intern/cycles/blender/blender_object.cpp b/intern/cycles/blender/blender_object.cpp
index 3d635800988..dcf6e3cc949 100644
--- a/intern/cycles/blender/blender_object.cpp
+++ b/intern/cycles/blender/blender_object.cpp
@@ -261,10 +261,8 @@ Object *BlenderSync::sync_object(BL::Depsgraph &b_depsgraph,
}
/* test if we need to sync */
- bool object_updated = false;
-
- if (object_map.add_or_update(&object, b_ob, b_parent, key))
- object_updated = true;
+ bool object_updated = object_map.add_or_update(&object, b_ob, b_parent, key) ||
+ (tfm != object->get_tfm());
/* mesh sync */
/* b_ob is owned by the iterator and will go out of scope at the end of the block.
@@ -313,8 +311,7 @@ Object *BlenderSync::sync_object(BL::Depsgraph &b_depsgraph,
* transform comparison should not be needed, but duplis don't work perfect
* in the depsgraph and may not signal changes, so this is a workaround */
if (object->is_modified() || object_updated ||
- (object->get_geometry() && object->get_geometry()->is_modified()) ||
- tfm != object->get_tfm()) {
+ (object->get_geometry() && object->get_geometry()->is_modified())) {
object->name = b_ob.name().c_str();
object->set_pass_id(b_ob.pass_index());
object->set_color(get_float3(b_ob.color()));
More information about the Bf-blender-cvs
mailing list