Fix T58118: Make duplicates real does nothing
The issue was caused by transflag set in geometry evaluation never copied back top original object. Now we have a dedicated operation which does all sort copy back to original object, so we don't have to worry about atomic assignments or what gets set where. Still need to move boundbox to the same function, but it needs some careful doublechecking first.
This commit is contained in:
@@ -579,6 +579,7 @@ void DepsgraphNodeBuilder::build_object(int base_index,
|
||||
}
|
||||
/* Create ID node for object and begin init. */
|
||||
IDDepsNode *id_node = add_id_node(&object->id);
|
||||
Object *object_cow = get_cow_datablock(object);
|
||||
id_node->linked_state = linked_state;
|
||||
if (object == scene_->camera) {
|
||||
id_node->is_directly_visible = true;
|
||||
@@ -663,6 +664,13 @@ void DepsgraphNodeBuilder::build_object(int base_index,
|
||||
DEG_OPCODE_PLACEHOLDER,
|
||||
"Dupli");
|
||||
}
|
||||
/* Syncronization back to original object. */
|
||||
add_operation_node(&object->id,
|
||||
DEG_NODE_TYPE_SYNCHRONIZE,
|
||||
function_bind(BKE_object_synchronize_to_original,
|
||||
_1,
|
||||
object_cow),
|
||||
DEG_OPCODE_SYNCHRONIZE_TO_ORIGINAL);
|
||||
}
|
||||
|
||||
void DepsgraphNodeBuilder::build_object_flags(
|
||||
|
||||
@@ -683,6 +683,12 @@ void DepsgraphRelationBuilder::build_object(Base *base, Object *object)
|
||||
}
|
||||
/* Point caches. */
|
||||
build_object_pointcache(object);
|
||||
/* Syncronization back to original object. */
|
||||
OperationKey synchronize_key(&object->id,
|
||||
DEG_NODE_TYPE_SYNCHRONIZE,
|
||||
DEG_OPCODE_SYNCHRONIZE_TO_ORIGINAL);
|
||||
add_relation(
|
||||
final_transform_key, synchronize_key, "Synchronize to Original");
|
||||
}
|
||||
|
||||
void DepsgraphRelationBuilder::build_object_flags(Base *base, Object *object)
|
||||
@@ -697,6 +703,12 @@ void DepsgraphRelationBuilder::build_object_flags(Base *base, Object *object)
|
||||
DEG_NODE_TYPE_OBJECT_FROM_LAYER,
|
||||
DEG_OPCODE_OBJECT_BASE_FLAGS);
|
||||
add_relation(view_layer_done_key, object_flags_key, "Base flags flush");
|
||||
/* Syncronization back to original object. */
|
||||
OperationKey synchronize_key(&object->id,
|
||||
DEG_NODE_TYPE_SYNCHRONIZE,
|
||||
DEG_OPCODE_SYNCHRONIZE_TO_ORIGINAL);
|
||||
add_relation(
|
||||
object_flags_key, synchronize_key, "Synchronize to Original");
|
||||
}
|
||||
|
||||
void DepsgraphRelationBuilder::build_object_data(Object *object)
|
||||
@@ -2023,6 +2035,13 @@ void DepsgraphRelationBuilder::build_object_data_geometry(Object *object)
|
||||
}
|
||||
}
|
||||
}
|
||||
/* Syncronization back to original object. */
|
||||
ComponentKey final_geometry_jey(&object->id, DEG_NODE_TYPE_GEOMETRY);
|
||||
OperationKey synchronize_key(&object->id,
|
||||
DEG_NODE_TYPE_SYNCHRONIZE,
|
||||
DEG_OPCODE_SYNCHRONIZE_TO_ORIGINAL);
|
||||
add_relation(
|
||||
final_geometry_jey, synchronize_key, "Synchronize to Original");
|
||||
}
|
||||
|
||||
void DepsgraphRelationBuilder::build_object_data_geometry_datablock(ID *obdata)
|
||||
|
||||
Reference in New Issue
Block a user