mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-08-12 09:49:04 +08:00
Update material node when its metadata changes
This should keep the tree up to date if anything is added, removed or changed in the container registry. Contributes to issue CURA-6600.
This commit is contained in:
parent
41c573b087
commit
30b2f943fd
@ -1,7 +1,7 @@
|
|||||||
# Copyright (c) 2019 Ultimaker B.V.
|
# Copyright (c) 2019 Ultimaker B.V.
|
||||||
# Cura is released under the terms of the LGPLv3 or higher.
|
# Cura is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
from typing import TYPE_CHECKING
|
from typing import Any, TYPE_CHECKING
|
||||||
|
|
||||||
from UM.Settings.ContainerRegistry import ContainerRegistry
|
from UM.Settings.ContainerRegistry import ContainerRegistry
|
||||||
from UM.Settings.Interfaces import ContainerInterface
|
from UM.Settings.Interfaces import ContainerInterface
|
||||||
@ -23,8 +23,11 @@ class MaterialNode(ContainerNode):
|
|||||||
container_registry = ContainerRegistry.getInstance()
|
container_registry = ContainerRegistry.getInstance()
|
||||||
my_metadata = container_registry.findContainersMetadata(id = container_id)[0]
|
my_metadata = container_registry.findContainersMetadata(id = container_id)[0]
|
||||||
self.base_file = my_metadata["base_file"]
|
self.base_file = my_metadata["base_file"]
|
||||||
|
self.material_type = my_metadata["material"]
|
||||||
|
self.guid = my_metadata["guid"]
|
||||||
self._loadAll()
|
self._loadAll()
|
||||||
container_registry.containerRemoved.connect(self._onRemoved)
|
container_registry.containerRemoved.connect(self._onRemoved)
|
||||||
|
container_registry.containerMetaDataChanged(self._onMetadataChanged)
|
||||||
|
|
||||||
def _loadAll(self) -> None:
|
def _loadAll(self) -> None:
|
||||||
container_registry = ContainerRegistry.getInstance()
|
container_registry = ContainerRegistry.getInstance()
|
||||||
@ -33,14 +36,13 @@ class MaterialNode(ContainerNode):
|
|||||||
qualities = container_registry.findInstanceContainersMetadata(type = "quality", definition = "fdmprinter")
|
qualities = container_registry.findInstanceContainersMetadata(type = "quality", definition = "fdmprinter")
|
||||||
else:
|
else:
|
||||||
# Need to find the qualities that specify a material profile with the same material type.
|
# Need to find the qualities that specify a material profile with the same material type.
|
||||||
my_metadata = container_registry.findInstanceContainersMetadata(id = self.container_id)[0]
|
my_material_type = self.material_type
|
||||||
my_material_type = my_metadata.get("material")
|
|
||||||
qualities = []
|
qualities = []
|
||||||
qualities_any_material = container_registry.findInstanceContainersMetadata(type = "quality", definition = self.variant.machine.quality_definition, variant = self.variant.variant_name)
|
qualities_any_material = container_registry.findInstanceContainersMetadata(type = "quality", definition = self.variant.machine.quality_definition, variant = self.variant.variant_name)
|
||||||
for material_metadata in container_registry.findInstanceContainersMetadata(type = "material", material = my_material_type):
|
for material_metadata in container_registry.findInstanceContainersMetadata(type = "material", material = my_material_type):
|
||||||
qualities.extend((quality for quality in qualities_any_material if quality["material"] == material_metadata["id"]))
|
qualities.extend((quality for quality in qualities_any_material if quality["material"] == material_metadata["id"]))
|
||||||
if not qualities: # No quality profiles found. Go by GUID then.
|
if not qualities: # No quality profiles found. Go by GUID then.
|
||||||
my_guid = my_metadata.get("guid")
|
my_guid = self.guid
|
||||||
for material_metadata in container_registry.findInstanceContainersMetadata(type = "material", guid = my_guid):
|
for material_metadata in container_registry.findInstanceContainersMetadata(type = "material", guid = my_guid):
|
||||||
qualities.extend((quality for quality in qualities_any_material if quality["material"] == material_metadata["id"]))
|
qualities.extend((quality for quality in qualities_any_material if quality["material"] == material_metadata["id"]))
|
||||||
|
|
||||||
@ -56,4 +58,30 @@ class MaterialNode(ContainerNode):
|
|||||||
if container.getId() == self.container_id:
|
if container.getId() == self.container_id:
|
||||||
# Remove myself from my parent.
|
# Remove myself from my parent.
|
||||||
if self.base_file in self.variant.materials:
|
if self.base_file in self.variant.materials:
|
||||||
del self.variant.materials[self.base_file]
|
del self.variant.materials[self.base_file]
|
||||||
|
|
||||||
|
## Triggered when any metadata changed in any container, but only handles
|
||||||
|
# it when the metadata of this node is changed.
|
||||||
|
# \param container The container whose metadata changed.
|
||||||
|
# \param kwargs Key-word arguments provided when changing the metadata.
|
||||||
|
# These are ignored. As far as I know they are never provided to this
|
||||||
|
# call.
|
||||||
|
def _onMetadataChanged(self, container: ContainerInterface, **kwargs: Any) -> None:
|
||||||
|
if container.getId() != self.container_id:
|
||||||
|
return
|
||||||
|
|
||||||
|
new_metadata = container.getMetaData()
|
||||||
|
old_base_file = self.base_file
|
||||||
|
if new_metadata["base_file"] != old_base_file:
|
||||||
|
self.base_file = new_metadata["base_file"]
|
||||||
|
if old_base_file in self.variant.materials: # Move in parent node.
|
||||||
|
del self.variant.materials[old_base_file]
|
||||||
|
self.variant.materials[self.base_file] = self
|
||||||
|
|
||||||
|
old_material_type = self.material_type
|
||||||
|
self.material_type = new_metadata["material"]
|
||||||
|
old_guid = self.guid
|
||||||
|
self.guid = new_metadata["guid"]
|
||||||
|
if self.base_file != old_base_file or self.material_type != old_material_type or self.guid != old_guid: # List of quality profiles could've changed.
|
||||||
|
self.qualities = {}
|
||||||
|
self._loadAll() # Re-load the quality profiles for this node.
|
Loading…
x
Reference in New Issue
Block a user