mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-08-15 11:55:53 +08:00
Create the new component that gathers all the printjob information
(times and material usage) in a popup that is shown when the "i" icon is pressed. Contributes to CURA-5786.
This commit is contained in:
parent
c862e72514
commit
ef7ac3b089
@ -39,10 +39,10 @@ Button
|
|||||||
|
|
||||||
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
closePolicy: Popup.CloseOnEscape | Popup.CloseOnPressOutsideParent
|
||||||
|
|
||||||
contentItem: Label
|
contentItem: PrintJobInformation
|
||||||
{
|
{
|
||||||
id: panel
|
id: printJobInformation
|
||||||
text: "Lorem ipsum dolor sit amet,\nconsectetur adipiscing elit, \nsed do eiusmod tempor incididunt \nut labore et dolore magna aliqua. \nUt enim ad minim veniam, ..."
|
width: UM.Theme.getSize("action_panel_information_widget").width
|
||||||
}
|
}
|
||||||
|
|
||||||
background: UM.PointingRectangle
|
background: UM.PointingRectangle
|
||||||
|
166
resources/qml/ActionPanel/PrintJobInformation.qml
Normal file
166
resources/qml/ActionPanel/PrintJobInformation.qml
Normal file
@ -0,0 +1,166 @@
|
|||||||
|
// Copyright (c) 2018 Ultimaker B.V.
|
||||||
|
// Cura is released under the terms of the LGPLv3 or higher.
|
||||||
|
|
||||||
|
import QtQuick 2.7
|
||||||
|
import QtQuick.Controls 2.1
|
||||||
|
|
||||||
|
import UM 1.1 as UM
|
||||||
|
import Cura 1.0 as Cura
|
||||||
|
|
||||||
|
Column
|
||||||
|
{
|
||||||
|
id: base
|
||||||
|
spacing: UM.Theme.getSize("default_margin").width
|
||||||
|
|
||||||
|
UM.I18nCatalog
|
||||||
|
{
|
||||||
|
id: catalog
|
||||||
|
name: "cura"
|
||||||
|
}
|
||||||
|
|
||||||
|
Column
|
||||||
|
{
|
||||||
|
id: timeSpecification
|
||||||
|
spacing: UM.Theme.getSize("thin_margin").width
|
||||||
|
width: parent.width
|
||||||
|
topPadding: UM.Theme.getSize("default_margin").height
|
||||||
|
leftPadding: UM.Theme.getSize("default_margin").width
|
||||||
|
rightPadding: UM.Theme.getSize("default_margin").width
|
||||||
|
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
text: catalog.i18nc("@label", "Time specification").toUpperCase()
|
||||||
|
color: UM.Theme.getColor("primary")
|
||||||
|
font: UM.Theme.getFont("small")
|
||||||
|
renderType: Text.NativeRendering
|
||||||
|
}
|
||||||
|
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
property var printDuration: PrintInformation.currentPrintTime
|
||||||
|
|
||||||
|
function getTimeSpecifications()
|
||||||
|
{
|
||||||
|
// All the time information for the different features is achieved
|
||||||
|
var printTime = PrintInformation.getFeaturePrintTimes()
|
||||||
|
var totalSeconds = parseInt(printDuration.getDisplayString(UM.DurationFormat.Seconds))
|
||||||
|
|
||||||
|
// A message is created and displayed when the user hover the time label
|
||||||
|
var text = "<table width=\"100%\">"
|
||||||
|
for(var feature in printTime)
|
||||||
|
{
|
||||||
|
if(!printTime[feature].isTotalDurationZero)
|
||||||
|
{
|
||||||
|
text += "<tr><td>" + feature + ":</td>" +
|
||||||
|
"<td align=\"right\" valign=\"bottom\"> %1</td>".arg(printTime[feature].getDisplayString(UM.DurationFormat.ISO8601).slice(0,-3)) +
|
||||||
|
"<td align=\"right\" valign=\"bottom\"> %1%</td>".arg(Math.round(100 * parseInt(printTime[feature].getDisplayString(UM.DurationFormat.Seconds)) / totalSeconds)) +
|
||||||
|
"</tr>"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
text += "</table>"
|
||||||
|
print(text)
|
||||||
|
return text
|
||||||
|
}
|
||||||
|
|
||||||
|
text: getTimeSpecifications()
|
||||||
|
width: parent.width - 2 * UM.Theme.getSize("default_margin").width
|
||||||
|
color: UM.Theme.getColor("text")
|
||||||
|
font: UM.Theme.getFont("very_small")
|
||||||
|
renderType: Text.NativeRendering
|
||||||
|
textFormat: Text.RichText
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Column
|
||||||
|
{
|
||||||
|
id: materialSpecification
|
||||||
|
spacing: UM.Theme.getSize("thin_margin").width
|
||||||
|
width: parent.width
|
||||||
|
bottomPadding: UM.Theme.getSize("default_margin").height
|
||||||
|
leftPadding: UM.Theme.getSize("default_margin").width
|
||||||
|
rightPadding: UM.Theme.getSize("default_margin").width
|
||||||
|
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
text: catalog.i18nc("@label", "Material specification").toUpperCase()
|
||||||
|
color: UM.Theme.getColor("primary")
|
||||||
|
font: UM.Theme.getFont("small")
|
||||||
|
renderType: Text.NativeRendering
|
||||||
|
}
|
||||||
|
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
property var printMaterialLengths: PrintInformation.materialLengths
|
||||||
|
property var printMaterialWeights: PrintInformation.materialWeights
|
||||||
|
property var printMaterialCosts: PrintInformation.materialCosts
|
||||||
|
property var printMaterialNames: PrintInformation.materialNames
|
||||||
|
|
||||||
|
function formatRow(items)
|
||||||
|
{
|
||||||
|
var rowHTML = "<tr>"
|
||||||
|
for(var item = 0; item < items.length; item++)
|
||||||
|
{
|
||||||
|
if (item == 0)
|
||||||
|
{
|
||||||
|
rowHTML += "<td valign=\"bottom\">%1</td>".arg(items[item])
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
rowHTML += "<td align=\"right\" valign=\"bottom\"> %1</td>".arg(items[item])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
rowHTML += "</tr>"
|
||||||
|
return rowHTML
|
||||||
|
}
|
||||||
|
|
||||||
|
function getMaterialSpecifications()
|
||||||
|
{
|
||||||
|
var lengths = []
|
||||||
|
var weights = []
|
||||||
|
var costs = []
|
||||||
|
var names = []
|
||||||
|
if(printMaterialLengths)
|
||||||
|
{
|
||||||
|
for(var index = 0; index < printMaterialLengths.length; index++)
|
||||||
|
{
|
||||||
|
if(printMaterialLengths[index] > 0)
|
||||||
|
{
|
||||||
|
names.push(printMaterialNames[index])
|
||||||
|
lengths.push(printMaterialLengths[index].toFixed(2))
|
||||||
|
weights.push(String(Math.round(printMaterialWeights[index])))
|
||||||
|
var cost = printMaterialCosts[index] == undefined ? 0 : printMaterialCosts[index].toFixed(2)
|
||||||
|
costs.push(cost)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(lengths.length == 0)
|
||||||
|
{
|
||||||
|
lengths = ["0.00"]
|
||||||
|
weights = ["0"]
|
||||||
|
costs = ["0.00"]
|
||||||
|
}
|
||||||
|
|
||||||
|
var text = "<table width=\"100%\">"
|
||||||
|
for(var index = 0; index < lengths.length; index++)
|
||||||
|
{
|
||||||
|
text += formatRow([
|
||||||
|
"%1:".arg(names[index]),
|
||||||
|
catalog.i18nc("@label m for meter", "%1m").arg(lengths[index]),
|
||||||
|
catalog.i18nc("@label g for grams", "%1g").arg(weights[index]),
|
||||||
|
"%1 %2".arg(UM.Preferences.getValue("cura/currency")).arg(costs[index]),
|
||||||
|
])
|
||||||
|
}
|
||||||
|
text += "</table>"
|
||||||
|
|
||||||
|
return text
|
||||||
|
}
|
||||||
|
|
||||||
|
text: getMaterialSpecifications()
|
||||||
|
width: parent.width - 2 * UM.Theme.getSize("default_margin").width
|
||||||
|
color: UM.Theme.getColor("text")
|
||||||
|
font: UM.Theme.getFont("very_small")
|
||||||
|
renderType: Text.NativeRendering
|
||||||
|
textFormat: Text.RichText
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -379,7 +379,7 @@
|
|||||||
"configuration_selector_widget": [35.0, 4.5],
|
"configuration_selector_widget": [35.0, 4.5],
|
||||||
"configuration_selector_mode_tabs": [0.0, 3.0],
|
"configuration_selector_mode_tabs": [0.0, 3.0],
|
||||||
|
|
||||||
"action_panel_widget": [35.0, 0.0],
|
"action_panel_information_widget": [20.0, 0.0],
|
||||||
"action_panel_button": [15.0, 3.0],
|
"action_panel_button": [15.0, 3.0],
|
||||||
|
|
||||||
"machine_selector_widget": [28.0, 4.5],
|
"machine_selector_widget": [28.0, 4.5],
|
||||||
|
Loading…
x
Reference in New Issue
Block a user