mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-04-23 22:29:41 +08:00
Merge branch 'CURA-10475_engineplugin' into CURA-10446_modify_gcode_path
This commit is contained in:
commit
c1acfee5f1
@ -12,7 +12,7 @@
|
|||||||
|
|
||||||
[![Badge Test]][Test]
|
[![Badge Test]][Test]
|
||||||
[![Badge Conan]][Conan]
|
[![Badge Conan]][Conan]
|
||||||
|
![Badge Downloads]
|
||||||
<br>
|
<br>
|
||||||
<br>
|
<br>
|
||||||
|
|
||||||
@ -84,6 +84,7 @@
|
|||||||
[Badge Conan]: https://img.shields.io/github/workflow/status/Ultimaker/Cura/conan-package?style=for-the-badge&logoColor=white&labelColor=6185aa&color=4c6987&logo=Conan&label=Conan%20Package
|
[Badge Conan]: https://img.shields.io/github/workflow/status/Ultimaker/Cura/conan-package?style=for-the-badge&logoColor=white&labelColor=6185aa&color=4c6987&logo=Conan&label=Conan%20Package
|
||||||
[Badge Test]: https://img.shields.io/github/workflow/status/Ultimaker/Cura/unit-test?style=for-the-badge&logoColor=white&labelColor=4a999d&color=346c6e&logo=Codacy&label=Unit%20Test
|
[Badge Test]: https://img.shields.io/github/workflow/status/Ultimaker/Cura/unit-test?style=for-the-badge&logoColor=white&labelColor=4a999d&color=346c6e&logo=Codacy&label=Unit%20Test
|
||||||
[Badge Size]: https://img.shields.io/github/repo-size/ultimaker/cura?style=for-the-badge&logoColor=white&labelColor=715a97&color=584674&logo=GoogleAnalytics
|
[Badge Size]: https://img.shields.io/github/repo-size/ultimaker/cura?style=for-the-badge&logoColor=white&labelColor=715a97&color=584674&logo=GoogleAnalytics
|
||||||
|
[Badge Downloads]: https://img.shields.io/github/downloads-pre/Ultimaker/Cura/latest/total?style=for-the-badge
|
||||||
|
|
||||||
|
|
||||||
<!---------------------------------[ Buttons ]--------------------------------->
|
<!---------------------------------[ Buttons ]--------------------------------->
|
||||||
|
@ -468,6 +468,7 @@ echo "CURA_APP_NAME={{ cura_app_name }}" >> ${{ env_prefix }}GITHUB_ENV
|
|||||||
save(self, os.path.join(self._script_dir, f"activate_github_actions_version_env{ext}"), activate_github_actions_version_env)
|
save(self, os.path.join(self._script_dir, f"activate_github_actions_version_env{ext}"), activate_github_actions_version_env)
|
||||||
|
|
||||||
self._generate_cura_version(os.path.join(self._site_packages, "cura"))
|
self._generate_cura_version(os.path.join(self._site_packages, "cura"))
|
||||||
|
self._generate_about_versions(str(self._share_dir.joinpath("cura", "resources", "qml", "Dialogs")))
|
||||||
|
|
||||||
entitlements_file = "'{}'".format(Path(self.cpp_info.res_paths[2], "MacOS", "cura.entitlements"))
|
entitlements_file = "'{}'".format(Path(self.cpp_info.res_paths[2], "MacOS", "cura.entitlements"))
|
||||||
self._generate_pyinstaller_spec(location = self._base_dir,
|
self._generate_pyinstaller_spec(location = self._base_dir,
|
||||||
@ -475,7 +476,6 @@ echo "CURA_APP_NAME={{ cura_app_name }}" >> ${{ env_prefix }}GITHUB_ENV
|
|||||||
icon_path = "'{}'".format(os.path.join(self.package_folder, self.cpp_info.resdirs[2], self.conan_data["pyinstaller"]["icon"][str(self.settings.os)])).replace("\\", "\\\\"),
|
icon_path = "'{}'".format(os.path.join(self.package_folder, self.cpp_info.resdirs[2], self.conan_data["pyinstaller"]["icon"][str(self.settings.os)])).replace("\\", "\\\\"),
|
||||||
entitlements_file = entitlements_file if self.settings.os == "Macos" else "None")
|
entitlements_file = entitlements_file if self.settings.os == "Macos" else "None")
|
||||||
|
|
||||||
self._generate_about_versions(os.path.join(self.source_folder, "resources", "qml", "Dialogs"))
|
|
||||||
|
|
||||||
def package(self):
|
def package(self):
|
||||||
copy(self, "cura_app.py", src = self.source_folder, dst = os.path.join(self.package_folder, self.cpp.package.bindirs[0]))
|
copy(self, "cura_app.py", src = self.source_folder, dst = os.path.join(self.package_folder, self.cpp.package.bindirs[0]))
|
||||||
|
@ -4,6 +4,7 @@ import subprocess
|
|||||||
from typing import Optional, List
|
from typing import Optional, List
|
||||||
|
|
||||||
from UM.Logger import Logger
|
from UM.Logger import Logger
|
||||||
|
from UM.Message import Message
|
||||||
from UM.Settings.AdditionalSettingDefinitionAppender import AdditionalSettingDefinitionsAppender
|
from UM.Settings.AdditionalSettingDefinitionAppender import AdditionalSettingDefinitionsAppender
|
||||||
|
|
||||||
|
|
||||||
@ -57,13 +58,25 @@ class BackendPlugin(AdditionalSettingDefinitionsAppender):
|
|||||||
self._is_running = True
|
self._is_running = True
|
||||||
return True
|
return True
|
||||||
except PermissionError:
|
except PermissionError:
|
||||||
Logger.log("e", f"Couldn't start backend_plugin [{self._plugin_id}]: No permission to execute process.")
|
Logger.log("e", f"Couldn't start EnginePlugin: {self._plugin_id} No permission to execute process.")
|
||||||
|
self._showMessage(self.catalog.i18nc("@info:plugin_failed",
|
||||||
|
f"Couldn't start EnginePlugin: {self._plugin_id}\nNo permission to execute process."),
|
||||||
|
message_type = Message.MessageType.ERROR)
|
||||||
except FileNotFoundError:
|
except FileNotFoundError:
|
||||||
Logger.logException("e", f"Unable to find backend_plugin executable [{self._plugin_id}]")
|
Logger.logException("e", f"Unable to find local EnginePlugin server executable for: {self._plugin_id}")
|
||||||
|
self._showMessage(self.catalog.i18nc("@info:plugin_failed",
|
||||||
|
f"Unable to find local EnginePlugin server executable for: {self._plugin_id}"),
|
||||||
|
message_type = Message.MessageType.ERROR)
|
||||||
except BlockingIOError:
|
except BlockingIOError:
|
||||||
Logger.logException("e", f"Couldn't start backend_plugin [{self._plugin_id}]: Resource is temporarily unavailable")
|
Logger.logException("e", f"Couldn't start EnginePlugin: {self._plugin_id} Resource is temporarily unavailable")
|
||||||
|
self._showMessage(self.catalog.i18nc("@info:plugin_failed",
|
||||||
|
f"Couldn't start EnginePlugin: {self._plugin_id}\nResource is temporarily unavailable"),
|
||||||
|
message_type = Message.MessageType.ERROR)
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
Logger.logException("e", f"Couldn't start backend_plugin [{self._plugin_id}]: Operating system is blocking it (antivirus?)")
|
Logger.logException("e", f"Couldn't start EnginePlugin {self._plugin_id} Operating system is blocking it (antivirus?)")
|
||||||
|
self._showMessage(self.catalog.i18nc("@info:plugin_failed",
|
||||||
|
f"Couldn't start EnginePlugin: {self._plugin_id}\nOperating system is blocking it (antivirus?)"),
|
||||||
|
message_type = Message.MessageType.ERROR)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def stop(self) -> bool:
|
def stop(self) -> bool:
|
||||||
@ -75,8 +88,15 @@ class BackendPlugin(AdditionalSettingDefinitionsAppender):
|
|||||||
self._process.terminate()
|
self._process.terminate()
|
||||||
return_code = self._process.wait()
|
return_code = self._process.wait()
|
||||||
self._is_running = False
|
self._is_running = False
|
||||||
Logger.log("d", f"Backend_plugin [{self._plugin_id}] was killed. Received return code {return_code}")
|
Logger.log("d", f"EnginePlugin: {self._plugin_id} was killed. Received return code {return_code}")
|
||||||
return True
|
return True
|
||||||
except PermissionError:
|
except PermissionError:
|
||||||
Logger.log("e", "Unable to kill running engine. Access is denied.")
|
Logger.log("e", f"Unable to kill running EnginePlugin: {self._plugin_id} Access is denied.")
|
||||||
|
self._showMessage(self.catalog.i18nc("@info:plugin_failed",
|
||||||
|
f"Unable to kill running EnginePlugin: {self._plugin_id}\nAccess is denied."),
|
||||||
|
message_type = Message.MessageType.ERROR)
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
def _showMessage(self, message: str, message_type: Message.MessageType = Message.MessageType.ERROR) -> None:
|
||||||
|
Message(message, title=self.catalog.i18nc("@info:title", "EnginePlugin"), message_type = message_type).show()
|
||||||
|
|
||||||
|
@ -1,15 +1,18 @@
|
|||||||
# Copyright (c) 2018 Ultimaker B.V.
|
# Copyright (c) 2023 UltiMaker
|
||||||
# Cura is released under the terms of the LGPLv3 or higher.
|
# Cura is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
from PyQt6.QtCore import QObject, QUrl
|
|
||||||
from PyQt6.QtGui import QDesktopServices
|
|
||||||
from typing import List, cast
|
from typing import List, cast
|
||||||
|
|
||||||
|
from PyQt6.QtCore import QObject, QUrl, QMimeData
|
||||||
|
from PyQt6.QtGui import QDesktopServices
|
||||||
|
from PyQt6.QtWidgets import QApplication
|
||||||
|
|
||||||
from UM.Event import CallFunctionEvent
|
from UM.Event import CallFunctionEvent
|
||||||
from UM.FlameProfiler import pyqtSlot
|
from UM.FlameProfiler import pyqtSlot
|
||||||
from UM.Math.Vector import Vector
|
from UM.Math.Vector import Vector
|
||||||
from UM.Scene.Selection import Selection
|
from UM.Scene.Selection import Selection
|
||||||
from UM.Scene.Iterator.BreadthFirstIterator import BreadthFirstIterator
|
from UM.Scene.Iterator.BreadthFirstIterator import BreadthFirstIterator
|
||||||
|
from UM.Scene.Iterator.DepthFirstIterator import DepthFirstIterator
|
||||||
from UM.Operations.GroupedOperation import GroupedOperation
|
from UM.Operations.GroupedOperation import GroupedOperation
|
||||||
from UM.Operations.RemoveSceneNodeOperation import RemoveSceneNodeOperation
|
from UM.Operations.RemoveSceneNodeOperation import RemoveSceneNodeOperation
|
||||||
from UM.Operations.TranslateOperation import TranslateOperation
|
from UM.Operations.TranslateOperation import TranslateOperation
|
||||||
@ -19,6 +22,7 @@ from cura.Operations.SetParentOperation import SetParentOperation
|
|||||||
from cura.MultiplyObjectsJob import MultiplyObjectsJob
|
from cura.MultiplyObjectsJob import MultiplyObjectsJob
|
||||||
from cura.Settings.SetObjectExtruderOperation import SetObjectExtruderOperation
|
from cura.Settings.SetObjectExtruderOperation import SetObjectExtruderOperation
|
||||||
from cura.Settings.ExtruderManager import ExtruderManager
|
from cura.Settings.ExtruderManager import ExtruderManager
|
||||||
|
from cura.Arranging.Nest2DArrange import createGroupOperationForArrange
|
||||||
|
|
||||||
from cura.Operations.SetBuildPlateNumberOperation import SetBuildPlateNumberOperation
|
from cura.Operations.SetBuildPlateNumberOperation import SetBuildPlateNumberOperation
|
||||||
|
|
||||||
@ -181,5 +185,60 @@ class CuraActions(QObject):
|
|||||||
|
|
||||||
Selection.clear()
|
Selection.clear()
|
||||||
|
|
||||||
|
@pyqtSlot()
|
||||||
|
def cut(self) -> None:
|
||||||
|
self.copy()
|
||||||
|
self.deleteSelection()
|
||||||
|
|
||||||
|
@pyqtSlot()
|
||||||
|
def copy(self) -> None:
|
||||||
|
mesh_writer = cura.CuraApplication.CuraApplication.getInstance().getMeshFileHandler().getWriter("3MFWriter")
|
||||||
|
if not mesh_writer:
|
||||||
|
Logger.log("e", "No 3MF writer found, unable to copy.")
|
||||||
|
return
|
||||||
|
|
||||||
|
# Get the selected nodes
|
||||||
|
selected_objects = Selection.getAllSelectedObjects()
|
||||||
|
# Serialize the nodes to a string
|
||||||
|
scene_string = mesh_writer.sceneNodesToString(selected_objects)
|
||||||
|
# Put the string on the clipboard
|
||||||
|
QApplication.clipboard().setText(scene_string)
|
||||||
|
|
||||||
|
@pyqtSlot()
|
||||||
|
def paste(self) -> None:
|
||||||
|
application = cura.CuraApplication.CuraApplication.getInstance()
|
||||||
|
mesh_reader = application.getMeshFileHandler().getReaderForFile(".3mf")
|
||||||
|
if not mesh_reader:
|
||||||
|
Logger.log("e", "No 3MF reader found, unable to paste.")
|
||||||
|
return
|
||||||
|
|
||||||
|
# Parse the scene from the clipboard
|
||||||
|
scene_string = QApplication.clipboard().text()
|
||||||
|
|
||||||
|
nodes = mesh_reader.stringToSceneNodes(scene_string)
|
||||||
|
|
||||||
|
if not nodes:
|
||||||
|
# Nothing to paste
|
||||||
|
return
|
||||||
|
|
||||||
|
# Find all fixed nodes, these are the nodes that should be avoided when arranging
|
||||||
|
fixed_nodes = []
|
||||||
|
root = application.getController().getScene().getRoot()
|
||||||
|
for node in DepthFirstIterator(root):
|
||||||
|
# Only count sliceable objects
|
||||||
|
if node.callDecoration("isSliceable"):
|
||||||
|
fixed_nodes.append(node)
|
||||||
|
# Add the new nodes to the scene, and arrange them
|
||||||
|
group_operation, not_fit_count = createGroupOperationForArrange(nodes, application.getBuildVolume(),
|
||||||
|
fixed_nodes, factor=10000,
|
||||||
|
add_new_nodes_in_scene=True)
|
||||||
|
group_operation.push()
|
||||||
|
|
||||||
|
# deselect currently selected nodes, and select the new nodes
|
||||||
|
for node in Selection.getAllSelectedObjects():
|
||||||
|
Selection.remove(node)
|
||||||
|
for node in nodes:
|
||||||
|
Selection.add(node)
|
||||||
|
|
||||||
def _openUrl(self, url: QUrl) -> None:
|
def _openUrl(self, url: QUrl) -> None:
|
||||||
QDesktopServices.openUrl(url)
|
QDesktopServices.openUrl(url)
|
||||||
|
@ -56,7 +56,8 @@ class ThreeMFReader(MeshReader):
|
|||||||
def emptyFileHintSet(self) -> bool:
|
def emptyFileHintSet(self) -> bool:
|
||||||
return self._empty_project
|
return self._empty_project
|
||||||
|
|
||||||
def _createMatrixFromTransformationString(self, transformation: str) -> Matrix:
|
@staticmethod
|
||||||
|
def _createMatrixFromTransformationString(transformation: str) -> Matrix:
|
||||||
if transformation == "":
|
if transformation == "":
|
||||||
return Matrix()
|
return Matrix()
|
||||||
|
|
||||||
@ -90,7 +91,8 @@ class ThreeMFReader(MeshReader):
|
|||||||
|
|
||||||
return temp_mat
|
return temp_mat
|
||||||
|
|
||||||
def _convertSavitarNodeToUMNode(self, savitar_node: Savitar.SceneNode, file_name: str = "") -> Optional[SceneNode]:
|
@staticmethod
|
||||||
|
def _convertSavitarNodeToUMNode(savitar_node: Savitar.SceneNode, file_name: str = "") -> Optional[SceneNode]:
|
||||||
"""Convenience function that converts a SceneNode object (as obtained from libSavitar) to a scene node.
|
"""Convenience function that converts a SceneNode object (as obtained from libSavitar) to a scene node.
|
||||||
|
|
||||||
:returns: Scene node.
|
:returns: Scene node.
|
||||||
@ -119,7 +121,7 @@ class ThreeMFReader(MeshReader):
|
|||||||
pass
|
pass
|
||||||
um_node.setName(node_name)
|
um_node.setName(node_name)
|
||||||
um_node.setId(node_id)
|
um_node.setId(node_id)
|
||||||
transformation = self._createMatrixFromTransformationString(savitar_node.getTransformation())
|
transformation = ThreeMFReader._createMatrixFromTransformationString(savitar_node.getTransformation())
|
||||||
um_node.setTransformation(transformation)
|
um_node.setTransformation(transformation)
|
||||||
mesh_builder = MeshBuilder()
|
mesh_builder = MeshBuilder()
|
||||||
|
|
||||||
@ -138,7 +140,7 @@ class ThreeMFReader(MeshReader):
|
|||||||
um_node.setMeshData(mesh_data)
|
um_node.setMeshData(mesh_data)
|
||||||
|
|
||||||
for child in savitar_node.getChildren():
|
for child in savitar_node.getChildren():
|
||||||
child_node = self._convertSavitarNodeToUMNode(child)
|
child_node = ThreeMFReader._convertSavitarNodeToUMNode(child)
|
||||||
if child_node:
|
if child_node:
|
||||||
um_node.addChild(child_node)
|
um_node.addChild(child_node)
|
||||||
|
|
||||||
@ -214,7 +216,7 @@ class ThreeMFReader(MeshReader):
|
|||||||
CuraApplication.getInstance().getController().getScene().setMetaDataEntry(key, value)
|
CuraApplication.getInstance().getController().getScene().setMetaDataEntry(key, value)
|
||||||
|
|
||||||
for node in scene_3mf.getSceneNodes():
|
for node in scene_3mf.getSceneNodes():
|
||||||
um_node = self._convertSavitarNodeToUMNode(node, file_name)
|
um_node = ThreeMFReader._convertSavitarNodeToUMNode(node, file_name)
|
||||||
if um_node is None:
|
if um_node is None:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
@ -300,8 +302,23 @@ class ThreeMFReader(MeshReader):
|
|||||||
if unit is None:
|
if unit is None:
|
||||||
unit = "millimeter"
|
unit = "millimeter"
|
||||||
elif unit not in conversion_to_mm:
|
elif unit not in conversion_to_mm:
|
||||||
Logger.log("w", "Unrecognised unit {unit} used. Assuming mm instead.".format(unit = unit))
|
Logger.log("w", "Unrecognised unit {unit} used. Assuming mm instead.".format(unit=unit))
|
||||||
unit = "millimeter"
|
unit = "millimeter"
|
||||||
|
|
||||||
scale = conversion_to_mm[unit]
|
scale = conversion_to_mm[unit]
|
||||||
return Vector(scale, scale, scale)
|
return Vector(scale, scale, scale)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def stringToSceneNodes(scene_string: str) -> List[SceneNode]:
|
||||||
|
parser = Savitar.ThreeMFParser()
|
||||||
|
scene = parser.parse(scene_string)
|
||||||
|
|
||||||
|
# Convert the scene to scene nodes
|
||||||
|
nodes = []
|
||||||
|
for savitar_node in scene.getSceneNodes():
|
||||||
|
scene_node = ThreeMFReader._convertSavitarNodeToUMNode(savitar_node, "file_name")
|
||||||
|
if scene_node is None:
|
||||||
|
continue
|
||||||
|
nodes.append(scene_node)
|
||||||
|
|
||||||
|
return nodes
|
||||||
|
@ -57,11 +57,12 @@ class ThreeMFWriter(MeshWriter):
|
|||||||
"cura": "http://software.ultimaker.com/xml/cura/3mf/2015/10"
|
"cura": "http://software.ultimaker.com/xml/cura/3mf/2015/10"
|
||||||
}
|
}
|
||||||
|
|
||||||
self._unit_matrix_string = self._convertMatrixToString(Matrix())
|
self._unit_matrix_string = ThreeMFWriter._convertMatrixToString(Matrix())
|
||||||
self._archive: Optional[zipfile.ZipFile] = None
|
self._archive: Optional[zipfile.ZipFile] = None
|
||||||
self._store_archive = False
|
self._store_archive = False
|
||||||
|
|
||||||
def _convertMatrixToString(self, matrix):
|
@staticmethod
|
||||||
|
def _convertMatrixToString(matrix):
|
||||||
result = ""
|
result = ""
|
||||||
result += str(matrix._data[0, 0]) + " "
|
result += str(matrix._data[0, 0]) + " "
|
||||||
result += str(matrix._data[1, 0]) + " "
|
result += str(matrix._data[1, 0]) + " "
|
||||||
@ -85,7 +86,8 @@ class ThreeMFWriter(MeshWriter):
|
|||||||
"""
|
"""
|
||||||
self._store_archive = store_archive
|
self._store_archive = store_archive
|
||||||
|
|
||||||
def _convertUMNodeToSavitarNode(self, um_node, transformation = Matrix()):
|
@staticmethod
|
||||||
|
def _convertUMNodeToSavitarNode(um_node, transformation=Matrix()):
|
||||||
"""Convenience function that converts an Uranium SceneNode object to a SavitarSceneNode
|
"""Convenience function that converts an Uranium SceneNode object to a SavitarSceneNode
|
||||||
|
|
||||||
:returns: Uranium Scene node.
|
:returns: Uranium Scene node.
|
||||||
@ -102,7 +104,7 @@ class ThreeMFWriter(MeshWriter):
|
|||||||
|
|
||||||
node_matrix = um_node.getLocalTransformation()
|
node_matrix = um_node.getLocalTransformation()
|
||||||
|
|
||||||
matrix_string = self._convertMatrixToString(node_matrix.preMultiply(transformation))
|
matrix_string = ThreeMFWriter._convertMatrixToString(node_matrix.preMultiply(transformation))
|
||||||
|
|
||||||
savitar_node.setTransformation(matrix_string)
|
savitar_node.setTransformation(matrix_string)
|
||||||
mesh_data = um_node.getMeshData()
|
mesh_data = um_node.getMeshData()
|
||||||
@ -135,7 +137,7 @@ class ThreeMFWriter(MeshWriter):
|
|||||||
# only save the nodes on the active build plate
|
# only save the nodes on the active build plate
|
||||||
if child_node.callDecoration("getBuildPlateNumber") != active_build_plate_nr:
|
if child_node.callDecoration("getBuildPlateNumber") != active_build_plate_nr:
|
||||||
continue
|
continue
|
||||||
savitar_child_node = self._convertUMNodeToSavitarNode(child_node)
|
savitar_child_node = ThreeMFWriter._convertUMNodeToSavitarNode(child_node)
|
||||||
if savitar_child_node is not None:
|
if savitar_child_node is not None:
|
||||||
savitar_node.addChild(savitar_child_node)
|
savitar_node.addChild(savitar_child_node)
|
||||||
|
|
||||||
@ -225,7 +227,7 @@ class ThreeMFWriter(MeshWriter):
|
|||||||
for node in nodes:
|
for node in nodes:
|
||||||
if node == root_node:
|
if node == root_node:
|
||||||
for root_child in node.getChildren():
|
for root_child in node.getChildren():
|
||||||
savitar_node = self._convertUMNodeToSavitarNode(root_child, transformation_matrix)
|
savitar_node = ThreeMFWriter._convertUMNodeToSavitarNode(root_child, transformation_matrix)
|
||||||
if savitar_node:
|
if savitar_node:
|
||||||
savitar_scene.addSceneNode(savitar_node)
|
savitar_scene.addSceneNode(savitar_node)
|
||||||
else:
|
else:
|
||||||
@ -369,9 +371,19 @@ class ThreeMFWriter(MeshWriter):
|
|||||||
Logger.log("w", "Can't create snapshot when renderer not initialized.")
|
Logger.log("w", "Can't create snapshot when renderer not initialized.")
|
||||||
return None
|
return None
|
||||||
try:
|
try:
|
||||||
snapshot = Snapshot.snapshot(width = 300, height = 300)
|
snapshot = Snapshot.snapshot(width=300, height=300)
|
||||||
except:
|
except:
|
||||||
Logger.logException("w", "Failed to create snapshot image")
|
Logger.logException("w", "Failed to create snapshot image")
|
||||||
return None
|
return None
|
||||||
|
|
||||||
return snapshot
|
return snapshot
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def sceneNodesToString(scene_nodes: [SceneNode]) -> str:
|
||||||
|
savitar_scene = Savitar.Scene()
|
||||||
|
for scene_node in scene_nodes:
|
||||||
|
savitar_node = ThreeMFWriter._convertUMNodeToSavitarNode(scene_node)
|
||||||
|
savitar_scene.addSceneNode(savitar_node)
|
||||||
|
parser = Savitar.ThreeMFParser()
|
||||||
|
scene_string = parser.sceneToString(savitar_scene)
|
||||||
|
return scene_string
|
||||||
|
@ -203,7 +203,7 @@ class CuraEngineBackend(QObject, Backend):
|
|||||||
backend_plugins = CuraApplication.getInstance().getBackendPlugins()
|
backend_plugins = CuraApplication.getInstance().getBackendPlugins()
|
||||||
for backend_plugin in backend_plugins:
|
for backend_plugin in backend_plugins:
|
||||||
if backend_plugin.isRunning():
|
if backend_plugin.isRunning():
|
||||||
continue
|
backend_plugin.stop()
|
||||||
# Set the port to prevent plugins from using the same one.
|
# Set the port to prevent plugins from using the same one.
|
||||||
backend_plugin.setPort(self._last_backend_plugin_port)
|
backend_plugin.setPort(self._last_backend_plugin_port)
|
||||||
self._last_backend_plugin_port += 1
|
self._last_backend_plugin_port += 1
|
||||||
|
29
resources/definitions/anycubic_kobra_plus.def.json
Normal file
29
resources/definitions/anycubic_kobra_plus.def.json
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
{
|
||||||
|
"version": 2,
|
||||||
|
"name": "Anycubic Kobra Plus",
|
||||||
|
"inherits": "fdmprinter",
|
||||||
|
"metadata":
|
||||||
|
{
|
||||||
|
"visible": true,
|
||||||
|
"author": "Jordon Brooks",
|
||||||
|
"manufacturer": "Anycubic",
|
||||||
|
"file_formats": "text/x-gcode",
|
||||||
|
"has_machine_quality": true,
|
||||||
|
"has_materials": true,
|
||||||
|
"machine_extruder_trains": { "0": "anycubic_kobra_plus_extruder_0" },
|
||||||
|
"preferred_material": "generic_pla",
|
||||||
|
"preferred_quality_type": "normal",
|
||||||
|
"quality_definition": "anycubic_kobra_plus"
|
||||||
|
},
|
||||||
|
"overrides":
|
||||||
|
{
|
||||||
|
"machine_depth": { "default_value": 302 },
|
||||||
|
"machine_end_gcode": { "default_value": "M104 S0\nM140 S0\n;Retract the filament\nG92 E1\nG1 E-1 F300\nG28 X0 Y0\nM84\nM355 S0; led off" },
|
||||||
|
"machine_gcode_flavor": { "default_value": "RepRap (Marlin/Sprinter)" },
|
||||||
|
"machine_heated_bed": { "default_value": true },
|
||||||
|
"machine_height": { "default_value": 352 },
|
||||||
|
"machine_name": { "default_value": "Anycubic Kobra Plus" },
|
||||||
|
"machine_start_gcode": { "default_value": "G28 ;Home\nG1 Z15.0 F6000 ;Move the platform down 15mm\n;Prime the extruder\nG92 E0\nM355 S1; Turn LED on\n; Add Custom purge lines\nG1 Z2.0 F3000 ; Move Z Axis up little to prevent scratching of Heat Bed\nG1 X1.0 Y30 Z0.3 F5000.0 ; Move to start position\nG1 X1.0 Y100.0 Z0.3 F1500.0 E15 ; Draw the first line\nG1 X1.3 Y100.0 Z0.3 F5000.0 ; Move to side a little\nG1 X1.3 Y30 Z0.3 F1500.0 E30 ; Draw the second line\nG92 E0 ; Reset Extruder\nG1 E-2 F500 ; Retract a little \nG1 X50 F500 ; wipe away from the filament line\nG1 X100 F9000 ; Quickly wipe away from the filament line\nG1 Z5.0 F3000 ; Move Z Axis up little to prevent scratching of Heat Bed\n; End custom purge lines" },
|
||||||
|
"machine_width": { "default_value": 302 }
|
||||||
|
}
|
||||||
|
}
|
@ -5921,7 +5921,7 @@
|
|||||||
"maximum_value_warning": "skirt_brim_line_width",
|
"maximum_value_warning": "skirt_brim_line_width",
|
||||||
"enabled": "resolveOrValue('adhesion_type') == 'brim'",
|
"enabled": "resolveOrValue('adhesion_type') == 'brim'",
|
||||||
"limit_to_extruder": "skirt_brim_extruder_nr",
|
"limit_to_extruder": "skirt_brim_extruder_nr",
|
||||||
"settable_per_mesh": true,
|
"settable_per_mesh": false,
|
||||||
"settable_per_extruder": true
|
"settable_per_extruder": true
|
||||||
},
|
},
|
||||||
"brim_replaces_support":
|
"brim_replaces_support":
|
||||||
|
16
resources/extruders/anycubic_kobra_plus_extruder_0.def.json
Normal file
16
resources/extruders/anycubic_kobra_plus_extruder_0.def.json
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
{
|
||||||
|
"version": 2,
|
||||||
|
"name": "Extruder 1",
|
||||||
|
"inherits": "fdmextruder",
|
||||||
|
"metadata":
|
||||||
|
{
|
||||||
|
"machine": "anycubic_kobra_plus",
|
||||||
|
"position": "0"
|
||||||
|
},
|
||||||
|
"overrides":
|
||||||
|
{
|
||||||
|
"extruder_nr": { "default_value": 0 },
|
||||||
|
"machine_nozzle_size": { "default_value": 0.4 },
|
||||||
|
"material_diameter": { "default_value": 1.75 }
|
||||||
|
}
|
||||||
|
}
|
@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 UltiMaker
|
// Copyright (c) 2023 UltiMaker
|
||||||
// Cura is released under the terms of the LGPLv3 or higher.
|
// Cura is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
pragma Singleton
|
pragma Singleton
|
||||||
@ -6,7 +6,7 @@ pragma Singleton
|
|||||||
import QtQuick 2.10
|
import QtQuick 2.10
|
||||||
import QtQuick.Controls 2.4
|
import QtQuick.Controls 2.4
|
||||||
import UM 1.1 as UM
|
import UM 1.1 as UM
|
||||||
import Cura 1.0 as Cura
|
import Cura 1.5 as Cura
|
||||||
|
|
||||||
Item
|
Item
|
||||||
{
|
{
|
||||||
@ -71,6 +71,15 @@ Item
|
|||||||
|
|
||||||
property alias browsePackages: browsePackagesAction
|
property alias browsePackages: browsePackagesAction
|
||||||
|
|
||||||
|
property alias paste: pasteAction
|
||||||
|
property alias copy: copyAction
|
||||||
|
property alias cut: cutAction
|
||||||
|
|
||||||
|
readonly property bool copy_paste_enabled: {
|
||||||
|
const all_enabled_packages = CuraApplication.getPackageManager().allEnabledPackages;
|
||||||
|
return all_enabled_packages.includes("3MFReader") && all_enabled_packages.includes("3MFWriter");
|
||||||
|
}
|
||||||
|
|
||||||
UM.I18nCatalog{id: catalog; name: "cura"}
|
UM.I18nCatalog{id: catalog; name: "cura"}
|
||||||
|
|
||||||
|
|
||||||
@ -309,6 +318,33 @@ Item
|
|||||||
onTriggered: CuraActions.centerSelection()
|
onTriggered: CuraActions.centerSelection()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Action
|
||||||
|
{
|
||||||
|
id: copyAction
|
||||||
|
text: catalog.i18nc("@action:inmenu menubar:edit", "Copy to clipboard")
|
||||||
|
onTriggered: CuraActions.copy()
|
||||||
|
enabled: UM.Controller.toolsEnabled && UM.Selection.hasSelection && copy_paste_enabled
|
||||||
|
shortcut: StandardKey.Copy
|
||||||
|
}
|
||||||
|
|
||||||
|
Action
|
||||||
|
{
|
||||||
|
id: pasteAction
|
||||||
|
text: catalog.i18nc("@action:inmenu menubar:edit", "Paste from clipboard")
|
||||||
|
onTriggered: CuraActions.paste()
|
||||||
|
enabled: UM.Controller.toolsEnabled && copy_paste_enabled
|
||||||
|
shortcut: StandardKey.Paste
|
||||||
|
}
|
||||||
|
|
||||||
|
Action
|
||||||
|
{
|
||||||
|
id: cutAction
|
||||||
|
text: catalog.i18nc("@action:inmenu menubar:edit", "Cut")
|
||||||
|
onTriggered: CuraActions.cut()
|
||||||
|
enabled: UM.Controller.toolsEnabled && UM.Selection.hasSelection && copy_paste_enabled
|
||||||
|
shortcut: StandardKey.Cut
|
||||||
|
}
|
||||||
|
|
||||||
Action
|
Action
|
||||||
{
|
{
|
||||||
id: multiplySelectionAction
|
id: multiplySelectionAction
|
||||||
|
@ -19,6 +19,8 @@ Cura.Menu
|
|||||||
// Selection-related actions.
|
// Selection-related actions.
|
||||||
Cura.MenuItem { action: Cura.Actions.centerSelection; }
|
Cura.MenuItem { action: Cura.Actions.centerSelection; }
|
||||||
Cura.MenuItem { action: Cura.Actions.deleteSelection; }
|
Cura.MenuItem { action: Cura.Actions.deleteSelection; }
|
||||||
|
Cura.MenuItem { action: Cura.Actions.copy; }
|
||||||
|
Cura.MenuItem { action: Cura.Actions.paste; }
|
||||||
Cura.MenuItem { action: Cura.Actions.multiplySelection; }
|
Cura.MenuItem { action: Cura.Actions.multiplySelection; }
|
||||||
|
|
||||||
// Extruder selection - only visible if there is more than 1 extruder
|
// Extruder selection - only visible if there is more than 1 extruder
|
||||||
|
@ -0,0 +1,28 @@
|
|||||||
|
[general]
|
||||||
|
definition = anycubic_kobra_plus
|
||||||
|
name = Normal
|
||||||
|
version = 4
|
||||||
|
|
||||||
|
[metadata]
|
||||||
|
global_quality = True
|
||||||
|
quality_type = normal
|
||||||
|
setting_version = 22
|
||||||
|
type = quality
|
||||||
|
weight = 0
|
||||||
|
|
||||||
|
[values]
|
||||||
|
infill_pattern = cubic
|
||||||
|
layer_height = 0.2
|
||||||
|
layer_height_0 = 0.2
|
||||||
|
material_final_print_temperature = 195
|
||||||
|
material_print_temperature = 195
|
||||||
|
retraction_combing = off
|
||||||
|
retraction_hop = 0.1
|
||||||
|
retraction_hop_enabled = True
|
||||||
|
retraction_hop_only_when_collides = True
|
||||||
|
speed_infill = 40
|
||||||
|
speed_layer_0 = 20
|
||||||
|
speed_print = 80
|
||||||
|
speed_wall_x = 60
|
||||||
|
wall_thickness = 1.2
|
||||||
|
|
@ -13,4 +13,8 @@ weight = 0
|
|||||||
|
|
||||||
[values]
|
[values]
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -14,5 +14,9 @@ weight = 0
|
|||||||
[values]
|
[values]
|
||||||
speed_infill = =math.ceil(speed_print * 40 / 55)
|
speed_infill = =math.ceil(speed_print * 40 / 55)
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.8
|
top_bottom_thickness = 0.8
|
||||||
|
|
||||||
|
@ -20,6 +20,10 @@ retraction_min_travel = 5
|
|||||||
speed_print = 70
|
speed_print = 70
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 70)
|
speed_topbottom = =math.ceil(speed_print * 30 / 70)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 70)
|
speed_wall = =math.ceil(speed_print * 30 / 70)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -29,7 +29,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -15,5 +15,9 @@ weight = 0
|
|||||||
material_print_temperature = =default_material_print_temperature - 5
|
material_print_temperature = =default_material_print_temperature - 5
|
||||||
speed_infill = =math.ceil(speed_print * 40 / 55)
|
speed_infill = =math.ceil(speed_print * 40 / 55)
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.8
|
top_bottom_thickness = 0.8
|
||||||
|
|
||||||
|
@ -21,6 +21,10 @@ retraction_hop = 0.2
|
|||||||
speed_print = 30
|
speed_print = 30
|
||||||
speed_wall = =math.ceil(speed_print * 25 / 30)
|
speed_wall = =math.ceil(speed_print * 25 / 30)
|
||||||
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.72
|
top_bottom_thickness = 0.72
|
||||||
travel_avoid_distance = 0.4
|
travel_avoid_distance = 0.4
|
||||||
wall_0_inset = 0.015
|
wall_0_inset = 0.015
|
||||||
|
@ -34,6 +34,10 @@ speed_print = 25
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -21,6 +21,10 @@ speed_print = 30
|
|||||||
speed_topbottom = =math.ceil(speed_print * 20 / 30)
|
speed_topbottom = =math.ceil(speed_print * 20 / 30)
|
||||||
speed_wall = =math.ceil(speed_print * 25 / 30)
|
speed_wall = =math.ceil(speed_print * 25 / 30)
|
||||||
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.72
|
top_bottom_thickness = 0.72
|
||||||
wall_0_inset = 0.015
|
wall_0_inset = 0.015
|
||||||
wall_0_wipe_dist = 0.25
|
wall_0_wipe_dist = 0.25
|
||||||
|
@ -22,4 +22,8 @@ speed_infill = =math.ceil(speed_print * 40 / 50)
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 50)
|
speed_wall = =math.ceil(speed_print * 30 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -23,4 +23,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 60)
|
speed_wall = =math.ceil(speed_print * 40 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -22,4 +22,8 @@ speed_infill = =math.ceil(speed_print * 40 / 55)
|
|||||||
speed_print = 55
|
speed_print = 55
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 55)
|
speed_wall = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -23,4 +23,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 60)
|
speed_wall = =math.ceil(speed_print * 45 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -28,6 +28,9 @@ speed_print = 40
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
||||||
speed_wall = =math.ceil(speed_print * 35 / 40)
|
speed_wall = =math.ceil(speed_print * 35 / 40)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -26,6 +26,9 @@ speed_print = 45
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 45)
|
speed_wall = =math.ceil(speed_print * 45 / 45)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -28,6 +28,9 @@ speed_print = 40
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
||||||
speed_wall = =math.ceil(speed_print * 35 / 40)
|
speed_wall = =math.ceil(speed_print * 35 / 40)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -26,6 +26,9 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 40 / 50)
|
speed_topbottom = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 50 / 50)
|
speed_wall = =math.ceil(speed_print * 50 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 40 / 50)
|
speed_wall_0 = =math.ceil(speed_wall * 40 / 50)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -21,4 +21,8 @@ speed_infill = =math.ceil(speed_print * 40 / 50)
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 50)
|
speed_wall = =math.ceil(speed_print * 30 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 60)
|
speed_wall = =math.ceil(speed_print * 40 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_infill = =math.ceil(speed_print * 45 / 55)
|
|||||||
speed_print = 55
|
speed_print = 55
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 55)
|
speed_wall = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 60)
|
speed_wall = =math.ceil(speed_print * 45 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -14,7 +14,10 @@ weight = 1
|
|||||||
[values]
|
[values]
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -15,7 +15,10 @@ weight = -1
|
|||||||
material_print_temperature = =default_material_print_temperature + 5
|
material_print_temperature = =default_material_print_temperature + 5
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -14,7 +14,10 @@ weight = 0
|
|||||||
[values]
|
[values]
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -15,7 +15,10 @@ weight = -2
|
|||||||
material_print_temperature = =default_material_print_temperature + 10
|
material_print_temperature = =default_material_print_temperature + 10
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -31,7 +31,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -31,7 +31,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -30,7 +30,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -31,7 +31,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -20,4 +20,8 @@ speed_infill = =math.ceil(speed_print * 40 / 50)
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 50)
|
speed_wall = =math.ceil(speed_print * 30 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -19,4 +19,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 60)
|
speed_wall = =math.ceil(speed_print * 40 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_infill = =math.ceil(speed_print * 45 / 55)
|
|||||||
speed_print = 55
|
speed_print = 55
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 55)
|
speed_wall = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -19,4 +19,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 60)
|
speed_wall = =math.ceil(speed_print * 45 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -21,5 +21,9 @@ retraction_prime_speed = =retraction_speed
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 35 / 50)
|
speed_topbottom = =math.ceil(speed_print * 35 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 35 / 50)
|
speed_wall = =math.ceil(speed_print * 35 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1
|
top_bottom_thickness = 1
|
||||||
|
|
||||||
|
@ -21,5 +21,9 @@ speed_print = 70
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 70)
|
speed_topbottom = =math.ceil(speed_print * 35 / 70)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 70)
|
speed_wall = =math.ceil(speed_print * 45 / 70)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 70)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 70)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1
|
top_bottom_thickness = 1
|
||||||
|
|
||||||
|
@ -17,5 +17,9 @@ machine_nozzle_heat_up_speed = 1.6
|
|||||||
prime_tower_enable = False
|
prime_tower_enable = False
|
||||||
raft_airgap = 0.25
|
raft_airgap = 0.25
|
||||||
retraction_prime_speed = =retraction_speed
|
retraction_prime_speed = =retraction_speed
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1
|
top_bottom_thickness = 1
|
||||||
|
|
||||||
|
@ -24,5 +24,9 @@ retraction_prime_speed = =retraction_speed
|
|||||||
speed_topbottom = =math.ceil(speed_print * 40 / 70)
|
speed_topbottom = =math.ceil(speed_print * 40 / 70)
|
||||||
speed_wall = =math.ceil(speed_print * 55 / 70)
|
speed_wall = =math.ceil(speed_print * 55 / 70)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 45 / 50)
|
speed_wall_0 = =math.ceil(speed_wall * 45 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.8
|
top_bottom_thickness = 0.8
|
||||||
|
|
||||||
|
@ -27,6 +27,10 @@ raft_airgap = 0.25
|
|||||||
retraction_prime_speed = =retraction_speed
|
retraction_prime_speed = =retraction_speed
|
||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_wall = 50
|
speed_wall = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.9
|
top_bottom_thickness = 0.9
|
||||||
wall_line_width_0 = =line_width * (1 + magic_spiralize * 0.25)
|
wall_line_width_0 = =line_width * (1 + magic_spiralize * 0.25)
|
||||||
|
|
||||||
|
@ -35,6 +35,10 @@ speed_topbottom = =math.ceil(speed_print * 25 / 25)
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -35,6 +35,10 @@ speed_topbottom = =math.ceil(speed_print * 25 / 25)
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -35,6 +35,10 @@ speed_topbottom = =math.ceil(speed_print * 25 / 25)
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -21,5 +21,9 @@ speed_print = 45
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 45)
|
speed_wall = =math.ceil(speed_print * 40 / 45)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
|
|
||||||
|
@ -21,5 +21,9 @@ speed_print = 45
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 45)
|
speed_wall = =math.ceil(speed_print * 40 / 45)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
|
|
||||||
|
@ -21,5 +21,9 @@ speed_print = 45
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 45)
|
speed_wall = =math.ceil(speed_print * 40 / 45)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
|
|
||||||
|
@ -22,5 +22,9 @@ speed_roofing = =math.ceil(speed_wall * 20 / 24)
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 36 / 50)
|
speed_wall = =math.ceil(speed_print * 36 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_print * 26 / 50)
|
speed_wall_0 = =math.ceil(speed_print * 26 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
|
|
||||||
|
@ -27,6 +27,10 @@ raft_airgap = 0.25
|
|||||||
retraction_prime_speed = =retraction_speed
|
retraction_prime_speed = =retraction_speed
|
||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_wall = 50
|
speed_wall = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
wall_line_width_0 = =line_width * (1 + magic_spiralize * 0.25)
|
wall_line_width_0 = =line_width * (1 + magic_spiralize * 0.25)
|
||||||
|
|
||||||
|
@ -36,6 +36,10 @@ speed_topbottom = =math.ceil(speed_print * 0.8)
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -35,6 +35,10 @@ speed_topbottom = =math.ceil(speed_print * 0.8)
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -36,6 +36,10 @@ speed_topbottom = =math.ceil(speed_print * 0.8)
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -22,8 +22,9 @@ speed_topbottom = =speed_print
|
|||||||
speed_wall = =speed_print
|
speed_wall = =speed_print
|
||||||
speed_wall_0 = =speed_wall
|
speed_wall_0 = =speed_wall
|
||||||
speed_wall_x = =speed_wall
|
speed_wall_x = =speed_wall
|
||||||
support_bottom_distance = =support_z_distance / 2
|
support_bottom_distance = =support_z_distance
|
||||||
support_top_distance = =support_z_distance / 2
|
support_interface_enable = True
|
||||||
support_z_distance = =layer_height * 2
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.8
|
top_bottom_thickness = 0.8
|
||||||
|
|
||||||
|
@ -22,8 +22,9 @@ speed_topbottom = =speed_print
|
|||||||
speed_wall = =speed_print
|
speed_wall = =speed_print
|
||||||
speed_wall_0 = =speed_wall
|
speed_wall_0 = =speed_wall
|
||||||
speed_wall_x = =speed_wall
|
speed_wall_x = =speed_wall
|
||||||
support_bottom_distance = =support_z_distance / 2
|
support_bottom_distance = =support_z_distance
|
||||||
support_top_distance = =support_z_distance / 2
|
support_interface_enable = True
|
||||||
support_z_distance = =layer_height * 2
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.8
|
top_bottom_thickness = 0.8
|
||||||
|
|
||||||
|
@ -22,8 +22,9 @@ speed_topbottom = =speed_print
|
|||||||
speed_wall = =speed_print
|
speed_wall = =speed_print
|
||||||
speed_wall_0 = =speed_wall
|
speed_wall_0 = =speed_wall
|
||||||
speed_wall_x = =speed_wall
|
speed_wall_x = =speed_wall
|
||||||
support_bottom_distance = =support_z_distance / 2
|
support_bottom_distance = =support_z_distance
|
||||||
support_top_distance = =support_z_distance / 2
|
support_interface_enable = True
|
||||||
support_z_distance = =layer_height * 2
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
|
|
||||||
|
@ -22,8 +22,9 @@ speed_topbottom = =speed_print
|
|||||||
speed_wall = =speed_print
|
speed_wall = =speed_print
|
||||||
speed_wall_0 = =speed_wall
|
speed_wall_0 = =speed_wall
|
||||||
speed_wall_x = =speed_wall
|
speed_wall_x = =speed_wall
|
||||||
support_bottom_distance = =support_z_distance / 2
|
support_bottom_distance = =support_z_distance
|
||||||
support_top_distance = =support_z_distance / 2
|
support_interface_enable = True
|
||||||
support_z_distance = =layer_height * 2
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
|
|
||||||
|
@ -22,8 +22,9 @@ speed_topbottom = =speed_print
|
|||||||
speed_wall = =speed_print
|
speed_wall = =speed_print
|
||||||
speed_wall_0 = =speed_wall
|
speed_wall_0 = =speed_wall
|
||||||
speed_wall_x = =speed_wall
|
speed_wall_x = =speed_wall
|
||||||
support_bottom_distance = =support_z_distance / 2
|
support_bottom_distance = =support_z_distance
|
||||||
support_top_distance = =support_z_distance / 2
|
support_interface_enable = True
|
||||||
support_z_distance = =layer_height * 2
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1.2
|
top_bottom_thickness = 1.2
|
||||||
|
|
||||||
|
@ -13,4 +13,8 @@ weight = 0
|
|||||||
|
|
||||||
[values]
|
[values]
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -14,5 +14,9 @@ weight = 0
|
|||||||
[values]
|
[values]
|
||||||
speed_infill = =math.ceil(speed_print * 40 / 55)
|
speed_infill = =math.ceil(speed_print * 40 / 55)
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.8
|
top_bottom_thickness = 0.8
|
||||||
|
|
||||||
|
@ -15,11 +15,15 @@ weight = 0
|
|||||||
machine_nozzle_cool_down_speed = 0.9
|
machine_nozzle_cool_down_speed = 0.9
|
||||||
machine_nozzle_heat_up_speed = 1.4
|
machine_nozzle_heat_up_speed = 1.4
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.15
|
raft_airgap = 0.4
|
||||||
retraction_min_travel = 5
|
retraction_min_travel = 5
|
||||||
speed_print = 70
|
speed_print = 70
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 70)
|
speed_topbottom = =math.ceil(speed_print * 30 / 70)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 70)
|
speed_wall = =math.ceil(speed_print * 30 / 70)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -29,7 +29,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -15,5 +15,9 @@ weight = 0
|
|||||||
material_print_temperature = =default_material_print_temperature - 5
|
material_print_temperature = =default_material_print_temperature - 5
|
||||||
speed_infill = =math.ceil(speed_print * 40 / 55)
|
speed_infill = =math.ceil(speed_print * 40 / 55)
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.8
|
top_bottom_thickness = 0.8
|
||||||
|
|
||||||
|
@ -21,6 +21,10 @@ retraction_hop = 0.2
|
|||||||
speed_print = 30
|
speed_print = 30
|
||||||
speed_wall = =math.ceil(speed_print * 25 / 30)
|
speed_wall = =math.ceil(speed_print * 25 / 30)
|
||||||
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.72
|
top_bottom_thickness = 0.72
|
||||||
travel_avoid_distance = 0.4
|
travel_avoid_distance = 0.4
|
||||||
wall_0_inset = 0.015
|
wall_0_inset = 0.015
|
||||||
|
@ -34,6 +34,10 @@ speed_print = 25
|
|||||||
speed_wall = =math.ceil(speed_print * 25 / 25)
|
speed_wall = =math.ceil(speed_print * 25 / 25)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 25)
|
||||||
support_angle = 50
|
support_angle = 50
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -21,6 +21,10 @@ speed_print = 30
|
|||||||
speed_topbottom = =math.ceil(speed_print * 20 / 30)
|
speed_topbottom = =math.ceil(speed_print * 20 / 30)
|
||||||
speed_wall = =math.ceil(speed_print * 25 / 30)
|
speed_wall = =math.ceil(speed_print * 25 / 30)
|
||||||
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
speed_wall_0 = =math.ceil(speed_print * 20 / 30)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 0.72
|
top_bottom_thickness = 0.72
|
||||||
wall_0_inset = 0.015
|
wall_0_inset = 0.015
|
||||||
wall_0_wipe_dist = 0.25
|
wall_0_wipe_dist = 0.25
|
||||||
|
@ -22,4 +22,8 @@ speed_infill = =math.ceil(speed_print * 40 / 50)
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 50)
|
speed_wall = =math.ceil(speed_print * 30 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -23,4 +23,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 60)
|
speed_wall = =math.ceil(speed_print * 40 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -22,4 +22,8 @@ speed_infill = =math.ceil(speed_print * 40 / 55)
|
|||||||
speed_print = 55
|
speed_print = 55
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 55)
|
speed_wall = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -23,4 +23,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 60)
|
speed_wall = =math.ceil(speed_print * 45 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -28,6 +28,9 @@ speed_print = 40
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
||||||
speed_wall = =math.ceil(speed_print * 35 / 40)
|
speed_wall = =math.ceil(speed_print * 35 / 40)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -26,6 +26,9 @@ speed_print = 45
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
speed_topbottom = =math.ceil(speed_print * 35 / 45)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 45)
|
speed_wall = =math.ceil(speed_print * 45 / 45)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -28,6 +28,9 @@ speed_print = 40
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
speed_topbottom = =math.ceil(speed_print * 30 / 35)
|
||||||
speed_wall = =math.ceil(speed_print * 35 / 40)
|
speed_wall = =math.ceil(speed_print * 35 / 40)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 35)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -26,6 +26,9 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 40 / 50)
|
speed_topbottom = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 50 / 50)
|
speed_wall = =math.ceil(speed_print * 50 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 40 / 50)
|
speed_wall_0 = =math.ceil(speed_wall * 40 / 50)
|
||||||
support_z_distance = =layer_height
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.4/layer_height)*layer_height
|
||||||
wall_0_inset = 0
|
wall_0_inset = 0
|
||||||
|
|
||||||
|
@ -21,4 +21,8 @@ speed_infill = =math.ceil(speed_print * 40 / 50)
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 50)
|
speed_wall = =math.ceil(speed_print * 30 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 60)
|
speed_wall = =math.ceil(speed_print * 40 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_infill = =math.ceil(speed_print * 45 / 55)
|
|||||||
speed_print = 55
|
speed_print = 55
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 55)
|
speed_wall = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 60)
|
speed_wall = =math.ceil(speed_print * 45 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -14,7 +14,10 @@ weight = 1
|
|||||||
[values]
|
[values]
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -15,7 +15,10 @@ weight = -1
|
|||||||
material_print_temperature = =default_material_print_temperature + 5
|
material_print_temperature = =default_material_print_temperature + 5
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -14,7 +14,10 @@ weight = 0
|
|||||||
[values]
|
[values]
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -15,7 +15,10 @@ weight = -2
|
|||||||
material_print_temperature = =default_material_print_temperature + 10
|
material_print_temperature = =default_material_print_temperature + 10
|
||||||
ooze_shield_angle = 40
|
ooze_shield_angle = 40
|
||||||
raft_airgap = 0.4
|
raft_airgap = 0.4
|
||||||
retraction_prime_speed = =retraction_speed
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 30
|
switch_extruder_prime_speed = 30
|
||||||
switch_extruder_retraction_amount = 30
|
switch_extruder_retraction_amount = 30
|
||||||
switch_extruder_retraction_speeds = 40
|
switch_extruder_retraction_speeds = 40
|
||||||
|
@ -31,7 +31,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -31,7 +31,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -30,7 +30,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -31,7 +31,11 @@ speed_print = 50
|
|||||||
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
speed_topbottom = =math.ceil(speed_print * 25 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 50)
|
speed_wall = =math.ceil(speed_print * 40 / 50)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 25 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
support_interface_density = 87.5
|
support_interface_density = 87.5
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
switch_extruder_prime_speed = 15
|
switch_extruder_prime_speed = 15
|
||||||
switch_extruder_retraction_amount = 20
|
switch_extruder_retraction_amount = 20
|
||||||
switch_extruder_retraction_speeds = 35
|
switch_extruder_retraction_speeds = 35
|
||||||
|
@ -20,4 +20,8 @@ speed_infill = =math.ceil(speed_print * 40 / 50)
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
speed_topbottom = =math.ceil(speed_print * 30 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 50)
|
speed_wall = =math.ceil(speed_print * 30 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -19,4 +19,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
speed_topbottom = =math.ceil(speed_print * 30 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 40 / 60)
|
speed_wall = =math.ceil(speed_print * 40 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
speed_wall_0 = =math.ceil(speed_wall * 30 / 40)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -20,4 +20,8 @@ speed_infill = =math.ceil(speed_print * 45 / 55)
|
|||||||
speed_print = 55
|
speed_print = 55
|
||||||
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
speed_topbottom = =math.ceil(speed_print * 30 / 55)
|
||||||
speed_wall = =math.ceil(speed_print * 30 / 55)
|
speed_wall = =math.ceil(speed_print * 30 / 55)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -19,4 +19,8 @@ speed_print = 60
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
speed_topbottom = =math.ceil(speed_print * 35 / 60)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 60)
|
speed_wall = =math.ceil(speed_print * 45 / 60)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 45)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
|
|
||||||
|
@ -21,5 +21,9 @@ retraction_prime_speed = =retraction_speed
|
|||||||
speed_print = 50
|
speed_print = 50
|
||||||
speed_topbottom = =math.ceil(speed_print * 35 / 50)
|
speed_topbottom = =math.ceil(speed_print * 35 / 50)
|
||||||
speed_wall = =math.ceil(speed_print * 35 / 50)
|
speed_wall = =math.ceil(speed_print * 35 / 50)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1
|
top_bottom_thickness = 1
|
||||||
|
|
||||||
|
@ -21,5 +21,9 @@ speed_print = 70
|
|||||||
speed_topbottom = =math.ceil(speed_print * 35 / 70)
|
speed_topbottom = =math.ceil(speed_print * 35 / 70)
|
||||||
speed_wall = =math.ceil(speed_print * 45 / 70)
|
speed_wall = =math.ceil(speed_print * 45 / 70)
|
||||||
speed_wall_0 = =math.ceil(speed_wall * 35 / 70)
|
speed_wall_0 = =math.ceil(speed_wall * 35 / 70)
|
||||||
|
support_bottom_distance = =support_z_distance
|
||||||
|
support_interface_enable = True
|
||||||
|
support_top_distance = =support_z_distance
|
||||||
|
support_z_distance = =math.ceil(0.3/layer_height)*layer_height
|
||||||
top_bottom_thickness = 1
|
top_bottom_thickness = 1
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user