mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-05-07 09:04:31 +08:00
Merge branch 'master' of github.com:Ultimaker/PluggableCura
Conflicts: plugins/USBPrinting/PrinterConnection.py plugins/USBPrinting/USBPrinterManager.py plugins/Views/LayerView/LayerView.py
This commit is contained in:
commit
8b5e5dbfda
15
LayerView.py
15
LayerView.py
@ -4,30 +4,39 @@ from UM.Scene.Iterator.DepthFirstIterator import DepthFirstIterator
|
|||||||
from UM.Resources import Resources
|
from UM.Resources import Resources
|
||||||
|
|
||||||
|
|
||||||
|
## View used to display g-code paths.
|
||||||
class LayerView(View):
|
class LayerView(View):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super().__init__()
|
super().__init__()
|
||||||
self._material = None
|
self._material = None
|
||||||
|
self._num_layers = 0
|
||||||
|
self._layer_percentage = 0 # what percentage of layers need to be shown (SLider gives value between 0 - 100)
|
||||||
|
|
||||||
def beginRendering(self):
|
def beginRendering(self):
|
||||||
scene = self.getController().getScene()
|
scene = self.getController().getScene()
|
||||||
renderer = self.getRenderer()
|
renderer = self.getRenderer()
|
||||||
renderer.setRenderSelection(False)
|
renderer.setRenderSelection(False)
|
||||||
|
self._num_layers = 0
|
||||||
|
|
||||||
if not self._material:
|
if not self._material:
|
||||||
self._material = renderer.createMaterial(Resources.getPath(Resources.ShadersLocation, 'basic.vert'), Resources.getPath(Resources.ShadersLocation, 'vertexcolor.frag'))
|
self._material = renderer.createMaterial(Resources.getPath(Resources.ShadersLocation, 'basic.vert'), Resources.getPath(Resources.ShadersLocation, 'vertexcolor.frag'))
|
||||||
|
|
||||||
self._material.setUniformValue("u_color", [1.0, 0.0, 0.0, 1.0])
|
self._material.setUniformValue("u_color", [1.0, 0.0, 0.0, 1.0])
|
||||||
|
|
||||||
for node in DepthFirstIterator(scene.getRoot()):
|
for node in DepthFirstIterator(scene.getRoot()):
|
||||||
if not node.render(renderer):
|
if not node.render(renderer):
|
||||||
if node.getMeshData() and node.isVisible():
|
if node.getMeshData() and node.isVisible():
|
||||||
try:
|
try:
|
||||||
layerData = node.getMeshData().layerData
|
layer_data = node.getMeshData().layerData
|
||||||
|
if self._num_layers < len(layer_data.getLayers()):
|
||||||
|
self._num_layers = len(layer_data.getLayers())
|
||||||
|
|
||||||
except AttributeError:
|
except AttributeError:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
renderer.queueNode(node, mesh = layerData, material = self._material, mode = Renderer.RenderLines)
|
renderer.queueNode(node, mesh = layer_data, material = self._material, mode = Renderer.RenderLines)
|
||||||
|
|
||||||
|
def setLayer(self, value):
|
||||||
|
self._layer_percentage = value
|
||||||
|
|
||||||
def endRendering(self):
|
def endRendering(self):
|
||||||
pass
|
pass
|
||||||
|
35
LayerView.qml
Normal file
35
LayerView.qml
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
import QtQuick 2.2
|
||||||
|
import QtQuick.Controls 1.2
|
||||||
|
import QtQuick.Layouts 1.1
|
||||||
|
import QtQuick.Controls.Styles 1.1
|
||||||
|
|
||||||
|
import UM 1.0 as UM
|
||||||
|
|
||||||
|
Item
|
||||||
|
{
|
||||||
|
width: 250
|
||||||
|
height: 250
|
||||||
|
/*Rectangle
|
||||||
|
{
|
||||||
|
color: "blue"
|
||||||
|
width: 250
|
||||||
|
height:250
|
||||||
|
}*/
|
||||||
|
Slider
|
||||||
|
{
|
||||||
|
width: 10
|
||||||
|
height: 250
|
||||||
|
anchors.right : parent.right
|
||||||
|
//anchors.fill: parent
|
||||||
|
//Layout.preferredHeight: UM.Theme.sizes.section.height;
|
||||||
|
orientation: Qt.Vertical
|
||||||
|
minimumValue: 0;
|
||||||
|
maximumValue: 100;
|
||||||
|
|
||||||
|
value: 50;
|
||||||
|
onValueChanged: UM.ActiveView.triggerAction("setLayer", value)
|
||||||
|
|
||||||
|
style: UM.Theme.styles.slider;
|
||||||
|
//Component.onCompleted: {console.log(UM.Theme.styles.slider)}
|
||||||
|
}
|
||||||
|
}
|
@ -8,7 +8,8 @@ def getMetaData():
|
|||||||
"name": "Layer View"
|
"name": "Layer View"
|
||||||
},
|
},
|
||||||
'view': {
|
'view': {
|
||||||
'name': 'Layers'
|
'name': 'Layers',
|
||||||
|
'view_panel': 'LayerView.qml'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user