From 95bca4b50c4fd46ae190ac87ea8934523881b776 Mon Sep 17 00:00:00 2001 From: Sebastian Kügler Date: Thu, 7 Jan 2016 00:39:33 +0100 Subject: sync with mobilecomponents 9d179eb74a227 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - Workaround for black squares is merged upstream - brings back the FAB button, additional - swipe interaction improvements in the same Signed-off-by: Sebastian Kügler --- qt-mobile/qml/mobilecomponents/ApplicationWindow.qml | 2 -- qt-mobile/qml/mobilecomponents/ContextDrawer.qml | 3 ++- qt-mobile/qml/mobilecomponents/Icon.qml | 16 +++++++--------- qt-mobile/qml/mobilecomponents/Page.qml | 5 +---- .../qml/mobilecomponents/private/ActionButton.qml | 18 ++++++++++++++---- 5 files changed, 24 insertions(+), 20 deletions(-) (limited to 'qt-mobile/qml') diff --git a/qt-mobile/qml/mobilecomponents/ApplicationWindow.qml b/qt-mobile/qml/mobilecomponents/ApplicationWindow.qml index 0eaa81ec0..8926b0574 100644 --- a/qt-mobile/qml/mobilecomponents/ApplicationWindow.qml +++ b/qt-mobile/qml/mobilecomponents/ApplicationWindow.qml @@ -85,7 +85,6 @@ inputMethod.keyboardRectangle.y) : 0 width: Units.gridUnit * 25 height: Units.gridUnit * 30 -/* property alias actionButton: __actionButton ActionButton { id: __actionButton @@ -98,5 +97,4 @@ inputMethod.keyboardRectangle.y) : 0 visible: root.globalDrawer || root.contextDrawer } - */ } diff --git a/qt-mobile/qml/mobilecomponents/ContextDrawer.qml b/qt-mobile/qml/mobilecomponents/ContextDrawer.qml index 575ac3679..088399721 100644 --- a/qt-mobile/qml/mobilecomponents/ContextDrawer.qml +++ b/qt-mobile/qml/mobilecomponents/ContextDrawer.qml @@ -67,10 +67,11 @@ OverlayDrawer { } } delegate: BasicListItem { - enabled: true checked: modelData.checked icon: modelData.iconName label: model ? model.text : modelData.text + enabled: model ? model.enabled : modelData.enabled + opacity: enabled ? 1.0 : 0.6 onClicked: { if (modelData && modelData.trigger !== undefined) { modelData.trigger(); diff --git a/qt-mobile/qml/mobilecomponents/Icon.qml b/qt-mobile/qml/mobilecomponents/Icon.qml index 9f7be0f9b..150c181e6 100644 --- a/qt-mobile/qml/mobilecomponents/Icon.qml +++ b/qt-mobile/qml/mobilecomponents/Icon.qml @@ -38,13 +38,11 @@ Item { sourceSize.width: root.width sourceSize.height: root.height } - /* - * this appears to cause us to show nothing but black squares instead - * of icons on some Android devices - GammaAdjust { - anchors.fill: image - source: image - gamma: root.active ? 3.0 : 1 - } - */ + /* // FIXME: This causes black squares on some GLES drivers, notably on Adreno hardware + GammaAdjust { + anchors.fill: image + source: image + gamma: root.active ? 3.0 : 1 + } + */ } diff --git a/qt-mobile/qml/mobilecomponents/Page.qml b/qt-mobile/qml/mobilecomponents/Page.qml index 449c7aa47..9220357e6 100644 --- a/qt-mobile/qml/mobilecomponents/Page.qml +++ b/qt-mobile/qml/mobilecomponents/Page.qml @@ -45,11 +45,8 @@ Rectangle { * Defines the contextual actions for the page: * an easy way to assign actions in the right sliding panel */ - property alias contextualActions: internalContextualActions.data + property list contextualActions - Item { - id: internalContextualActions - } Layout.fillWidth: true color: "transparent" diff --git a/qt-mobile/qml/mobilecomponents/private/ActionButton.qml b/qt-mobile/qml/mobilecomponents/private/ActionButton.qml index 80f037e48..c6963c285 100644 --- a/qt-mobile/qml/mobilecomponents/private/ActionButton.qml +++ b/qt-mobile/qml/mobilecomponents/private/ActionButton.qml @@ -29,9 +29,9 @@ MouseArea { property bool checked: false //either Action or QAction should work here property QtObject action - Layout.minimumWidth: Units.iconSizes.large + Layout.minimumWidth: Units.iconSizes.medium Layout.maximumWidth: Layout.minimumWidth - implicitWidth: Units.iconSizes.large + implicitWidth: Units.iconSizes.medium implicitHeight: width drag { target: button @@ -52,11 +52,21 @@ MouseArea { transform: Translate { id: translateTransform } + property var downTimestamp; + property int startX + onPressed: { + downTimestamp = (new Date()).getTime(); + startX = button.x + } onReleased: { - if (globalDrawer && x > Math.min(parent.width/4*3, parent.width/2 + globalDrawer.contentItem.width/2)) { + //pixel/second + var speed = ((button.x - startX) / ((new Date()).getTime() - downTimestamp) * 1000); + + //project where it would be a full second in the future + if (globalDrawer && x + speed > Math.min(parent.width/4*3, parent.width/2 + globalDrawer.contentItem.width/2)) { globalDrawer.open(); contextDrawer.close(); - } else if (contextDrawer && x < Math.max(parent.width/4, parent.width/2 - contextDrawer.contentItem.width/2)) { + } else if (contextDrawer && x + speed < Math.max(parent.width/4, parent.width/2 - contextDrawer.contentItem.width/2)) { if (contextDrawer) { contextDrawer.open(); } -- cgit v1.2.3-70-g09d2