Don't duplicate background resizing to contents

The code in Button is
panel.implicitWidth: max(label+borders, backgroundImplicitSize)

by setting the background implicitSize to be max(size, labels+borders)
we just duplicate the functionality.

This worked, but icon only buttons became smaller because we weren't
setting the implicitHeight of the label properly.

(two wrongs were making a right)

We need to move the RowLayout inside an Item as we are modiyfing the
preferredHeight of RowLayout, but this doesn't sync back to updating the
implicitHeight which Button.qml uses.

This fixes all binding loops and the rather broken icon only flat
button.

Change-Id: Id2f9c2ab37b2280ee69dc1473f388fe686e3327e
This commit is contained in:
David Edmundson 2014-09-23 00:41:12 +02:00 committed by David Edmundson
parent b2a5ebc926
commit 8a70067e8c

View File

@ -34,72 +34,84 @@ QtQuickControlStyle.ButtonStyle {
property int minimumWidth property int minimumWidth
property int minimumHeight property int minimumHeight
label: RowLayout { label: Item {
id: buttonContent //wrapper is needed as we are adjusting the preferredHeight of the layout from the default
spacing: units.smallSpacing //and the implicitHeight is implicitly read only
Layout.preferredHeight: Math.max(units.iconSizes.small, label.implicitHeight) implicitHeight: buttonContent.Layout.preferredHeight
implicitWidth: buttonContent.implicitWidth
RowLayout {
id: buttonContent
anchors.fill: parent
spacing: units.smallSpacing
property real minimumWidth: Layout.minimumWidth + style.padding.left + style.padding.right Layout.preferredHeight: Math.max(units.iconSizes.small, label.implicitHeight)
onMinimumWidthChanged: {
if (control.minimumWidth !== undefined) { property real minimumWidth: Layout.minimumWidth + style.padding.left + style.padding.right
style.minimumWidth = minimumWidth; onMinimumWidthChanged: {
control.minimumWidth = minimumWidth; if (control.minimumWidth !== undefined) {
style.minimumWidth = minimumWidth;
control.minimumWidth = minimumWidth;
}
} }
}
property real minimumHeight: Layout.preferredHeight + style.padding.top + style.padding.bottom property real minimumHeight: Layout.preferredHeight + style.padding.top + style.padding.bottom
onMinimumHeightChanged: { onMinimumHeightChanged: {
if (control.minimumHeight !== undefined) { if (control.minimumHeight !== undefined) {
style.minimumHeight = minimumHeight; style.minimumHeight = minimumHeight;
control.minimumHeight = minimumHeight; control.minimumHeight = minimumHeight;
}
} }
}
PlasmaCore.IconItem { PlasmaCore.IconItem {
id: icon id: icon
source: control.iconName || control.iconSource source: control.iconName || control.iconSource
anchors.verticalCenter: parent.verticalCenter anchors.verticalCenter: parent.verticalCenter
Layout.minimumWidth: valid ? parent.height: 0
Layout.maximumWidth: Layout.minimumWidth
visible: valid
Layout.minimumHeight: Layout.minimumWidth
Layout.maximumHeight: Layout.minimumWidth
active: control.hovered
colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup
}
PlasmaComponents.Label { implicitHeight: label.implicitHeight
id: label implicitWidth: implicitHeight
Layout.minimumWidth: implicitWidth
text: control.text
font: control.font
visible: control.text != ""
Layout.fillWidth: true
height: parent.height
color: control.hovered || !control.flat ? theme.buttonTextColor : theme.textColor
horizontalAlignment: icon.valid ? Text.AlignLeft : Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
elide: Text.ElideRight
}
PlasmaExtras.ConditionalLoader { Layout.minimumWidth: valid ? parent.height: 0
id: arrow Layout.maximumWidth: Layout.minimumWidth
when: control.menu !== null visible: valid
visible: when Layout.minimumHeight: Layout.minimumWidth
Layout.minimumWidth: units.iconSizes.small Layout.maximumHeight: Layout.minimumWidth
Layout.maximumWidth: Layout.minimumWidth active: control.hovered
Layout.alignment: Qt.AlignVCenter colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup
height: width }
source: Component { PlasmaComponents.Label {
PlasmaCore.SvgItem { id: label
visible: control.menu !== null Layout.minimumWidth: implicitWidth
anchors.fill: parent text: control.text
svg: PlasmaCore.Svg { font: control.font
imagePath: "widgets/arrows" visible: control.text != ""
colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup Layout.fillWidth: true
height: parent.height
color: control.hovered || !control.flat ? theme.buttonTextColor : theme.textColor
horizontalAlignment: icon.valid ? Text.AlignLeft : Text.AlignHCenter
verticalAlignment: Text.AlignVCenter
elide: Text.ElideRight
}
PlasmaExtras.ConditionalLoader {
id: arrow
when: control.menu !== null
visible: when
Layout.minimumWidth: units.iconSizes.small
Layout.maximumWidth: Layout.minimumWidth
Layout.alignment: Qt.AlignVCenter
height: width
source: Component {
PlasmaCore.SvgItem {
visible: control.menu !== null
anchors.fill: parent
svg: PlasmaCore.Svg {
imagePath: "widgets/arrows"
colorGroup: control.hovered || !control.flat ? PlasmaCore.Theme.ButtonColorGroup : PlasmaCore.Theme.NormalColorGroup
}
elementId: "down-arrow"
} }
elementId: "down-arrow"
} }
} }
} }
@ -117,7 +129,9 @@ QtQuickControlStyle.ButtonStyle {
id: roundButtonComponent id: roundButtonComponent
Item { Item {
id: roundButtonDelegate id: roundButtonDelegate
anchors.fill: parent implicitHeight: Math.floor(theme.mSize(theme.defaultFont).height*1.6)
implicitWidth: implicitHeight
property QtObject margins: QtObject { property QtObject margins: QtObject {
property int left: control.width/8 property int left: control.width/8
property int top: control.width/8 property int top: control.width/8
@ -166,13 +180,13 @@ QtQuickControlStyle.ButtonStyle {
id: buttonComponent id: buttonComponent
Item { Item {
id: buttonSurface id: buttonSurface
implicitHeight: Math.floor(Math.max(theme.mSize(theme.defaultFont).height*1.6, style.minimumHeight)) implicitHeight: Math.floor(theme.mSize(theme.defaultFont).height*1.6)
implicitWidth: { implicitWidth: {
if (control.text.length == 0) { if (control.text.length == 0) {
implicitHeight; implicitHeight;
} else { } else {
Math.max(theme.mSize(theme.defaultFont).width*12, style.minimumWidth); Math.floor(theme.mSize(theme.defaultFont).width*12);
} }
} }
Connections { Connections {