mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-08 07:27:29 -06:00
Always use extruder stack when adding settings per object - CURA-4482
This commit is contained in:
parent
77cd10374c
commit
a7383b42d5
1 changed files with 16 additions and 21 deletions
|
@ -78,31 +78,26 @@ class PerObjectSettingsTool(Tool):
|
||||||
def _onGlobalContainerChanged(self):
|
def _onGlobalContainerChanged(self):
|
||||||
global_container_stack = Application.getInstance().getGlobalContainerStack()
|
global_container_stack = Application.getInstance().getGlobalContainerStack()
|
||||||
if global_container_stack:
|
if global_container_stack:
|
||||||
|
|
||||||
|
# used for enabling or disabling per extruder settings per object
|
||||||
self._multi_extrusion = global_container_stack.getProperty("machine_extruder_count", "value") > 1
|
self._multi_extrusion = global_container_stack.getProperty("machine_extruder_count", "value") > 1
|
||||||
|
|
||||||
# Ensure that all extruder data is reset
|
extruder_stack = ExtruderManager.getInstance().getExtruderStack(0)
|
||||||
if not self._multi_extrusion:
|
|
||||||
default_stack_id = global_container_stack.getId()
|
|
||||||
else:
|
|
||||||
default_stack = ExtruderManager.getInstance().getExtruderStack(0)
|
|
||||||
if default_stack:
|
|
||||||
default_stack_id = default_stack.getId()
|
|
||||||
else:
|
|
||||||
default_stack_id = global_container_stack.getId()
|
|
||||||
|
|
||||||
root_node = Application.getInstance().getController().getScene().getRoot()
|
if extruder_stack:
|
||||||
for node in DepthFirstIterator(root_node):
|
root_node = Application.getInstance().getController().getScene().getRoot()
|
||||||
new_stack_id = default_stack_id
|
for node in DepthFirstIterator(root_node):
|
||||||
# Get position of old extruder stack for this node
|
new_stack_id = extruder_stack.getId()
|
||||||
old_extruder_pos = node.callDecoration("getActiveExtruderPosition")
|
# Get position of old extruder stack for this node
|
||||||
if old_extruder_pos is not None:
|
old_extruder_pos = node.callDecoration("getActiveExtruderPosition")
|
||||||
# Fetch current (new) extruder stack at position
|
if old_extruder_pos is not None:
|
||||||
new_stack = ExtruderManager.getInstance().getExtruderStack(old_extruder_pos)
|
# Fetch current (new) extruder stack at position
|
||||||
if new_stack:
|
new_stack = ExtruderManager.getInstance().getExtruderStack(old_extruder_pos)
|
||||||
new_stack_id = new_stack.getId()
|
if new_stack:
|
||||||
node.callDecoration("setActiveExtruder", new_stack_id)
|
new_stack_id = new_stack.getId()
|
||||||
|
node.callDecoration("setActiveExtruder", new_stack_id)
|
||||||
|
|
||||||
self._updateEnabled()
|
self._updateEnabled()
|
||||||
|
|
||||||
def _updateEnabled(self):
|
def _updateEnabled(self):
|
||||||
selected_objects = Selection.getAllSelectedObjects()
|
selected_objects = Selection.getAllSelectedObjects()
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue