blob: 6789eac28bc72ee814308fef4f72a3e81f2a9f80 (
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
|
import QtQuick 1.0
import "../shared" 1.0
Item {
id:lineedit
property alias text: textInp.text
width: textInp.width + 11
height: 13 + 11
Rectangle {
color: 'lightsteelblue'
anchors.fill: parent
}
clip: true
Component.onCompleted: textInp.cursorPosition = 0;
TestTextInput {
id:textInp
cursorDelegate: Item {
Rectangle {
visible: parent.parent.focus
color: "#009BCE"
height: 13
width: 2
y: 1
}
}
property int leftMargin: 6
property int rightMargin: 6
x: leftMargin
y: 5
//Below function implements all scrolling logic
onCursorPositionChanged: {
if(cursorRectangle.x < leftMargin - textInp.x){//Cursor went off the front
textInp.x = leftMargin - Math.max(0, cursorRectangle.x);
}else if(cursorRectangle.x > parent.width - leftMargin - rightMargin - textInp.x){//Cusor went off the end
textInp.x = leftMargin - Math.max(0, cursorRectangle.x - (parent.width - leftMargin - rightMargin));
}
}
autoScroll: false //It is preferable to implement your own scrolling
text:""
horizontalAlignment: TextInput.AlignLeft
font.pixelSize:15
selectionColor: 'steelblue'
}
MouseArea {
//Implements all line edit mouse handling
id: mainMouseArea
anchors.fill: parent;
function translateX(x){
return x - textInp.x
}
onPressed: {
textInp.focus = true;
textInp.cursorPosition = textInp.positionAt(translateX(mouse.x));
}
onPositionChanged: {
textInp.moveCursorSelection(textInp.positionAt(translateX(mouse.x)));
}
onReleased: {
}
onDoubleClicked: {
textInp.selectAll()
}
z: textInp.z + 1
}
}
|