blob: 0b7bb9e3b0613b6c046f5a02b57006d633aec2bb (
plain)
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
|
// Copyright (C) 2019 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only
import QtQuick
import QtQuick.Window
import QtQuick.VirtualKeyboard
import Qt.labs.platform
Window {
id: keyboardWindow
width: Screen.width / 2
height: width / 2.65
y: Screen.height - height
color: "transparent"
visible: Qt.inputMethod.visible
flags: Qt.WindowStaysOnTopHint | Qt.WindowDoesNotAcceptFocus | Qt.FramelessWindowHint
readonly property double scaleFactor: 1.5
signal languageChangedSignal(string msg)
QtObject {
id: d
property double alternativeKeySpaceHeight: inputPanel.height / 4.7
}
Loader {
id: testLoader
sourceComponent: {
if (typeof(QT_TESTING_RUN) !== undefined) {
lang
}
}
}
Component {
id: lang
Text {
id: langText
visible: false
text: qsTr(Qt.locale(InputContext.locale).nativeLanguageName)
onTextChanged: {
keyboardWindow.languageChangedSignal(langText.text)
}
}
}
SystemTrayIcon {
id: qtLogo
icon {
mask: true
source: "graphics/Qt_logo.png"
}
visible: !Qt.inputMethod.visible
onActivated: atspiFocus.setKeyboardVisible(!Qt.inputMethod.visible)
Component.onCompleted: console.log("Found system tray?:",qtLogo.available)
}
Rectangle {
id: dragArea
anchors.fill: parent
anchors.bottomMargin: keyboardWindow.height - d.alternativeKeySpaceHeight
color: "#aa444444"
opacity: hoverHandler.hovered ? 1 : 0
DragHandler {
target: null
onTranslationChanged: {
var dx = translation.x
var dy = translation.y
var ksx = keyboardWindow.x + keyboardWindow.width
var ksy = keyboardWindow.y + keyboardWindow.height
if (keyboardWindow.x < 0 && (keyboardWindow.x + dx) < 0)
dx = 0
if (ksx > Screen.width && (ksx + dx) > Screen.width)
dx = 0
if (keyboardWindow.y < 0 && (keyboardWindow.y + dy) < 0)
dy = 0
if (ksy > Screen.height && (ksy + dy) > Screen.height)
dy = 0
keyboardWindow.x += dx
keyboardWindow.y += dy
}
}
HoverHandler {
id: hoverHandler
}
Behavior on opacity {
NumberAnimation {}
}
Text {
text: "Click here and then drag to move the keyboard"
color: "white"
anchors.horizontalCenter: parent.horizontalCenter
y: (d.alternativeKeySpaceHeight - height) / 2
}
}
InputPanel {
id: inputPanel
z: 99
anchors.fill: parent
}
}
|