mirror of
https://github.com/alicevision/Meshroom.git
synced 2025-06-20 19:47:22 +02:00
55 lines
1.5 KiB
QML
55 lines
1.5 KiB
QML
import QtQuick
|
|
import QtQuick.Controls
|
|
import QtQuick.Layouts
|
|
|
|
/**
|
|
* MaterialToolButton is a standard ToolButton using MaterialIcons font.
|
|
* It also shows up its tooltip when hovered.
|
|
*/
|
|
|
|
ToolButton {
|
|
id: control
|
|
property alias iconText: icon.text
|
|
property alias iconSize: icon.font.pointSize
|
|
property alias label: labelItem.text
|
|
padding: 0
|
|
ToolTip.visible: ToolTip.text && hovered
|
|
ToolTip.delay: 100
|
|
|
|
property alias labelItem: labelItem
|
|
property alias iconItem: icon
|
|
property alias rowIconLabel: rowIconLabel
|
|
|
|
contentItem: RowLayout {
|
|
id: rowIconLabel
|
|
Layout.margins: 0
|
|
Label {
|
|
id: icon
|
|
font.family: MaterialIcons.fontFamily
|
|
font.pointSize: 13
|
|
padding: 0
|
|
text: ""
|
|
color: (checked ? palette.highlight : palette.text)
|
|
}
|
|
Label {
|
|
id: labelItem
|
|
text: ""
|
|
padding: 0
|
|
color: (checked ? palette.highlight : palette.text)
|
|
Layout.fillWidth: true
|
|
}
|
|
}
|
|
background: Rectangle {
|
|
color: {
|
|
if (enabled && (pressed || checked || hovered)) {
|
|
if (pressed || checked)
|
|
return Qt.darker(parent.palette.base, 1.3)
|
|
if (hovered)
|
|
return Qt.darker(parent.palette.base, 0.6)
|
|
}
|
|
return "transparent"
|
|
}
|
|
|
|
border.color: checked ? Qt.darker(parent.palette.base, 1.4) : "transparent"
|
|
}
|
|
}
|