mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-08-12 18:49:02 +08:00
Merge branch 'feature_filter_materials_by_diameter' of git://github.com/fieldOfView/Cura
This commit is contained in:
commit
397b08ce6d
@ -244,7 +244,13 @@ class ExtruderManager(QObject):
|
|||||||
material = materials[0]
|
material = materials[0]
|
||||||
preferred_material_id = machine_definition.getMetaDataEntry("preferred_material")
|
preferred_material_id = machine_definition.getMetaDataEntry("preferred_material")
|
||||||
if preferred_material_id:
|
if preferred_material_id:
|
||||||
search_criteria = { "type": "material", "id": preferred_material_id}
|
global_stack = ContainerRegistry.getInstance().findContainerStacks(id = machine_id)
|
||||||
|
if global_stack:
|
||||||
|
approximate_material_diameter = round(global_stack[0].getProperty("material_diameter", "value"))
|
||||||
|
else:
|
||||||
|
approximate_material_diameter = round(machine_definition.getProperty("material_diameter", "value"))
|
||||||
|
|
||||||
|
search_criteria = { "type": "material", "id": preferred_material_id, "approximate_diameter": approximate_material_diameter}
|
||||||
if machine_definition.getMetaDataEntry("has_machine_materials"):
|
if machine_definition.getMetaDataEntry("has_machine_materials"):
|
||||||
search_criteria["definition"] = machine_definition_id
|
search_criteria["definition"] = machine_definition_id
|
||||||
|
|
||||||
|
@ -332,7 +332,7 @@ class MachineManager(QObject):
|
|||||||
container_registry.addContainer(new_global_stack)
|
container_registry.addContainer(new_global_stack)
|
||||||
|
|
||||||
variant_instance_container = self._updateVariantContainer(definition)
|
variant_instance_container = self._updateVariantContainer(definition)
|
||||||
material_instance_container = self._updateMaterialContainer(definition, variant_instance_container)
|
material_instance_container = self._updateMaterialContainer(definition, new_global_stack, variant_instance_container)
|
||||||
quality_instance_container = self._updateQualityContainer(definition, variant_instance_container, material_instance_container)
|
quality_instance_container = self._updateQualityContainer(definition, variant_instance_container, material_instance_container)
|
||||||
|
|
||||||
current_settings_instance_container = InstanceContainer(name + "_current_settings")
|
current_settings_instance_container = InstanceContainer(name + "_current_settings")
|
||||||
@ -760,7 +760,7 @@ class MachineManager(QObject):
|
|||||||
if old_material:
|
if old_material:
|
||||||
preferred_material_name = old_material.getName()
|
preferred_material_name = old_material.getName()
|
||||||
|
|
||||||
self.setActiveMaterial(self._updateMaterialContainer(self._global_container_stack.getBottom(), containers[0], preferred_material_name).id)
|
self.setActiveMaterial(self._updateMaterialContainer(self._global_container_stack.getBottom(), self._global_container_stack, containers[0], preferred_material_name).id)
|
||||||
else:
|
else:
|
||||||
Logger.log("w", "While trying to set the active variant, no variant was found to replace.")
|
Logger.log("w", "While trying to set the active variant, no variant was found to replace.")
|
||||||
|
|
||||||
@ -1110,11 +1110,12 @@ class MachineManager(QObject):
|
|||||||
|
|
||||||
return self._empty_variant_container
|
return self._empty_variant_container
|
||||||
|
|
||||||
def _updateMaterialContainer(self, definition, variant_container = None, preferred_material_name = None):
|
def _updateMaterialContainer(self, stack, definition, variant_container = None, preferred_material_name = None):
|
||||||
if not definition.getMetaDataEntry("has_materials"):
|
if not definition.getMetaDataEntry("has_materials"):
|
||||||
return self._empty_material_container
|
return self._empty_material_container
|
||||||
|
|
||||||
search_criteria = { "type": "material" }
|
approximate_material_diameter = round(stack.getProperty("material_diameter", "value"))
|
||||||
|
search_criteria = { "type": "material", "approximate_diameter": approximate_material_diameter }
|
||||||
|
|
||||||
if definition.getMetaDataEntry("has_machine_materials"):
|
if definition.getMetaDataEntry("has_machine_materials"):
|
||||||
search_criteria["definition"] = self.getQualityDefinitionId(definition)
|
search_criteria["definition"] = self.getQualityDefinitionId(definition)
|
||||||
|
@ -118,6 +118,7 @@ class XmlMaterialProfile(InstanceContainer):
|
|||||||
metadata.pop("variant", "")
|
metadata.pop("variant", "")
|
||||||
metadata.pop("type", "")
|
metadata.pop("type", "")
|
||||||
metadata.pop("base_file", "")
|
metadata.pop("base_file", "")
|
||||||
|
metadata.pop("approximate_diameter", "")
|
||||||
|
|
||||||
## Begin Name Block
|
## Begin Name Block
|
||||||
builder.start("name")
|
builder.start("name")
|
||||||
@ -437,6 +438,7 @@ class XmlMaterialProfile(InstanceContainer):
|
|||||||
Logger.log("d", "Unsupported material setting %s", key)
|
Logger.log("d", "Unsupported material setting %s", key)
|
||||||
self._cached_values = global_setting_values
|
self._cached_values = global_setting_values
|
||||||
|
|
||||||
|
meta_data["approximate_diameter"] = round(diameter)
|
||||||
meta_data["compatible"] = global_compatibility
|
meta_data["compatible"] = global_compatibility
|
||||||
self.setMetaData(meta_data)
|
self.setMetaData(meta_data)
|
||||||
self._dirty = False
|
self._dirty = False
|
||||||
|
@ -15,6 +15,15 @@ Menu
|
|||||||
property int extruderIndex: 0
|
property int extruderIndex: 0
|
||||||
property bool printerConnected: Cura.MachineManager.printerOutputDevices.length != 0
|
property bool printerConnected: Cura.MachineManager.printerOutputDevices.length != 0
|
||||||
|
|
||||||
|
UM.SettingPropertyProvider
|
||||||
|
{
|
||||||
|
id: materialDiameterProvider
|
||||||
|
|
||||||
|
containerStackId: Cura.MachineManager.activeMachineId
|
||||||
|
key: "material_diameter"
|
||||||
|
watchedProperties: [ "value" ]
|
||||||
|
}
|
||||||
|
|
||||||
MenuItem
|
MenuItem
|
||||||
{
|
{
|
||||||
id: automaticMaterial
|
id: automaticMaterial
|
||||||
@ -141,7 +150,7 @@ Menu
|
|||||||
|
|
||||||
function materialFilter()
|
function materialFilter()
|
||||||
{
|
{
|
||||||
var result = { "type": "material" };
|
var result = { "type": "material", "approximate_diameter": Math.round(materialDiameterProvider.properties.value) };
|
||||||
if(Cura.MachineManager.filterMaterialsByMachine)
|
if(Cura.MachineManager.filterMaterialsByMachine)
|
||||||
{
|
{
|
||||||
result.definition = Cura.MachineManager.activeQualityDefinitionId;
|
result.definition = Cura.MachineManager.activeQualityDefinitionId;
|
||||||
|
@ -18,7 +18,7 @@ UM.ManagementPage
|
|||||||
{
|
{
|
||||||
filter:
|
filter:
|
||||||
{
|
{
|
||||||
var result = { "type": "material" }
|
var result = { "type": "material", "approximate_diameter": Math.round(materialDiameterProvider.properties.value) }
|
||||||
if(Cura.MachineManager.filterMaterialsByMachine)
|
if(Cura.MachineManager.filterMaterialsByMachine)
|
||||||
{
|
{
|
||||||
result.definition = Cura.MachineManager.activeQualityDefinitionId;
|
result.definition = Cura.MachineManager.activeQualityDefinitionId;
|
||||||
@ -327,6 +327,15 @@ UM.ManagementPage
|
|||||||
id: messageDialog
|
id: messageDialog
|
||||||
}
|
}
|
||||||
|
|
||||||
|
UM.SettingPropertyProvider
|
||||||
|
{
|
||||||
|
id: materialDiameterProvider
|
||||||
|
|
||||||
|
containerStackId: Cura.MachineManager.activeMachineId
|
||||||
|
key: "material_diameter"
|
||||||
|
watchedProperties: [ "value" ]
|
||||||
|
}
|
||||||
|
|
||||||
UM.I18nCatalog { id: catalog; name: "cura"; }
|
UM.I18nCatalog { id: catalog; name: "cura"; }
|
||||||
SystemPalette { id: palette }
|
SystemPalette { id: palette }
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user