summaryrefslogtreecommitdiffstats
path: root/examples/declarative/positioners/Button.qml
blob: d03eeb5cee9864600e35060a1508d1f9468c14d9 (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
import Qt 4.7

Rectangle {
    id: page

    property string text
    property string icon
    signal clicked

    border.color: "black"; color: "steelblue"; radius: 5
    width: pix.width + textelement.width + 13
    height: pix.height + 10

    Image { id: pix; x: 5; y:5; source: parent.icon }

    Text {
        id: textelement
        text: page.text; color: "white"
        x: pix.width + pix.x + 3
        anchors.verticalCenter: pix.verticalCenter
    }

    MouseArea {
        id: mr
        anchors.fill: parent
        onClicked: { parent.focus = true; page.clicked() }
    }

    states: State {
        name: "pressed"; when: mr.pressed
        PropertyChanges { target: textelement; x: 5 }
        PropertyChanges { target: pix; x: textelement.x + textelement.width + 3 }
    }

    transitions: Transition {
        NumberAnimation { properties: "x,left"; easing.type: Easing.InOutQuad; duration: 200 }
    }
}