mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-04-22 05:39:37 +08:00
223 lines
7.0 KiB
QML
223 lines
7.0 KiB
QML
// Copyright (c) 2018 Ultimaker B.V.
|
|
// Cura is released under the terms of the LGPLv3 or higher.
|
|
|
|
import QtQuick 2.2
|
|
import QtQuick.Controls 2.3
|
|
|
|
import UM 1.2 as UM
|
|
import Cura 1.0 as Cura
|
|
|
|
Item
|
|
{
|
|
id: base
|
|
|
|
width: buttons.width
|
|
height: buttons.height
|
|
property int activeY
|
|
|
|
Item
|
|
{
|
|
id: buttons
|
|
width: parent.visible ? toolButtons.width : 0
|
|
height: childrenRect.height
|
|
|
|
Behavior on width { NumberAnimation { duration: 100 } }
|
|
|
|
// Used to create a rounded rectangle behind the toolButtons
|
|
Rectangle
|
|
{
|
|
anchors
|
|
{
|
|
fill: toolButtons
|
|
leftMargin: -radius - border.width
|
|
rightMargin: -border.width
|
|
topMargin: -border.width
|
|
bottomMargin: -border.width
|
|
}
|
|
radius: UM.Theme.getSize("default_radius").width
|
|
color: UM.Theme.getColor("lining")
|
|
}
|
|
|
|
Column
|
|
{
|
|
id: toolButtons
|
|
|
|
anchors.top: parent.top
|
|
anchors.right: parent.right
|
|
spacing: UM.Theme.getSize("default_lining").height
|
|
|
|
Repeater
|
|
{
|
|
id: repeat
|
|
|
|
model: UM.ToolModel { id: toolsModel }
|
|
width: childrenRect.width
|
|
height: childrenRect.height
|
|
|
|
delegate: ToolbarButton
|
|
{
|
|
text: model.name + (model.shortcut ? (" (" + model.shortcut + ")") : "")
|
|
checkable: true
|
|
checked: model.active
|
|
enabled: model.enabled && UM.Selection.hasSelection && UM.Controller.toolsEnabled
|
|
|
|
isTopElement: toolsModel.getItem(0).id == model.id
|
|
isBottomElement: toolsModel.getItem(toolsModel.count - 1).id == model.id
|
|
|
|
toolItem: UM.RecolorImage
|
|
{
|
|
source: UM.Theme.getIcon(model.icon) != "" ? UM.Theme.getIcon(model.icon) : "file:///" + model.location + "/" + model.icon
|
|
color: UM.Theme.getColor("icon")
|
|
|
|
sourceSize: UM.Theme.getSize("button_icon")
|
|
}
|
|
|
|
onCheckedChanged:
|
|
{
|
|
if (checked)
|
|
{
|
|
base.activeY = y;
|
|
}
|
|
}
|
|
|
|
//Workaround since using ToolButton's onClicked would break the binding of the checked property, instead
|
|
//just catch the click so we do not trigger that behaviour.
|
|
MouseArea
|
|
{
|
|
anchors.fill: parent;
|
|
onClicked:
|
|
{
|
|
forceActiveFocus() //First grab focus, so all the text fields are updated
|
|
if(parent.checked)
|
|
{
|
|
UM.Controller.setActiveTool(null);
|
|
}
|
|
else
|
|
{
|
|
UM.Controller.setActiveTool(model.id);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
// Used to create a rounded rectangle behind the extruderButtons
|
|
Rectangle
|
|
{
|
|
anchors
|
|
{
|
|
fill: extruderButtons
|
|
leftMargin: -radius - border.width
|
|
rightMargin: -border.width
|
|
topMargin: -border.width
|
|
bottomMargin: -border.width
|
|
}
|
|
radius: UM.Theme.getSize("default_radius").width
|
|
color: UM.Theme.getColor("lining")
|
|
visible: extrudersModel.items.length > 1
|
|
}
|
|
|
|
Column
|
|
{
|
|
id: extruderButtons
|
|
|
|
anchors.topMargin: UM.Theme.getSize("default_margin").height
|
|
anchors.top: toolButtons.bottom
|
|
anchors.right: parent.right
|
|
spacing: UM.Theme.getSize("default_lining").height
|
|
|
|
Repeater
|
|
{
|
|
id: extruders
|
|
width: childrenRect.width
|
|
height: childrenRect.height
|
|
model: extrudersModel.items.length > 1 ? extrudersModel : 0
|
|
|
|
delegate: ExtruderButton
|
|
{
|
|
extruder: model
|
|
isTopElement: extrudersModel.getItem(0).id == model.id
|
|
isBottomElement: extrudersModel.getItem(extrudersModel.rowCount() - 1).id == model.id
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
property var extrudersModel: CuraApplication.getExtrudersModel()
|
|
|
|
UM.PointingRectangle
|
|
{
|
|
id: panelBorder
|
|
|
|
anchors.left: parent.right
|
|
anchors.leftMargin: UM.Theme.getSize("default_margin").width
|
|
anchors.top: base.top
|
|
anchors.topMargin: base.activeY
|
|
z: buttons.z - 1
|
|
|
|
target: Qt.point(parent.right, base.activeY + Math.round(UM.Theme.getSize("button").height/2))
|
|
arrowSize: UM.Theme.getSize("default_arrow").width
|
|
|
|
width:
|
|
{
|
|
if (panel.item && panel.width > 0)
|
|
{
|
|
return Math.max(panel.width + 2 * UM.Theme.getSize("default_margin").width)
|
|
}
|
|
else
|
|
{
|
|
return 0;
|
|
}
|
|
}
|
|
height: panel.item ? panel.height + 2 * UM.Theme.getSize("default_margin").height : 0
|
|
|
|
opacity: panel.item && panel.width > 0 ? 1 : 0
|
|
Behavior on opacity { NumberAnimation { duration: 100 } }
|
|
|
|
color: UM.Theme.getColor("tool_panel_background")
|
|
borderColor: UM.Theme.getColor("lining")
|
|
borderWidth: UM.Theme.getSize("default_lining").width
|
|
|
|
MouseArea //Catch all mouse events (so scene doesnt handle them)
|
|
{
|
|
anchors.fill: parent
|
|
acceptedButtons: Qt.NoButton
|
|
onWheel: wheel.accepted = true
|
|
}
|
|
|
|
Loader
|
|
{
|
|
id: panel
|
|
|
|
x: UM.Theme.getSize("default_margin").width
|
|
y: UM.Theme.getSize("default_margin").height
|
|
|
|
source: UM.ActiveTool.valid ? UM.ActiveTool.activeToolPanel : ""
|
|
enabled: UM.Controller.toolsEnabled
|
|
}
|
|
}
|
|
|
|
// This rectangle displays the information about the current angle etc. when
|
|
// dragging a tool handle.
|
|
Rectangle
|
|
{
|
|
x: -base.x + base.mouseX + UM.Theme.getSize("default_margin").width
|
|
y: -base.y + base.mouseY + UM.Theme.getSize("default_margin").height
|
|
|
|
width: toolHint.width + UM.Theme.getSize("default_margin").width
|
|
height: toolHint.height;
|
|
color: UM.Theme.getColor("tooltip")
|
|
Label
|
|
{
|
|
id: toolHint
|
|
text: UM.ActiveTool.properties.getValue("ToolHint") != undefined ? UM.ActiveTool.properties.getValue("ToolHint") : ""
|
|
color: UM.Theme.getColor("tooltip_text")
|
|
font: UM.Theme.getFont("default")
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
}
|
|
|
|
visible: toolHint.text != ""
|
|
}
|
|
}
|