mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-07 06:57:28 -06:00
Project load dialog now also gives information about the quality & quality changes
CURA-1263
This commit is contained in:
parent
6bb1b7ec80
commit
b3f1f6b4db
3 changed files with 62 additions and 4 deletions
|
@ -87,6 +87,9 @@ class ThreeMFWorkspaceReader(WorkspaceReader):
|
||||||
|
|
||||||
# Check if any quality_changes instance container is in conflict.
|
# Check if any quality_changes instance container is in conflict.
|
||||||
instance_container_files = [name for name in cura_file_names if name.endswith(self._instance_container_suffix)]
|
instance_container_files = [name for name in cura_file_names if name.endswith(self._instance_container_suffix)]
|
||||||
|
quality_name = ""
|
||||||
|
quality_type = ""
|
||||||
|
num_settings_overriden_by_quality_changes = 0 # How many settings are changed by the quality changes
|
||||||
for instance_container_file in instance_container_files:
|
for instance_container_file in instance_container_files:
|
||||||
container_id = self._stripFileToId(instance_container_file)
|
container_id = self._stripFileToId(instance_container_file)
|
||||||
instance_container = InstanceContainer(container_id)
|
instance_container = InstanceContainer(container_id)
|
||||||
|
@ -95,15 +98,21 @@ class ThreeMFWorkspaceReader(WorkspaceReader):
|
||||||
instance_container.deserialize(archive.open(instance_container_file).read().decode("utf-8"))
|
instance_container.deserialize(archive.open(instance_container_file).read().decode("utf-8"))
|
||||||
container_type = instance_container.getMetaDataEntry("type")
|
container_type = instance_container.getMetaDataEntry("type")
|
||||||
if container_type == "quality_changes":
|
if container_type == "quality_changes":
|
||||||
|
quality_name = instance_container.getName()
|
||||||
|
num_settings_overriden_by_quality_changes += len(instance_container._instances)
|
||||||
# Check if quality changes already exists.
|
# Check if quality changes already exists.
|
||||||
quality_changes = self._container_registry.findInstanceContainers(id = container_id)
|
quality_changes = self._container_registry.findInstanceContainers(id = container_id)
|
||||||
if quality_changes:
|
if quality_changes:
|
||||||
# Check if there really is a conflict by comparing the values
|
# Check if there really is a conflict by comparing the values
|
||||||
if quality_changes[0] != instance_container:
|
if quality_changes[0] != instance_container:
|
||||||
quality_changes_conflict = True
|
quality_changes_conflict = True
|
||||||
break
|
elif container_type == "quality":
|
||||||
|
# If the quality name is not set (either by quality or changes, set it now)
|
||||||
|
# Quality changes should always override this (as they are "on top")
|
||||||
|
if quality_name == "":
|
||||||
|
quality_name = instance_container.getName()
|
||||||
|
quality_type = instance_container.getName()
|
||||||
Job.yieldThread()
|
Job.yieldThread()
|
||||||
|
|
||||||
num_visible_settings = 0
|
num_visible_settings = 0
|
||||||
try:
|
try:
|
||||||
temp_preferences = Preferences()
|
temp_preferences = Preferences()
|
||||||
|
@ -125,6 +134,9 @@ class ThreeMFWorkspaceReader(WorkspaceReader):
|
||||||
self._dialog.setQualityChangesConflict(quality_changes_conflict)
|
self._dialog.setQualityChangesConflict(quality_changes_conflict)
|
||||||
self._dialog.setMaterialConflict(material_conflict)
|
self._dialog.setMaterialConflict(material_conflict)
|
||||||
self._dialog.setNumVisibleSettings(num_visible_settings)
|
self._dialog.setNumVisibleSettings(num_visible_settings)
|
||||||
|
self._dialog.setQualityName(quality_name)
|
||||||
|
self._dialog.setQualityType(quality_type)
|
||||||
|
self._dialog.setNumSettingsOverridenByQualityChanges(num_settings_overriden_by_quality_changes)
|
||||||
self._dialog.setActiveMode(active_mode)
|
self._dialog.setActiveMode(active_mode)
|
||||||
self._dialog.show()
|
self._dialog.show()
|
||||||
|
|
||||||
|
|
|
@ -32,12 +32,42 @@ class WorkspaceDialog(QObject):
|
||||||
self._has_material_conflict = False
|
self._has_material_conflict = False
|
||||||
self._num_visible_settings = 0
|
self._num_visible_settings = 0
|
||||||
self._active_mode = ""
|
self._active_mode = ""
|
||||||
|
self._quality_name = ""
|
||||||
|
self._num_settings_overriden_by_quality_changes = 0
|
||||||
|
self._quality_type = ""
|
||||||
|
|
||||||
machineConflictChanged = pyqtSignal()
|
machineConflictChanged = pyqtSignal()
|
||||||
qualityChangesConflictChanged = pyqtSignal()
|
qualityChangesConflictChanged = pyqtSignal()
|
||||||
materialConflictChanged = pyqtSignal()
|
materialConflictChanged = pyqtSignal()
|
||||||
numVisibleSettingsChanged = pyqtSignal()
|
numVisibleSettingsChanged = pyqtSignal()
|
||||||
activeModeChanged = pyqtSignal()
|
activeModeChanged = pyqtSignal()
|
||||||
|
qualityNameChanged = pyqtSignal()
|
||||||
|
numSettingsOverridenByQualityChangesChanged = pyqtSignal()
|
||||||
|
qualityTypeChanged = pyqtSignal()
|
||||||
|
|
||||||
|
@pyqtProperty(str, notify=qualityTypeChanged)
|
||||||
|
def qualityType(self):
|
||||||
|
return self._quality_type
|
||||||
|
|
||||||
|
def setQualityType(self, quality_type):
|
||||||
|
self._quality_type = quality_type
|
||||||
|
self.qualityTypeChanged.emit()
|
||||||
|
|
||||||
|
@pyqtProperty(int, notify=numSettingsOverridenByQualityChangesChanged)
|
||||||
|
def numSettingsOverridenByQualityChanges(self):
|
||||||
|
return self._num_settings_overriden_by_quality_changes
|
||||||
|
|
||||||
|
def setNumSettingsOverridenByQualityChanges(self, num_settings_overriden_by_quality_changes):
|
||||||
|
self._num_settings_overriden_by_quality_changes = num_settings_overriden_by_quality_changes
|
||||||
|
self.numSettingsOverridenByQualityChangesChanged.emit()
|
||||||
|
|
||||||
|
@pyqtProperty(str, notify=qualityNameChanged)
|
||||||
|
def qualityName(self):
|
||||||
|
return self._quality_name
|
||||||
|
|
||||||
|
def setQualityName(self, quality_name):
|
||||||
|
self._quality_name = quality_name
|
||||||
|
self.qualityNameChanged.emit()
|
||||||
|
|
||||||
@pyqtProperty(str, notify=activeModeChanged)
|
@pyqtProperty(str, notify=activeModeChanged)
|
||||||
def activeMode(self):
|
def activeMode(self):
|
||||||
|
|
|
@ -130,12 +130,12 @@ UM.Dialog
|
||||||
height: childrenRect.height
|
height: childrenRect.height
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Type")
|
text: catalog.i18nc("@action:label", "Name")
|
||||||
width: parent.width / 3
|
width: parent.width / 3
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "TOCHANGE")
|
text: manager.qualityName
|
||||||
width: parent.width / 3
|
width: parent.width / 3
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -159,6 +159,22 @@ UM.Dialog
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Row
|
||||||
|
{
|
||||||
|
width: parent.width
|
||||||
|
height: childrenRect.height
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
text: catalog.i18nc("@action:label", "Derivative from")
|
||||||
|
width: parent.width / 3
|
||||||
|
}
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
text: catalog.i18nc("@action:label", "%1, %2 overrides" ).arg(manager.qualityType).arg(manager.numSettingsOverridenByQualityChanges)
|
||||||
|
width: parent.width / 3
|
||||||
|
}
|
||||||
|
visible: manager.numSettingsOverridenByQualityChanges != 0
|
||||||
|
}
|
||||||
|
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue