mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-04-22 13:49:39 +08:00
402 lines
14 KiB
QML
402 lines
14 KiB
QML
// Copyright (c) 2015 Ultimaker B.V.
|
|
// Uranium is released under the terms of the AGPLv3 or higher.
|
|
|
|
import QtQuick 2.2
|
|
import QtQuick.Controls 1.2
|
|
import QtQuick.Controls.Styles 1.2
|
|
import QtQuick.Window 2.2
|
|
|
|
import UM 1.1 as UM
|
|
|
|
Item {
|
|
id: base;
|
|
|
|
width: 0;
|
|
height: 0;
|
|
|
|
property variant position: mapToItem(null, 0, 0)
|
|
|
|
property real viewportWidth: UM.Application.mainWindow.width * UM.Application.mainWindow.viewportRect.width;
|
|
property real viewportHeight: UM.Application.mainWindow.height * UM.Application.mainWindow.viewportRect.height;
|
|
|
|
property int currentIndex;
|
|
|
|
Rectangle {
|
|
id: settingsPanel;
|
|
|
|
z: 3;
|
|
|
|
width: UM.Theme.sizes.per_object_settings_panel.width;
|
|
height: items.height + UM.Theme.sizes.default_margin.height * 2;
|
|
|
|
opacity: 0;
|
|
Behavior on opacity { NumberAnimation { } }
|
|
|
|
border.width: UM.Theme.sizes.per_object_settings_panel_border.width;
|
|
border.color: UM.Theme.colors.per_object_settings_panel_border;
|
|
|
|
color: UM.Theme.colors.per_object_settings_panel_background;
|
|
|
|
DropArea {
|
|
anchors.fill: parent;
|
|
}
|
|
|
|
Button {
|
|
id: closeButton;
|
|
width: UM.Theme.sizes.message_close.width;
|
|
height: UM.Theme.sizes.message_close.height;
|
|
anchors {
|
|
right: parent.right;
|
|
rightMargin: UM.Theme.sizes.default_margin.width / 2;
|
|
top: parent.top;
|
|
topMargin: UM.Theme.sizes.default_margin.width / 2;
|
|
}
|
|
UM.RecolorImage {
|
|
anchors.fill: parent;
|
|
sourceSize.width: width
|
|
sourceSize.height: width
|
|
color: UM.Theme.colors.message_dismiss
|
|
source: UM.Theme.icons.cross2;
|
|
}
|
|
|
|
onClicked: settingsPanel.opacity = 0
|
|
|
|
style: ButtonStyle {
|
|
background: Rectangle {
|
|
color: UM.Theme.colors.message_background
|
|
}
|
|
}
|
|
}
|
|
|
|
Column {
|
|
id: items
|
|
anchors.top: parent.top;
|
|
anchors.topMargin: UM.Theme.sizes.default_margin.height;
|
|
|
|
spacing: UM.Theme.sizes.default_lining.height;
|
|
|
|
UM.SettingItem {
|
|
id: profileSelection
|
|
|
|
x: UM.Theme.sizes.per_object_settings_panel_border.width + 1
|
|
|
|
width: UM.Theme.sizes.setting.width;
|
|
height: UM.Theme.sizes.setting.height;
|
|
|
|
name: catalog.i18nc("@label", "Profile")
|
|
type: "enum"
|
|
|
|
style: UM.Theme.styles.setting_item;
|
|
|
|
options: UM.ProfilesModel { addUseGlobal: true }
|
|
|
|
value: UM.ActiveTool.properties.Model.getItem(base.currentIndex).profile
|
|
|
|
onItemValueChanged: {
|
|
var item = UM.ActiveTool.properties.Model.getItem(base.currentIndex);
|
|
UM.ActiveTool.properties.Model.setObjectProfile(item.id, value)
|
|
}
|
|
}
|
|
|
|
Repeater {
|
|
id: settings;
|
|
|
|
model: UM.ActiveTool.properties.Model.getItem(base.currentIndex).settings
|
|
|
|
UM.SettingItem {
|
|
width: UM.Theme.sizes.setting.width;
|
|
height: UM.Theme.sizes.setting.height;
|
|
x: UM.Theme.sizes.per_object_settings_panel_border.width + 1
|
|
|
|
name: model.label;
|
|
type: model.type;
|
|
value: model.value;
|
|
description: model.description;
|
|
unit: model.unit;
|
|
valid: model.valid;
|
|
options: model.options
|
|
|
|
style: UM.Theme.styles.setting_item;
|
|
|
|
onItemValueChanged: {
|
|
settings.model.setSettingValue(model.key, value)
|
|
}
|
|
|
|
Button
|
|
{
|
|
anchors.left: parent.horizontalCenter;
|
|
anchors.leftMargin: UM.Theme.sizes.default_margin.width;
|
|
|
|
width: UM.Theme.sizes.setting.height;
|
|
height: UM.Theme.sizes.setting.height;
|
|
|
|
opacity: parent.hovered || hovered ? 1 : 0;
|
|
onClicked: UM.ActiveTool.properties.Model.removeSettingOverride(UM.ActiveTool.properties.Model.getItem(base.currentIndex).id, model.key)
|
|
|
|
style: ButtonStyle
|
|
{
|
|
background: Rectangle
|
|
{
|
|
color: control.hovered ? control.parent.style.controlHighlightColor : control.parent.style.controlColor;
|
|
UM.RecolorImage
|
|
{
|
|
anchors.verticalCenter: parent.verticalCenter
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
width: parent.width/2
|
|
height: parent.height/2
|
|
sourceSize.width: width
|
|
sourceSize.height: width
|
|
color: UM.Theme.colors.setting_control_revert
|
|
source: UM.Theme.icons.cross1
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
Item
|
|
{
|
|
height: UM.Theme.sizes.default_margin.height / 2
|
|
width: parent.width
|
|
}
|
|
|
|
Button
|
|
{
|
|
id: customise_settings_button;
|
|
anchors.right: profileSelection.right;
|
|
visible: parseInt(UM.Preferences.getValue("cura/active_mode")) == 1
|
|
|
|
text: catalog.i18nc("@action:button", "Customize Settings");
|
|
|
|
style: ButtonStyle
|
|
{
|
|
background: Rectangle
|
|
{
|
|
width: control.width;
|
|
height: control.height;
|
|
color: control.hovered ? UM.Theme.colors.load_save_button_hover : UM.Theme.colors.load_save_button;
|
|
}
|
|
label: Label
|
|
{
|
|
text: control.text;
|
|
color: UM.Theme.colors.load_save_button_text;
|
|
}
|
|
}
|
|
|
|
onClicked: settingPickDialog.visible = true;
|
|
|
|
Connections
|
|
{
|
|
target: UM.Preferences;
|
|
|
|
onPreferenceChanged:
|
|
{
|
|
customise_settings_button.visible = parseInt(UM.Preferences.getValue("cura/active_mode"))
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
UM.I18nCatalog { id: catalog; name: "uranium"; }
|
|
}
|
|
|
|
Repeater {
|
|
model: UM.ActiveTool.properties.Model;
|
|
delegate: Button {
|
|
x: ((model.x + 1.0) / 2.0) * base.viewportWidth - base.position.x - width / 2
|
|
y: -((model.y + 1.0) / 2.0) * base.viewportHeight + (base.viewportHeight - base.position.y) + height / 2
|
|
|
|
width: UM.Theme.sizes.per_object_settings_button.width
|
|
height: UM.Theme.sizes.per_object_settings_button.height
|
|
|
|
tooltip: catalog.i18nc("@info:tooltip", "Customise settings for this object");
|
|
|
|
checkable: true;
|
|
onClicked: {
|
|
if(settingsPanel.opacity < 0.5) //Per-object panel is not currently displayed.
|
|
{
|
|
base.currentIndex = index;
|
|
|
|
settingsPanel.anchors.left = right;
|
|
settingsPanel.anchors.top = top;
|
|
|
|
settingsPanel.opacity = 1;
|
|
}
|
|
else //Per-object panel is already displayed. Deactivate it (same behaviour as the close button).
|
|
{
|
|
settingsPanel.opacity = 0;
|
|
}
|
|
}
|
|
|
|
style: ButtonStyle
|
|
{
|
|
background: Rectangle
|
|
{
|
|
width: control.width;
|
|
height: control.height;
|
|
|
|
color: control.hovered ? UM.Theme.colors.button_active : UM.Theme.colors.button_hover;
|
|
}
|
|
label: Image {
|
|
width: control.width;
|
|
height: control.height;
|
|
sourceSize.width: width;
|
|
sourceSize.height: height;
|
|
source: UM.Theme.icons.plus;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
UM.Dialog {
|
|
id: settingPickDialog
|
|
|
|
title: catalog.i18nc("@title:window", "Pick a Setting to Customize")
|
|
|
|
TextField {
|
|
id: filter;
|
|
|
|
anchors {
|
|
top: parent.top;
|
|
left: parent.left;
|
|
right: parent.right;
|
|
}
|
|
|
|
placeholderText: catalog.i18nc("@label:textbox", "Filter...");
|
|
|
|
onTextChanged: settingCategoriesModel.filter(text);
|
|
}
|
|
|
|
ScrollView {
|
|
id: view;
|
|
anchors {
|
|
top: filter.bottom;
|
|
left: parent.left;
|
|
right: parent.right;
|
|
bottom: parent.bottom;
|
|
}
|
|
|
|
Column {
|
|
width: view.width - UM.Theme.sizes.default_margin.width * 2;
|
|
height: childrenRect.height;
|
|
|
|
Repeater {
|
|
id: settingList;
|
|
|
|
model: UM.SettingCategoriesModel { id: settingCategoriesModel; }
|
|
|
|
delegate: Item {
|
|
id: delegateItem;
|
|
|
|
width: parent.width;
|
|
height: childrenRect.height;
|
|
|
|
ToolButton {
|
|
id: categoryHeader;
|
|
text: model.name;
|
|
checkable: true;
|
|
width: parent.width;
|
|
onCheckedChanged: settingsColumn.state != "" ? settingsColumn.state = "" : settingsColumn.state = "collapsed";
|
|
|
|
style: ButtonStyle {
|
|
background: Rectangle
|
|
{
|
|
width: control.width;
|
|
height: control.height;
|
|
color: control.hovered ? palette.highlight : "transparent";
|
|
}
|
|
label: Row
|
|
{
|
|
spacing: UM.Theme.sizes.default_margin.width;
|
|
Image
|
|
{
|
|
anchors.verticalCenter: parent.verticalCenter;
|
|
source: control.checked ? UM.Theme.icons.arrow_right : UM.Theme.icons.arrow_bottom;
|
|
}
|
|
Label
|
|
{
|
|
text: control.text;
|
|
font.bold: true;
|
|
color: control.hovered ? palette.highlightedText : palette.text;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
property variant settingsModel: model.settings;
|
|
|
|
visible: model.visible;
|
|
|
|
Column {
|
|
id: settingsColumn;
|
|
|
|
anchors.top: categoryHeader.bottom;
|
|
|
|
property real childrenHeight:
|
|
{
|
|
var h = 0.0;
|
|
for(var i in children)
|
|
{
|
|
var item = children[i];
|
|
h += children[i].height;
|
|
if(item.settingVisible)
|
|
{
|
|
if(i > 0)
|
|
{
|
|
h += spacing;
|
|
}
|
|
}
|
|
}
|
|
return h;
|
|
}
|
|
|
|
width: childrenRect.width;
|
|
height: childrenHeight;
|
|
Repeater {
|
|
model: delegateItem.settingsModel;
|
|
|
|
delegate: ToolButton {
|
|
id: button;
|
|
x: model.depth * UM.Theme.sizes.default_margin.width;
|
|
text: model.name;
|
|
tooltip: model.description;
|
|
|
|
onClicked: {
|
|
var object_id = UM.ActiveTool.properties.Model.getItem(base.currentIndex).id;
|
|
UM.ActiveTool.properties.Model.addSettingOverride(object_id, model.key);
|
|
settingPickDialog.visible = false;
|
|
}
|
|
|
|
states: State {
|
|
name: "filtered"
|
|
when: model.filtered || !model.visible || !model.enabled
|
|
PropertyChanges { target: button; height: 0; opacity: 0; }
|
|
}
|
|
}
|
|
}
|
|
|
|
states: State {
|
|
name: "collapsed";
|
|
|
|
PropertyChanges { target: settingsColumn; opacity: 0; height: 0; }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
rightButtons: [
|
|
Button {
|
|
text: catalog.i18nc("@action:button", "Cancel");
|
|
onClicked: {
|
|
settingPickDialog.visible = false;
|
|
}
|
|
}
|
|
]
|
|
}
|
|
|
|
SystemPalette { id: palette; }
|
|
}
|