aboutsummaryrefslogtreecommitdiffstats
path: root/examples/quick/customitems/dialcontrol/dialcontrol.qml
diff options
context:
space:
mode:
authorAlex Blasche <alexander.blasche@digia.com>2014-09-19 11:46:44 +0200
committerAlex Blasche <alexander.blasche@digia.com>2014-09-24 13:24:23 +0200
commitd2d0bfe830330f30913973a79c080d3cc5b00a21 (patch)
treeb711999dc4f93e2aa8dedfd104d6b87744a9ae01 /examples/quick/customitems/dialcontrol/dialcontrol.qml
parentcce0e1f9c27683292741310a730e21e36f123ae0 (diff)
Fix disappearing slider during size/orientation change
Now the slider remains at a position that is equivalent to the old position based on the previous percentage. This change is most commonly triggered during orientation changes on mobile device. That is the reason why the app was converted to a proper Qt project. This way it was possible to test this behavior on Android. Task-number: QTBUG-18423 Change-Id: If05e6a1e42249f90a821c4882021d28cf212fc52 Reviewed-by: Simon Hausmann <simon.hausmann@digia.com>
Diffstat (limited to 'examples/quick/customitems/dialcontrol/dialcontrol.qml')
-rw-r--r--examples/quick/customitems/dialcontrol/dialcontrol.qml19
1 files changed, 16 insertions, 3 deletions
diff --git a/examples/quick/customitems/dialcontrol/dialcontrol.qml b/examples/quick/customitems/dialcontrol/dialcontrol.qml
index f545877655..0bf6d7e68c 100644
--- a/examples/quick/customitems/dialcontrol/dialcontrol.qml
+++ b/examples/quick/customitems/dialcontrol/dialcontrol.qml
@@ -1,6 +1,6 @@
/****************************************************************************
**
-** Copyright (C) 2013 Digia Plc and/or its subsidiary(-ies).
+** Copyright (C) 2014 Digia Plc and/or its subsidiary(-ies).
** Contact: http://www.qt-project.org/legal
**
** This file is part of the examples of the Qt Toolkit.
@@ -39,7 +39,8 @@
****************************************************************************/
//! [imports]
-import QtQuick 2.0
+import QtQuick 2.2
+import QtQuick.Window 2.1
import "content"
//! [imports]
@@ -53,12 +54,13 @@ Rectangle {
Dial {
id: dial
anchors.centerIn: parent
- value: slider.x * 100 / (container.width - 34)
+ value: slider.x * 100 / (container.width - 32)
}
//! [the dial in use]
Rectangle {
id: container
+ property int oldWidth: 0
anchors { bottom: parent.bottom; left: parent.left
right: parent.right; leftMargin: 20; rightMargin: 20
bottomMargin: 10
@@ -73,6 +75,17 @@ Rectangle {
GradientStop { position: 1.0; color: "white" }
}
+ onWidthChanged: {
+ if (oldWidth === 0) {
+ oldWidth = width;
+ return
+ }
+
+ var desiredPercent = slider.x * 100 / (oldWidth - 32)
+ slider.x = desiredPercent * (width - 32) / 100
+ oldWidth = width
+ }
+
Rectangle {
id: slider
x: 1; y: 1; width: 30; height: 14