1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50
|
// Copyright (C) 2021 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQuick
Item {
width: image.implicitWidth; height: image.implicitHeight
Image {
id: image
anchors.centerIn: parent
source: "images/joystick-outer-case-pov.jpg"
property real margin: 50
Image {
id: knob
source: "images/redball.png"
DragHandler {
id: dragHandler
xAxis {
minimum: image.margin
maximum: image.width - image.margin - knob.width
}
yAxis {
minimum: image.margin
maximum: image.height - image.margin - knob.height
}
}
anchors {
horizontalCenter: parent.horizontalCenter
verticalCenter: parent.verticalCenter
}
states: [
State {
when: dragHandler.active
AnchorChanges {
target: knob
anchors.horizontalCenter: undefined
anchors.verticalCenter: undefined
}
}
]
transitions: [
Transition {
AnchorAnimation { easing.type: Easing.OutElastic }
}
]
}
}
}
|