mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-12 17:27:51 -06:00
Add global quality nodes to machine node
This means that the parent of the quality node could be one of two types. A bit confusing. Contributes to issue CURA-6600.
This commit is contained in:
parent
fff26bb021
commit
8f075b644d
3 changed files with 28 additions and 12 deletions
|
@ -7,6 +7,7 @@ from UM.Util import parseBool
|
|||
from UM.Settings.ContainerRegistry import ContainerRegistry # To find all the variants for this machine.
|
||||
from UM.Settings.Interfaces import ContainerInterface
|
||||
from cura.Machines.ContainerNode import ContainerNode
|
||||
from cura.Machines.QualityNode import QualityNode
|
||||
from cura.Machines.VariantNode import VariantNode
|
||||
|
||||
if TYPE_CHECKING:
|
||||
|
@ -18,7 +19,8 @@ if TYPE_CHECKING:
|
|||
class MachineNode(ContainerNode):
|
||||
def __init__(self, container_id: str) -> None:
|
||||
super().__init__(container_id)
|
||||
self.variants = {} # type: Dict[str, VariantNode] # mapping variant names to their nodes.
|
||||
self.variants = {} # type: Dict[str, VariantNode] # Mapping variant names to their nodes.
|
||||
self.global_qualities = {} # type: Dict[str, QualityNode] # Mapping quality types to the global quality for those types.
|
||||
container_registry = ContainerRegistry.getInstance()
|
||||
|
||||
my_metadata = container_registry.findContainersMetadata(id = container_id)[0]
|
||||
|
@ -37,12 +39,20 @@ class MachineNode(ContainerNode):
|
|||
## (Re)loads all variants under this printer.
|
||||
def _loadAll(self):
|
||||
# Find all the variants for this definition ID.
|
||||
variants = ContainerRegistry.getInstance().findInstanceContainersMetadata(type = "variant", definition = self.container_id, hardware_type = "nozzle")
|
||||
container_registry = ContainerRegistry.getInstance()
|
||||
variants = container_registry.findInstanceContainersMetadata(type = "variant", definition = self.container_id, hardware_type = "nozzle")
|
||||
for variant in variants:
|
||||
variant_name = variant["name"]
|
||||
if variant_name not in self.variants:
|
||||
self.variants[variant_name] = VariantNode(variant["id"], machine = self)
|
||||
|
||||
# Find the global qualities for this printer.
|
||||
global_qualities = container_registry.findInstanceContainersMetadata(type = "quality", definition = self.container_id, global_quality = True) # First try specific to this printer.
|
||||
if len(global_qualities) == 0: # This printer doesn't override the global qualities.
|
||||
global_qualities = container_registry.findInstanceContainersMetadata(type = "quality", definition = "fdmprinter", global_quality = True) # Otherwise pick the global global qualities.
|
||||
for global_quality in global_qualities:
|
||||
self.global_qualities[global_quality["quality_type"]] = QualityNode(global_quality["id"], parent = self)
|
||||
|
||||
## When a variant gets added to the set of profiles, we need to update our
|
||||
# tree here.
|
||||
def _variantAdded(self, container: ContainerInterface):
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue