Added a custom Button (CaptureButton) to expose more properties and signals
[harmattan/cameraplus] / qml / CaptureButton.qml
1 // -*- qml -*-
2
3 /*!
4  * This file is part of CameraPlus.
5  *
6  * Copyright (C) 2012 Mohammed Sameer <msameer@foolab.org>
7  *
8  * This library is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU Lesser General Public
10  * License as published by the Free Software Foundation; either
11  * version 2.1 of the License, or (at your option) any later version.
12  *
13  * This library is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16  * Lesser General Public License for more details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with this library; if not, write to the Free Software
20  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
21  */
22
23 import QtQuick 1.1
24 import com.nokia.meego 1.1
25
26 Item {
27         id: button
28
29         property url iconSource
30         property Style platformStyle: ButtonStyle {}
31
32         property alias pressed: mouse.pressed
33         property alias containsMouse: mouse.containsMouse
34         property alias mouseX: mouse.mouseX
35         property alias mouseY: mouse.mouseY
36
37         signal clicked
38         signal exited
39
40         MouseArea {
41                 id: mouse
42                 anchors.fill: parent
43                 onClicked: button.clicked();
44                 onExited: button.exited();
45         }
46
47         BorderImage {
48                 id: background
49                 anchors.fill: parent
50                 border.left: button.platformStyle.backgroundMarginLeft
51                 border.top: button.platformStyle.backgroundMarginTop
52                 border.right: button.platformStyle.backgroundMarginRight
53                 border.bottom: button.platformStyle.backgroundMarginBottom
54                 source:  pressed ? button.platformStyle.pressedBackground : button.platformStyle.background
55         }
56
57         Image {
58                 id: icon
59                 anchors.centerIn: parent
60                 anchors.verticalCenter: parent.verticalCenter
61                 anchors.verticalCenterOffset: -1
62                 source: button.iconSource
63                 visible: source != ""
64         }
65 }