mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-06 22:47:29 -06:00
Merge branch 'master' into WIP_improve_initialization
This commit is contained in:
commit
b7fe43e68c
24 changed files with 433 additions and 279 deletions
|
@ -19,6 +19,7 @@ endif()
|
||||||
|
|
||||||
set(CURA_VERSION "master" CACHE STRING "Version name of Cura")
|
set(CURA_VERSION "master" CACHE STRING "Version name of Cura")
|
||||||
set(CURA_BUILDTYPE "" CACHE STRING "Build type of Cura, eg. 'PPA'")
|
set(CURA_BUILDTYPE "" CACHE STRING "Build type of Cura, eg. 'PPA'")
|
||||||
|
set(CURA_PACKAGES_VERSION "" CACHE STRING "Packages version of Cura")
|
||||||
configure_file(${CMAKE_SOURCE_DIR}/cura.desktop.in ${CMAKE_BINARY_DIR}/cura.desktop @ONLY)
|
configure_file(${CMAKE_SOURCE_DIR}/cura.desktop.in ${CMAKE_BINARY_DIR}/cura.desktop @ONLY)
|
||||||
configure_file(cura/CuraVersion.py.in CuraVersion.py @ONLY)
|
configure_file(cura/CuraVersion.py.in CuraVersion.py @ONLY)
|
||||||
|
|
||||||
|
|
|
@ -537,7 +537,7 @@ class CuraApplication(QtApplication):
|
||||||
|
|
||||||
## A reusable dialogbox
|
## A reusable dialogbox
|
||||||
#
|
#
|
||||||
showMessageBox = pyqtSignal(str, str, str, str, int, int, arguments = ["title", "text", "informativeText", "detailedText", "buttons", "icon"])
|
showMessageBox = pyqtSignal(str, str, str, str, str, int, int, arguments = ["title", "footer", "text", "informativeText", "detailedText", "buttons", "icon"])
|
||||||
|
|
||||||
def messageBox(self, title, text, informativeText = "", detailedText = "", buttons = QMessageBox.Ok, icon = QMessageBox.NoIcon, callback = None, callback_arguments = []):
|
def messageBox(self, title, text, informativeText = "", detailedText = "", buttons = QMessageBox.Ok, icon = QMessageBox.NoIcon, callback = None, callback_arguments = []):
|
||||||
self._message_box_callback = callback
|
self._message_box_callback = callback
|
||||||
|
|
|
@ -8,13 +8,14 @@ import shutil
|
||||||
import zipfile
|
import zipfile
|
||||||
import tempfile
|
import tempfile
|
||||||
|
|
||||||
from PyQt5.QtCore import pyqtSlot, QObject, pyqtSignal
|
from PyQt5.QtCore import pyqtSlot, QObject, pyqtSignal, QUrl
|
||||||
|
|
||||||
from UM.Application import Application
|
from UM.Application import Application
|
||||||
from UM.Logger import Logger
|
from UM.Logger import Logger
|
||||||
from UM.Resources import Resources
|
from UM.Resources import Resources
|
||||||
from UM.Version import Version
|
from UM.Version import Version
|
||||||
|
|
||||||
|
|
||||||
class CuraPackageManager(QObject):
|
class CuraPackageManager(QObject):
|
||||||
Version = 1
|
Version = 1
|
||||||
|
|
||||||
|
@ -184,6 +185,12 @@ class CuraPackageManager(QObject):
|
||||||
def isPackageInstalled(self, package_id: str) -> bool:
|
def isPackageInstalled(self, package_id: str) -> bool:
|
||||||
return self.getInstalledPackageInfo(package_id) is not None
|
return self.getInstalledPackageInfo(package_id) is not None
|
||||||
|
|
||||||
|
# This is called by drag-and-dropping curapackage files.
|
||||||
|
@pyqtSlot(QUrl)
|
||||||
|
def installPackageViaDragAndDrop(self, file_url: str) -> None:
|
||||||
|
filename = QUrl(file_url).toLocalFile()
|
||||||
|
return self.installPackage(filename)
|
||||||
|
|
||||||
# Schedules the given package file to be installed upon the next start.
|
# Schedules the given package file to be installed upon the next start.
|
||||||
@pyqtSlot(str)
|
@pyqtSlot(str)
|
||||||
def installPackage(self, filename: str) -> None:
|
def installPackage(self, filename: str) -> None:
|
||||||
|
|
|
@ -4,3 +4,4 @@
|
||||||
CuraVersion = "@CURA_VERSION@"
|
CuraVersion = "@CURA_VERSION@"
|
||||||
CuraBuildType = "@CURA_BUILDTYPE@"
|
CuraBuildType = "@CURA_BUILDTYPE@"
|
||||||
CuraDebugMode = True if "@_cura_debugmode@" == "ON" else False
|
CuraDebugMode = True if "@_cura_debugmode@" == "ON" else False
|
||||||
|
CuraPackagesVersion = "@CURA_PACKAGES_VERSION@"
|
||||||
|
|
|
@ -76,7 +76,9 @@ class MaterialManager(QObject):
|
||||||
|
|
||||||
def initialize(self):
|
def initialize(self):
|
||||||
# Find all materials and put them in a matrix for quick search.
|
# Find all materials and put them in a matrix for quick search.
|
||||||
material_metadatas = {metadata["id"]: metadata for metadata in self._container_registry.findContainersMetadata(type = "material")}
|
material_metadatas = {metadata["id"]: metadata for metadata in
|
||||||
|
self._container_registry.findContainersMetadata(type = "material") if
|
||||||
|
metadata.get("GUID")}
|
||||||
|
|
||||||
self._material_group_map = dict()
|
self._material_group_map = dict()
|
||||||
|
|
||||||
|
@ -158,11 +160,11 @@ class MaterialManager(QObject):
|
||||||
key_data.append(root_material_metadata.get(key))
|
key_data.append(root_material_metadata.get(key))
|
||||||
key_data = tuple(key_data)
|
key_data = tuple(key_data)
|
||||||
|
|
||||||
# If the key_data doesn't exist, no matter if the material is read only...
|
# If the key_data doesn't exist, it doesn't matter if the material is read only...
|
||||||
if key_data not in material_group_dict:
|
if key_data not in material_group_dict:
|
||||||
material_group_dict[key_data] = dict()
|
material_group_dict[key_data] = dict()
|
||||||
else:
|
else:
|
||||||
# ...but if key_data exists, we just overrite it if the material is read only, otherwise we skip it
|
# ...but if key_data exists, we just overwrite it if the material is read only, otherwise we skip it
|
||||||
if not machine_node.is_read_only:
|
if not machine_node.is_read_only:
|
||||||
continue
|
continue
|
||||||
approximate_diameter = root_material_metadata.get("approximate_diameter")
|
approximate_diameter = root_material_metadata.get("approximate_diameter")
|
||||||
|
|
|
@ -35,7 +35,7 @@ class PlatformPhysics:
|
||||||
self._max_overlap_checks = 10 # How many times should we try to find a new spot per tick?
|
self._max_overlap_checks = 10 # How many times should we try to find a new spot per tick?
|
||||||
self._minimum_gap = 2 # It is a minimum distance (in mm) between two models, applicable for small models
|
self._minimum_gap = 2 # It is a minimum distance (in mm) between two models, applicable for small models
|
||||||
|
|
||||||
Application.getInstance().getPreferences().addPreference("physics/automatic_push_free", True)
|
Application.getInstance().getPreferences().addPreference("physics/automatic_push_free", False)
|
||||||
Application.getInstance().getPreferences().addPreference("physics/automatic_drop_down", True)
|
Application.getInstance().getPreferences().addPreference("physics/automatic_drop_down", True)
|
||||||
|
|
||||||
def _onSceneChanged(self, source):
|
def _onSceneChanged(self, source):
|
||||||
|
|
|
@ -1,7 +1,6 @@
|
||||||
# Copyright (c) 2018 Ultimaker B.V.
|
# Copyright (c) 2018 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 UM.Application import Application
|
from UM.Application import Application
|
||||||
from UM.Math.Color import Color
|
|
||||||
from UM.Resources import Resources
|
from UM.Resources import Resources
|
||||||
|
|
||||||
from UM.View.RenderPass import RenderPass
|
from UM.View.RenderPass import RenderPass
|
||||||
|
@ -74,7 +73,6 @@ class PreviewPass(RenderPass):
|
||||||
|
|
||||||
# Create batches to be rendered
|
# Create batches to be rendered
|
||||||
batch = RenderBatch(self._shader)
|
batch = RenderBatch(self._shader)
|
||||||
batch_non_printing = RenderBatch(self._non_printing_shader, type = RenderBatch.RenderType.Transparent)
|
|
||||||
batch_support_mesh = RenderBatch(self._support_mesh_shader)
|
batch_support_mesh = RenderBatch(self._support_mesh_shader)
|
||||||
|
|
||||||
# Fill up the batch with objects that can be sliced. `
|
# Fill up the batch with objects that can be sliced. `
|
||||||
|
@ -83,7 +81,7 @@ class PreviewPass(RenderPass):
|
||||||
per_mesh_stack = node.callDecoration("getStack")
|
per_mesh_stack = node.callDecoration("getStack")
|
||||||
if node.callDecoration("isNonPrintingMesh"):
|
if node.callDecoration("isNonPrintingMesh"):
|
||||||
# Non printing mesh
|
# Non printing mesh
|
||||||
batch_non_printing.addItem(node.getWorldTransformation(), node.getMeshData(), uniforms = {})
|
continue
|
||||||
elif per_mesh_stack is not None and per_mesh_stack.getProperty("support_mesh", "value") == True:
|
elif per_mesh_stack is not None and per_mesh_stack.getProperty("support_mesh", "value") == True:
|
||||||
# Support mesh
|
# Support mesh
|
||||||
uniforms = {}
|
uniforms = {}
|
||||||
|
@ -112,7 +110,6 @@ class PreviewPass(RenderPass):
|
||||||
|
|
||||||
batch.render(render_camera)
|
batch.render(render_camera)
|
||||||
batch_support_mesh.render(render_camera)
|
batch_support_mesh.render(render_camera)
|
||||||
batch_non_printing.render(render_camera)
|
|
||||||
|
|
||||||
self.release()
|
self.release()
|
||||||
|
|
||||||
|
|
|
@ -6,13 +6,10 @@ from PyQt5 import QtCore
|
||||||
from PyQt5.QtGui import QImage
|
from PyQt5.QtGui import QImage
|
||||||
|
|
||||||
from cura.PreviewPass import PreviewPass
|
from cura.PreviewPass import PreviewPass
|
||||||
from cura.Scene import ConvexHullNode
|
|
||||||
|
|
||||||
from UM.Application import Application
|
from UM.Application import Application
|
||||||
from UM.Math.AxisAlignedBox import AxisAlignedBox
|
|
||||||
from UM.Math.Matrix import Matrix
|
from UM.Math.Matrix import Matrix
|
||||||
from UM.Math.Vector import Vector
|
from UM.Math.Vector import Vector
|
||||||
from UM.Mesh.MeshData import transformVertices
|
|
||||||
from UM.Scene.Camera import Camera
|
from UM.Scene.Camera import Camera
|
||||||
from UM.Scene.Iterator.DepthFirstIterator import DepthFirstIterator
|
from UM.Scene.Iterator.DepthFirstIterator import DepthFirstIterator
|
||||||
|
|
||||||
|
@ -51,7 +48,7 @@ class Snapshot:
|
||||||
# determine zoom and look at
|
# determine zoom and look at
|
||||||
bbox = None
|
bbox = None
|
||||||
for node in DepthFirstIterator(root):
|
for node in DepthFirstIterator(root):
|
||||||
if node.callDecoration("isSliceable") and node.getMeshData() and node.isVisible():
|
if node.callDecoration("isSliceable") and node.getMeshData() and node.isVisible() and not node.callDecoration("isNonPrintingMesh"):
|
||||||
if bbox is None:
|
if bbox is None:
|
||||||
bbox = node.getBoundingBox()
|
bbox = node.getBoundingBox()
|
||||||
else:
|
else:
|
||||||
|
|
|
@ -9,7 +9,6 @@ import UM 1.1 as UM
|
||||||
Item
|
Item
|
||||||
{
|
{
|
||||||
id: tile
|
id: tile
|
||||||
property bool installed: toolbox.isInstalled(model.id)
|
|
||||||
width: detailList.width - UM.Theme.getSize("wide_margin").width
|
width: detailList.width - UM.Theme.getSize("wide_margin").width
|
||||||
height: normalData.height + compatibilityChart.height + 4 * UM.Theme.getSize("default_margin").height
|
height: normalData.height + compatibilityChart.height + 4 * UM.Theme.getSize("default_margin").height
|
||||||
Item
|
Item
|
||||||
|
@ -46,7 +45,7 @@ Item
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Item
|
ToolboxDetailTileActions
|
||||||
{
|
{
|
||||||
id: controls
|
id: controls
|
||||||
anchors.right: tile.right
|
anchors.right: tile.right
|
||||||
|
@ -54,28 +53,6 @@ Item
|
||||||
width: childrenRect.width
|
width: childrenRect.width
|
||||||
height: childrenRect.height
|
height: childrenRect.height
|
||||||
|
|
||||||
ToolboxProgressButton
|
|
||||||
{
|
|
||||||
id: installButton
|
|
||||||
active: toolbox.isDownloading && toolbox.activePackage == model
|
|
||||||
complete: tile.installed
|
|
||||||
readyAction: function()
|
|
||||||
{
|
|
||||||
toolbox.activePackage = model
|
|
||||||
toolbox.startDownload(model.download_url)
|
|
||||||
}
|
|
||||||
activeAction: function()
|
|
||||||
{
|
|
||||||
toolbox.cancelDownload()
|
|
||||||
}
|
|
||||||
completeAction: function()
|
|
||||||
{
|
|
||||||
toolbox.viewCategory = "installed"
|
|
||||||
}
|
|
||||||
// Don't allow installing while another download is running
|
|
||||||
enabled: installed || !(toolbox.isDownloading && toolbox.activePackage != model)
|
|
||||||
opacity: enabled ? 1.0 : 0.5
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ToolboxCompatibilityChart
|
ToolboxCompatibilityChart
|
||||||
|
@ -94,9 +71,4 @@ Item
|
||||||
anchors.top: compatibilityChart.bottom
|
anchors.top: compatibilityChart.bottom
|
||||||
anchors.topMargin: UM.Theme.getSize("default_margin").height + UM.Theme.getSize("wide_margin").height //Normal margin for spacing after chart, wide margin between items.
|
anchors.topMargin: UM.Theme.getSize("default_margin").height + UM.Theme.getSize("wide_margin").height //Normal margin for spacing after chart, wide margin between items.
|
||||||
}
|
}
|
||||||
Connections
|
|
||||||
{
|
|
||||||
target: toolbox
|
|
||||||
onInstallChanged: installed = toolbox.isInstalled(model.id)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
66
plugins/Toolbox/resources/qml/ToolboxDetailTileActions.qml
Normal file
66
plugins/Toolbox/resources/qml/ToolboxDetailTileActions.qml
Normal file
|
@ -0,0 +1,66 @@
|
||||||
|
// Copyright (c) 2018 Ultimaker B.V.
|
||||||
|
// Toolbox is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
|
import QtQuick 2.7
|
||||||
|
import QtQuick.Controls 1.4
|
||||||
|
import QtQuick.Controls.Styles 1.4
|
||||||
|
import UM 1.1 as UM
|
||||||
|
|
||||||
|
Column
|
||||||
|
{
|
||||||
|
property bool installed: toolbox.isInstalled(model.id)
|
||||||
|
property bool canUpdate: toolbox.canUpdate(model.id)
|
||||||
|
width: UM.Theme.getSize("toolbox_action_button").width
|
||||||
|
spacing: UM.Theme.getSize("narrow_margin").height
|
||||||
|
|
||||||
|
ToolboxProgressButton
|
||||||
|
{
|
||||||
|
id: installButton
|
||||||
|
active: toolbox.isDownloading && toolbox.activePackage == model
|
||||||
|
complete: installed
|
||||||
|
readyAction: function()
|
||||||
|
{
|
||||||
|
toolbox.activePackage = model
|
||||||
|
toolbox.startDownload(model.download_url)
|
||||||
|
}
|
||||||
|
activeAction: function()
|
||||||
|
{
|
||||||
|
toolbox.cancelDownload()
|
||||||
|
}
|
||||||
|
completeAction: function()
|
||||||
|
{
|
||||||
|
toolbox.viewCategory = "installed"
|
||||||
|
}
|
||||||
|
// Don't allow installing while another download is running
|
||||||
|
enabled: installed || !(toolbox.isDownloading && toolbox.activePackage != model)
|
||||||
|
opacity: enabled ? 1.0 : 0.5
|
||||||
|
}
|
||||||
|
|
||||||
|
ToolboxProgressButton
|
||||||
|
{
|
||||||
|
id: updateButton
|
||||||
|
active: toolbox.isDownloading && toolbox.activePackage == model
|
||||||
|
readyLabel: catalog.i18nc("@action:button", "Update")
|
||||||
|
activeLabel: catalog.i18nc("@action:button", "Updating")
|
||||||
|
completeLabel: catalog.i18nc("@action:button", "Updated")
|
||||||
|
readyAction: function()
|
||||||
|
{
|
||||||
|
toolbox.activePackage = model
|
||||||
|
toolbox.update(model.id)
|
||||||
|
}
|
||||||
|
activeAction: function()
|
||||||
|
{
|
||||||
|
toolbox.cancelDownload()
|
||||||
|
}
|
||||||
|
// Don't allow installing while another download is running
|
||||||
|
enabled: !(toolbox.isDownloading && toolbox.activePackage != model)
|
||||||
|
opacity: enabled ? 1.0 : 0.5
|
||||||
|
visible: installed && canUpdate
|
||||||
|
}
|
||||||
|
Connections
|
||||||
|
{
|
||||||
|
target: toolbox
|
||||||
|
onInstallChanged: installed = toolbox.isInstalled(model.id)
|
||||||
|
onMetadataChanged: canUpdate = toolbox.canUpdate(model.id)
|
||||||
|
}
|
||||||
|
}
|
|
@ -15,7 +15,7 @@ Column
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
id: heading
|
id: heading
|
||||||
text: toolbox.viewCategory == "material" ? catalog.i18nc("@label", "Maker Choices") : catalog.i18nc("@label", "Community Plugins")
|
text: toolbox.viewCategory == "material" ? catalog.i18nc("@label", "Community contributions") : catalog.i18nc("@label", "Community plugins")
|
||||||
width: parent.width
|
width: parent.width
|
||||||
color: UM.Theme.getColor("text_medium")
|
color: UM.Theme.getColor("text_medium")
|
||||||
font: UM.Theme.getFont("medium")
|
font: UM.Theme.getFont("medium")
|
||||||
|
|
|
@ -10,7 +10,6 @@ Item
|
||||||
{
|
{
|
||||||
height: UM.Theme.getSize("toolbox_installed_tile").height
|
height: UM.Theme.getSize("toolbox_installed_tile").height
|
||||||
width: parent.width
|
width: parent.width
|
||||||
property bool canUpdate: false
|
|
||||||
property bool isEnabled: true
|
property bool isEnabled: true
|
||||||
|
|
||||||
Rectangle
|
Rectangle
|
||||||
|
@ -109,7 +108,6 @@ Item
|
||||||
{
|
{
|
||||||
target: toolbox
|
target: toolbox
|
||||||
onEnabledChanged: isEnabled = toolbox.isEnabled(model.id)
|
onEnabledChanged: isEnabled = toolbox.isEnabled(model.id)
|
||||||
onMetadataChanged: canUpdate = toolbox.canUpdate(model.id)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -8,6 +8,8 @@ import UM 1.1 as UM
|
||||||
|
|
||||||
Column
|
Column
|
||||||
{
|
{
|
||||||
|
property bool canUpdate: false
|
||||||
|
property bool canDowngrade: false
|
||||||
width: UM.Theme.getSize("toolbox_action_button").width
|
width: UM.Theme.getSize("toolbox_action_button").width
|
||||||
spacing: UM.Theme.getSize("narrow_margin").height
|
spacing: UM.Theme.getSize("narrow_margin").height
|
||||||
|
|
||||||
|
@ -36,7 +38,7 @@ Column
|
||||||
Button
|
Button
|
||||||
{
|
{
|
||||||
id: removeButton
|
id: removeButton
|
||||||
text: catalog.i18nc("@action:button", "Uninstall")
|
text: canDowngrade ? catalog.i18nc("@action:button", "Downgrade") : catalog.i18nc("@action:button", "Uninstall")
|
||||||
visible: !model.is_bundled
|
visible: !model.is_bundled
|
||||||
enabled: !toolbox.isDownloading
|
enabled: !toolbox.isDownloading
|
||||||
style: ButtonStyle
|
style: ButtonStyle
|
||||||
|
@ -49,7 +51,17 @@ Column
|
||||||
border
|
border
|
||||||
{
|
{
|
||||||
width: UM.Theme.getSize("default_lining").width
|
width: UM.Theme.getSize("default_lining").width
|
||||||
color: UM.Theme.getColor("lining")
|
color:
|
||||||
|
{
|
||||||
|
if (control.hovered)
|
||||||
|
{
|
||||||
|
return UM.Theme.getColor("primary_hover")
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return UM.Theme.getColor("lining")
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
label: Label
|
label: Label
|
||||||
|
@ -58,8 +70,18 @@ Column
|
||||||
color: UM.Theme.getColor("text")
|
color: UM.Theme.getColor("text")
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
horizontalAlignment: Text.AlignHCenter
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
font: UM.Theme.getFont("default")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
onClicked: toolbox.uninstall(model.id)
|
onClicked: toolbox.uninstall(model.id)
|
||||||
|
Connections
|
||||||
|
{
|
||||||
|
target: toolbox
|
||||||
|
onMetadataChanged:
|
||||||
|
{
|
||||||
|
canUpdate = toolbox.canUpdate(model.id)
|
||||||
|
canDowngrade = toolbox.canDowngrade(model.id)
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -68,7 +68,7 @@ Item
|
||||||
{
|
{
|
||||||
if (base.complete)
|
if (base.complete)
|
||||||
{
|
{
|
||||||
return UM.Theme.getColor("action_button_disabled")
|
return "transparent"
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -82,6 +82,31 @@ Item
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
border
|
||||||
|
{
|
||||||
|
width:
|
||||||
|
{
|
||||||
|
if (base.complete)
|
||||||
|
{
|
||||||
|
UM.Theme.getSize("default_lining").width
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
color:
|
||||||
|
{
|
||||||
|
if (control.hovered)
|
||||||
|
{
|
||||||
|
return UM.Theme.getColor("primary_hover")
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return UM.Theme.getColor("lining")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
label: Label
|
label: Label
|
||||||
{
|
{
|
||||||
|
@ -90,7 +115,7 @@ Item
|
||||||
{
|
{
|
||||||
if (base.complete)
|
if (base.complete)
|
||||||
{
|
{
|
||||||
return UM.Theme.getColor("action_button_disabled_text")
|
return UM.Theme.getColor("text")
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -106,7 +131,17 @@ Item
|
||||||
}
|
}
|
||||||
verticalAlignment: Text.AlignVCenter
|
verticalAlignment: Text.AlignVCenter
|
||||||
horizontalAlignment: Text.AlignHCenter
|
horizontalAlignment: Text.AlignHCenter
|
||||||
font: UM.Theme.getFont("default_bold")
|
font:
|
||||||
|
{
|
||||||
|
if (base.complete)
|
||||||
|
{
|
||||||
|
return UM.Theme.getFont("default")
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return UM.Theme.getFont("default_bold")
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -300,6 +300,20 @@ class Toolbox(QObject, Extension):
|
||||||
remote_version = Version(remote_package["package_version"])
|
remote_version = Version(remote_package["package_version"])
|
||||||
return remote_version > local_version
|
return remote_version > local_version
|
||||||
|
|
||||||
|
@pyqtSlot(str, result=bool)
|
||||||
|
def canDowngrade(self, package_id: str) -> bool:
|
||||||
|
local_package = self._package_manager.getInstalledPackageInfo(package_id)
|
||||||
|
if local_package is None:
|
||||||
|
return False
|
||||||
|
|
||||||
|
remote_package = self.getRemotePackage(package_id)
|
||||||
|
if remote_package is None:
|
||||||
|
return False
|
||||||
|
|
||||||
|
local_version = Version(local_package["package_version"])
|
||||||
|
remote_version = Version(remote_package["package_version"])
|
||||||
|
return remote_version < local_version
|
||||||
|
|
||||||
@pyqtSlot(str, result = bool)
|
@pyqtSlot(str, result = bool)
|
||||||
def isInstalled(self, package_id: str) -> bool:
|
def isInstalled(self, package_id: str) -> bool:
|
||||||
return self._package_manager.isPackageInstalled(package_id)
|
return self._package_manager.isPackageInstalled(package_id)
|
||||||
|
|
|
@ -45,6 +45,8 @@ class DiscoverUM3Action(MachineAction):
|
||||||
@pyqtSlot()
|
@pyqtSlot()
|
||||||
def reset(self):
|
def reset(self):
|
||||||
Logger.log("d", "Reset the list of found devices.")
|
Logger.log("d", "Reset the list of found devices.")
|
||||||
|
if self._network_plugin:
|
||||||
|
self._network_plugin.resetLastManualDevice()
|
||||||
self.discoveredDevicesChanged.emit()
|
self.discoveredDevicesChanged.emit()
|
||||||
|
|
||||||
@pyqtSlot()
|
@pyqtSlot()
|
||||||
|
@ -83,15 +85,8 @@ class DiscoverUM3Action(MachineAction):
|
||||||
@pyqtProperty("QVariantList", notify = discoveredDevicesChanged)
|
@pyqtProperty("QVariantList", notify = discoveredDevicesChanged)
|
||||||
def foundDevices(self):
|
def foundDevices(self):
|
||||||
if self._network_plugin:
|
if self._network_plugin:
|
||||||
# TODO: Check if this needs to stay.
|
|
||||||
if Application.getInstance().getGlobalContainerStack():
|
|
||||||
global_printer_type = Application.getInstance().getGlobalContainerStack().getBottom().getId()
|
|
||||||
else:
|
|
||||||
global_printer_type = "unknown"
|
|
||||||
|
|
||||||
printers = list(self._network_plugin.getDiscoveredDevices().values())
|
printers = list(self._network_plugin.getDiscoveredDevices().values())
|
||||||
# TODO; There are still some testing printers that don't have a correct printer type, so don't filter out unkown ones just yet.
|
|
||||||
#printers = [printer for printer in printers if printer.printerType == global_printer_type or printer.printerType == "unknown"]
|
|
||||||
printers.sort(key = lambda k: k.name)
|
printers.sort(key = lambda k: k.name)
|
||||||
return printers
|
return printers
|
||||||
else:
|
else:
|
||||||
|
@ -138,7 +133,7 @@ class DiscoverUM3Action(MachineAction):
|
||||||
self._network_plugin.reCheckConnections()
|
self._network_plugin.reCheckConnections()
|
||||||
|
|
||||||
@pyqtSlot(result = str)
|
@pyqtSlot(result = str)
|
||||||
def getStoredKey(self):
|
def getStoredKey(self) -> str:
|
||||||
global_container_stack = Application.getInstance().getGlobalContainerStack()
|
global_container_stack = Application.getInstance().getGlobalContainerStack()
|
||||||
if global_container_stack:
|
if global_container_stack:
|
||||||
meta_data = global_container_stack.getMetaData()
|
meta_data = global_container_stack.getMetaData()
|
||||||
|
@ -147,6 +142,12 @@ class DiscoverUM3Action(MachineAction):
|
||||||
|
|
||||||
return ""
|
return ""
|
||||||
|
|
||||||
|
@pyqtSlot(result = str)
|
||||||
|
def getLastManualEntryKey(self) -> str:
|
||||||
|
if self._network_plugin:
|
||||||
|
return self._network_plugin.getLastManualDevice()
|
||||||
|
return ""
|
||||||
|
|
||||||
@pyqtSlot(str, result = bool)
|
@pyqtSlot(str, result = bool)
|
||||||
def existsKey(self, key) -> bool:
|
def existsKey(self, key) -> bool:
|
||||||
return Application.getInstance().getMachineManager().existNetworkInstances(network_key = key)
|
return Application.getInstance().getMachineManager().existNetworkInstances(network_key = key)
|
||||||
|
|
|
@ -158,7 +158,10 @@ Cura.MachineAction
|
||||||
model: manager.foundDevices
|
model: manager.foundDevices
|
||||||
onModelChanged:
|
onModelChanged:
|
||||||
{
|
{
|
||||||
var selectedKey = manager.getStoredKey();
|
var selectedKey = manager.getLastManualEntryKey()
|
||||||
|
// If there is no last manual entry key, then we select the stored key (if any)
|
||||||
|
if (selectedKey == "")
|
||||||
|
selectedKey = manager.getStoredKey()
|
||||||
for(var i = 0; i < model.length; i++) {
|
for(var i = 0; i < model.length; i++) {
|
||||||
if(model[i].key == selectedKey)
|
if(model[i].key == selectedKey)
|
||||||
{
|
{
|
||||||
|
@ -354,12 +357,10 @@ Cura.MachineAction
|
||||||
onShowDialog:
|
onShowDialog:
|
||||||
{
|
{
|
||||||
printerKey = key;
|
printerKey = key;
|
||||||
|
|
||||||
addressText = address;
|
addressText = address;
|
||||||
|
manualPrinterDialog.show();
|
||||||
addressField.selectAll();
|
addressField.selectAll();
|
||||||
addressField.focus = true;
|
addressField.focus = true;
|
||||||
|
|
||||||
manualPrinterDialog.show();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
onAccepted:
|
onAccepted:
|
||||||
|
|
|
@ -59,6 +59,9 @@ class UM3OutputDevicePlugin(OutputDevicePlugin):
|
||||||
|
|
||||||
self._manual_instances = self._preferences.getValue("um3networkprinting/manual_instances").split(",")
|
self._manual_instances = self._preferences.getValue("um3networkprinting/manual_instances").split(",")
|
||||||
|
|
||||||
|
# Store the last manual entry key
|
||||||
|
self._last_manual_entry_key = "" # type: str
|
||||||
|
|
||||||
# The zero-conf service changed requests are handled in a separate thread, so we can re-schedule the requests
|
# The zero-conf service changed requests are handled in a separate thread, so we can re-schedule the requests
|
||||||
# which fail to get detailed service info.
|
# which fail to get detailed service info.
|
||||||
# Any new or re-scheduled requests will be appended to the request queue, and the handling thread will pick
|
# Any new or re-scheduled requests will be appended to the request queue, and the handling thread will pick
|
||||||
|
@ -71,6 +74,12 @@ class UM3OutputDevicePlugin(OutputDevicePlugin):
|
||||||
def getDiscoveredDevices(self):
|
def getDiscoveredDevices(self):
|
||||||
return self._discovered_devices
|
return self._discovered_devices
|
||||||
|
|
||||||
|
def getLastManualDevice(self) -> str:
|
||||||
|
return self._last_manual_entry_key
|
||||||
|
|
||||||
|
def resetLastManualDevice(self) -> None:
|
||||||
|
self._last_manual_entry_key = ""
|
||||||
|
|
||||||
## Start looking for devices on network.
|
## Start looking for devices on network.
|
||||||
def start(self):
|
def start(self):
|
||||||
self.startDiscovery()
|
self.startDiscovery()
|
||||||
|
@ -92,6 +101,7 @@ class UM3OutputDevicePlugin(OutputDevicePlugin):
|
||||||
for address in self._manual_instances:
|
for address in self._manual_instances:
|
||||||
if address:
|
if address:
|
||||||
self.addManualDevice(address)
|
self.addManualDevice(address)
|
||||||
|
self.resetLastManualDevice()
|
||||||
|
|
||||||
def reCheckConnections(self):
|
def reCheckConnections(self):
|
||||||
active_machine = Application.getInstance().getGlobalContainerStack()
|
active_machine = Application.getInstance().getGlobalContainerStack()
|
||||||
|
@ -135,6 +145,7 @@ class UM3OutputDevicePlugin(OutputDevicePlugin):
|
||||||
if not address:
|
if not address:
|
||||||
address = self._discovered_devices[key].ipAddress
|
address = self._discovered_devices[key].ipAddress
|
||||||
self._onRemoveDevice(key)
|
self._onRemoveDevice(key)
|
||||||
|
self.resetLastManualDevice()
|
||||||
|
|
||||||
if address in self._manual_instances:
|
if address in self._manual_instances:
|
||||||
self._manual_instances.remove(address)
|
self._manual_instances.remove(address)
|
||||||
|
@ -156,6 +167,7 @@ class UM3OutputDevicePlugin(OutputDevicePlugin):
|
||||||
if instance_name not in self._discovered_devices:
|
if instance_name not in self._discovered_devices:
|
||||||
# Add a preliminary printer instance
|
# Add a preliminary printer instance
|
||||||
self._onAddDevice(instance_name, address, properties)
|
self._onAddDevice(instance_name, address, properties)
|
||||||
|
self._last_manual_entry_key = instance_name
|
||||||
|
|
||||||
self._checkManualDevice(address)
|
self._checkManualDevice(address)
|
||||||
|
|
||||||
|
|
|
@ -514,7 +514,7 @@ class XmlMaterialProfile(InstanceContainer):
|
||||||
color = entry.find("./um:color", self.__namespaces)
|
color = entry.find("./um:color", self.__namespaces)
|
||||||
label = entry.find("./um:label", self.__namespaces)
|
label = entry.find("./um:label", self.__namespaces)
|
||||||
|
|
||||||
if label is not None:
|
if label is not None and label.text is not None:
|
||||||
meta_data["name"] = label.text
|
meta_data["name"] = label.text
|
||||||
else:
|
else:
|
||||||
meta_data["name"] = self._profile_name(material.text, color.text)
|
meta_data["name"] = self._profile_name(material.text, color.text)
|
||||||
|
@ -805,7 +805,7 @@ class XmlMaterialProfile(InstanceContainer):
|
||||||
color = entry.find("./um:color", cls.__namespaces)
|
color = entry.find("./um:color", cls.__namespaces)
|
||||||
label = entry.find("./um:label", cls.__namespaces)
|
label = entry.find("./um:label", cls.__namespaces)
|
||||||
|
|
||||||
if label is not None:
|
if label is not None and label.text is not None:
|
||||||
base_metadata["name"] = label.text
|
base_metadata["name"] = label.text
|
||||||
else:
|
else:
|
||||||
base_metadata["name"] = cls._profile_name(material.text, color.text)
|
base_metadata["name"] = cls._profile_name(material.text, color.text)
|
||||||
|
|
|
@ -5772,6 +5772,27 @@
|
||||||
"limit_to_extruder": "infill_extruder_nr",
|
"limit_to_extruder": "infill_extruder_nr",
|
||||||
"settable_per_mesh": true
|
"settable_per_mesh": true
|
||||||
},
|
},
|
||||||
|
"cross_infill_density_image":
|
||||||
|
{
|
||||||
|
"label": "Cross Infill Density Image",
|
||||||
|
"description": "The file location of an image of which the brightness values determine the minimal density at the corresponding location in the infill of the print.",
|
||||||
|
"type": "str",
|
||||||
|
"default_value": "",
|
||||||
|
"enabled": "infill_pattern == 'cross' or infill_pattern == 'cross_3d'",
|
||||||
|
"limit_to_extruder": "infill_extruder_nr",
|
||||||
|
"settable_per_mesh": true
|
||||||
|
},
|
||||||
|
"cross_support_density_image":
|
||||||
|
{
|
||||||
|
"label": "Cross Fill Density Image for Support",
|
||||||
|
"description": "The file location of an image of which the brightness values determine the minimal density at the corresponding location in the support.",
|
||||||
|
"type": "str",
|
||||||
|
"default_value": "",
|
||||||
|
"enabled": "infill_pattern == 'cross' or infill_pattern == 'cross_3d'",
|
||||||
|
"limit_to_extruder": "support_infill_extruder_nr",
|
||||||
|
"settable_per_mesh": false,
|
||||||
|
"settable_per_extruder": true
|
||||||
|
},
|
||||||
"spaghetti_infill_enabled":
|
"spaghetti_infill_enabled":
|
||||||
{
|
{
|
||||||
"label": "Spaghetti Infill",
|
"label": "Spaghetti Infill",
|
||||||
|
|
|
@ -323,6 +323,21 @@ UM.MainWindow
|
||||||
{
|
{
|
||||||
if (drop.urls.length > 0)
|
if (drop.urls.length > 0)
|
||||||
{
|
{
|
||||||
|
// As the drop area also supports plugins, first check if it's a plugin that was dropped.
|
||||||
|
if (drop.urls.length == 1)
|
||||||
|
{
|
||||||
|
var filename = drop.urls[0];
|
||||||
|
if (filename.endsWith(".curapackage"))
|
||||||
|
{
|
||||||
|
// Try to install plugin & close.
|
||||||
|
CuraApplication.getCuraPackageManager().installPackageViaDragAndDrop(filename);
|
||||||
|
packageInstallDialog.text = catalog.i18nc("@label", "This package will be installed after restarting.");
|
||||||
|
packageInstallDialog.icon = StandardIcon.Information;
|
||||||
|
packageInstallDialog.open();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
openDialog.handleOpenFileUrls(drop.urls);
|
openDialog.handleOpenFileUrls(drop.urls);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -489,6 +504,7 @@ UM.MainWindow
|
||||||
horizontalCenterOffset: -(Math.round(UM.Theme.getSize("sidebar").width / 2))
|
horizontalCenterOffset: -(Math.round(UM.Theme.getSize("sidebar").width / 2))
|
||||||
top: parent.verticalCenter;
|
top: parent.verticalCenter;
|
||||||
bottom: parent.bottom;
|
bottom: parent.bottom;
|
||||||
|
bottomMargin: UM.Theme.getSize("default_margin").height
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -789,6 +805,14 @@ UM.MainWindow
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MessageDialog
|
||||||
|
{
|
||||||
|
id: packageInstallDialog
|
||||||
|
title: catalog.i18nc("@window:title", "Install Package");
|
||||||
|
standardButtons: StandardButton.Ok
|
||||||
|
modality: Qt.ApplicationModal
|
||||||
|
}
|
||||||
|
|
||||||
MessageDialog {
|
MessageDialog {
|
||||||
id: infoMultipleFilesWithGcodeDialog
|
id: infoMultipleFilesWithGcodeDialog
|
||||||
title: catalog.i18nc("@title:window", "Open File(s)")
|
title: catalog.i18nc("@title:window", "Open File(s)")
|
||||||
|
|
|
@ -67,7 +67,7 @@ Column
|
||||||
HeatedBedBox
|
HeatedBedBox
|
||||||
{
|
{
|
||||||
visible: {
|
visible: {
|
||||||
if(activePrinter != null && activePrinter.bed_temperature != -1)
|
if(activePrinter != null && activePrinter.bedTemperature != -1)
|
||||||
{
|
{
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
// Copyright (c) 2016 Ultimaker B.V.
|
// Copyright (c) 2018 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.
|
||||||
|
|
||||||
import QtQuick 2.1
|
import QtQuick 2.1
|
||||||
|
@ -61,32 +61,34 @@ UM.Dialog
|
||||||
{
|
{
|
||||||
id: palette
|
id: palette
|
||||||
}
|
}
|
||||||
|
|
||||||
Column
|
|
||||||
{
|
|
||||||
anchors.fill: parent
|
|
||||||
spacing: 2 * screenScaleFactor
|
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
id: titleLabel
|
id: mainHeading
|
||||||
|
width: parent.width
|
||||||
text: catalog.i18nc("@action:title", "Summary - Cura Project")
|
text: catalog.i18nc("@action:title", "Summary - Cura Project")
|
||||||
font.pointSize: 18
|
font.pointSize: 18
|
||||||
|
anchors.top: parent.top
|
||||||
}
|
}
|
||||||
Rectangle
|
ScrollView
|
||||||
{
|
{
|
||||||
id: separator
|
id: scroll
|
||||||
color: palette.text
|
|
||||||
width: parent.width
|
width: parent.width
|
||||||
height: 1
|
anchors
|
||||||
}
|
|
||||||
Item // Spacer
|
|
||||||
{
|
{
|
||||||
height: spacerHeight
|
top: mainHeading.bottom
|
||||||
width: height
|
topMargin: UM.Theme.getSize("default_margin").height
|
||||||
|
bottom: controls.top
|
||||||
|
bottomMargin: UM.Theme.getSize("default_margin").height
|
||||||
}
|
}
|
||||||
|
style: UM.Theme.styles.scrollview
|
||||||
|
ColumnLayout
|
||||||
|
{
|
||||||
|
spacing: UM.Theme.getSize("default_margin").height
|
||||||
|
Column
|
||||||
|
{
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
|
id: settingsHeading
|
||||||
text: catalog.i18nc("@action:label", "Printer settings")
|
text: catalog.i18nc("@action:label", "Printer settings")
|
||||||
font.bold: true
|
font.bold: true
|
||||||
}
|
}
|
||||||
|
@ -97,12 +99,12 @@ UM.Dialog
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Type")
|
text: catalog.i18nc("@action:label", "Type")
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: (Cura.MachineManager.activeMachine == null) ? "" : Cura.MachineManager.activeMachine.definition.name
|
text: (Cura.MachineManager.activeMachine == null) ? "" : Cura.MachineManager.activeMachine.definition.name
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Row
|
Row
|
||||||
|
@ -112,56 +114,45 @@ UM.Dialog
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", Cura.MachineManager.activeMachineNetworkGroupName != "" ? "Printer Group" : "Name")
|
text: catalog.i18nc("@action:label", Cura.MachineManager.activeMachineNetworkGroupName != "" ? "Printer Group" : "Name")
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: Cura.MachineManager.activeMachineNetworkGroupName != "" ? Cura.MachineManager.activeMachineNetworkGroupName : Cura.MachineManager.activeMachineName
|
text: Cura.MachineManager.activeMachineNetworkGroupName != "" ? Cura.MachineManager.activeMachineNetworkGroupName : Cura.MachineManager.activeMachineName
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Column
|
|
||||||
{
|
|
||||||
width: parent.width
|
|
||||||
visible: Cura.MachineManager.hasVariantBuildplates
|
|
||||||
Item // Spacer
|
|
||||||
{
|
|
||||||
height: spacerHeight
|
|
||||||
width: height
|
|
||||||
}
|
}
|
||||||
Row
|
Row
|
||||||
{
|
{
|
||||||
|
visible: Cura.MachineManager.hasVariantBuildplates
|
||||||
width: parent.width
|
width: parent.width
|
||||||
height: childrenRect.height
|
height: childrenRect.height
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Build plate")
|
text: catalog.i18nc("@action:label", "Build plate")
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: Cura.MachineManager.activeVariantBuildplateName
|
text: Cura.MachineManager.activeVariantBuildplateName
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
Repeater
|
Repeater
|
||||||
{
|
{
|
||||||
|
width: parent.width
|
||||||
|
height: childrenRect.height
|
||||||
model: Cura.MachineManager.currentExtruderPositions
|
model: Cura.MachineManager.currentExtruderPositions
|
||||||
delegate: Column
|
delegate: Column
|
||||||
{
|
{
|
||||||
Item // Spacer
|
height: childrenRect.height
|
||||||
{
|
width: parent.width
|
||||||
height: spacerHeight
|
|
||||||
width: height
|
|
||||||
}
|
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Extruder %1").arg(modelData)
|
text: catalog.i18nc("@action:label", "Extruder %1").arg(modelData)
|
||||||
|
font.bold: true
|
||||||
}
|
}
|
||||||
height: childrenRect.height
|
|
||||||
width: parent.width
|
|
||||||
Row
|
Row
|
||||||
{
|
{
|
||||||
width: parent.width
|
width: parent.width
|
||||||
|
@ -169,23 +160,20 @@ UM.Dialog
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "%1 & material").arg(Cura.MachineManager.activeDefinitionVariantsName)
|
text: catalog.i18nc("@action:label", "%1 & material").arg(Cura.MachineManager.activeDefinitionVariantsName)
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: Cura.MachineManager.activeVariantNames[modelData] + ", " + Cura.MachineManager.getExtruder(modelData).material.name
|
text: Cura.MachineManager.activeVariantNames[modelData] + ", " + Cura.MachineManager.getExtruder(modelData).material.name
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Column
|
||||||
Item // Spacer
|
|
||||||
{
|
{
|
||||||
height: spacerHeight
|
width: parent.width
|
||||||
width: height
|
height: childrenRect.height
|
||||||
}
|
|
||||||
|
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Profile settings")
|
text: catalog.i18nc("@action:label", "Profile settings")
|
||||||
|
@ -197,12 +185,12 @@ UM.Dialog
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Not in profile")
|
text: catalog.i18nc("@action:label", "Not in profile")
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18ncp("@action:label", "%1 override", "%1 overrides", Cura.MachineManager.numUserSettings).arg(Cura.MachineManager.numUserSettings)
|
text: catalog.i18ncp("@action:label", "%1 override", "%1 overrides", Cura.MachineManager.numUserSettings).arg(Cura.MachineManager.numUserSettings)
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
visible: Cura.MachineManager.numUserSettings
|
visible: Cura.MachineManager.numUserSettings
|
||||||
}
|
}
|
||||||
|
@ -213,22 +201,20 @@ UM.Dialog
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Name")
|
text: catalog.i18nc("@action:label", "Name")
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: Cura.MachineManager.activeQualityOrQualityChangesName
|
text: Cura.MachineManager.activeQualityOrQualityChangesName
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
Item // Spacer
|
Column
|
||||||
{
|
{
|
||||||
height: spacerHeight
|
width: parent.width
|
||||||
width: height
|
height: childrenRect.height
|
||||||
}
|
|
||||||
|
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Setting visibility")
|
text: catalog.i18nc("@action:label", "Setting visibility")
|
||||||
|
@ -241,57 +227,54 @@ UM.Dialog
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "Visible settings:")
|
text: catalog.i18nc("@action:label", "Visible settings:")
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@action:label", "%1 out of %2" ).arg(definitionsModel.visibleCount).arg(Cura.MachineManager.totalNumberOfSettings)
|
text: catalog.i18nc("@action:label", "%1 out of %2" ).arg(definitionsModel.visibleCount).arg(Cura.MachineManager.totalNumberOfSettings)
|
||||||
width: (parent.width / 3) | 0
|
width: Math.floor(scroll.width / 3) | 0
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
Item // Spacer
|
}
|
||||||
|
}
|
||||||
|
Item
|
||||||
{
|
{
|
||||||
height: spacerHeight
|
id: controls
|
||||||
width: height
|
width: parent.width
|
||||||
}
|
height: childrenRect.height
|
||||||
}
|
anchors.bottom: parent.bottom
|
||||||
|
|
||||||
CheckBox
|
CheckBox
|
||||||
{
|
{
|
||||||
id: dontShowAgainCheckbox
|
id: dontShowAgainCheckbox
|
||||||
anchors.bottom: cancel_button.top
|
|
||||||
anchors.bottomMargin: UM.Theme.getSize("default_margin").height
|
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
|
|
||||||
text: catalog.i18nc("@action:label", "Don't show project summary on save again")
|
text: catalog.i18nc("@action:label", "Don't show project summary on save again")
|
||||||
checked: dontShowAgain
|
checked: dontShowAgain
|
||||||
}
|
}
|
||||||
|
|
||||||
Button
|
Button
|
||||||
{
|
{
|
||||||
id: cancel_button
|
id: cancel_button
|
||||||
anchors.bottom: parent.bottom
|
anchors
|
||||||
anchors.right: ok_button.left
|
{
|
||||||
anchors.rightMargin: 2
|
right: ok_button.left
|
||||||
|
rightMargin: UM.Theme.getSize("default_margin").width
|
||||||
|
}
|
||||||
text: catalog.i18nc("@action:button","Cancel");
|
text: catalog.i18nc("@action:button","Cancel");
|
||||||
enabled: true
|
enabled: true
|
||||||
onClicked: close()
|
onClicked: close()
|
||||||
}
|
}
|
||||||
|
|
||||||
Button
|
Button
|
||||||
{
|
{
|
||||||
id: ok_button
|
id: ok_button
|
||||||
anchors.bottom: parent.bottom
|
|
||||||
anchors.right: parent.right
|
anchors.right: parent.right
|
||||||
|
|
||||||
text: catalog.i18nc("@action:button","Save");
|
text: catalog.i18nc("@action:button","Save");
|
||||||
enabled: true
|
enabled: true
|
||||||
onClicked: {
|
onClicked:
|
||||||
|
{
|
||||||
close()
|
close()
|
||||||
yes()
|
yes()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
|
@ -25,9 +25,9 @@ fragment =
|
||||||
highp float distance_to_camera = distance(v_vertex, u_viewPosition) * 1000.; // distance in micron
|
highp float distance_to_camera = distance(v_vertex, u_viewPosition) * 1000.; // distance in micron
|
||||||
|
|
||||||
vec3 encoded; // encode float into 3 8-bit channels; this gives a precision of a micron at a range of up to ~16 meter
|
vec3 encoded; // encode float into 3 8-bit channels; this gives a precision of a micron at a range of up to ~16 meter
|
||||||
encoded.b = floor(distance_to_camera / 65536.0);
|
encoded.r = floor(distance_to_camera / 65536.0);
|
||||||
encoded.g = floor((distance_to_camera - encoded.b * 65536.0) / 256.0);
|
encoded.g = floor((distance_to_camera - encoded.r * 65536.0) / 256.0);
|
||||||
encoded.r = floor(distance_to_camera - encoded.b * 65536.0 - encoded.g * 256.0);
|
encoded.b = floor(distance_to_camera - encoded.r * 65536.0 - encoded.g * 256.0);
|
||||||
|
|
||||||
gl_FragColor.rgb = encoded / 255.;
|
gl_FragColor.rgb = encoded / 255.;
|
||||||
gl_FragColor.a = 1.0;
|
gl_FragColor.a = 1.0;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue