--- /dev/null
+// -*- qml -*-
+
+/*!
+ * This file is part of CameraPlus.
+ *
+ * Copyright (C) 2012-2013 Mohammed Sameer <msameer@foolab.org>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+import QtQuick 2.0
+
+Item {
+ id: captureControl
+
+ property bool capturePressed: false
+ property bool zoomPressed: false
+ property bool proximityClosed: false
+ property bool canceled: false
+ property bool showCancelBanner: (zoomPressed || proximityClosed) && state == "capturing"
+
+ signal startCapture
+ signal cancelCapture
+
+ states: [
+ State {
+ name: "idle"
+ when: !capturePressed && !zoomPressed && !proximityClosed
+ },
+ State {
+ name: "canceled"
+ when: canceled
+ },
+ State {
+ name: "capturing"
+ when: capturePressed || zoomPressed || proximityClosed
+ }
+ ]
+
+ state: "idle"
+
+ onStateChanged: {
+ if (state == "idle") {
+ captureControl.canceled = false
+ }
+ }
+
+ transitions: [
+ Transition {
+ from: "capturing"
+ to: "idle"
+ ScriptAction {
+ script: captureControl.startCapture()
+ }
+ },
+ Transition {
+ from: "capturing"
+ to: "canceled"
+ ScriptAction {
+ script: captureControl.cancelCapture()
+ }
+ }
+ ]
+}
width: 75
height: 75
opacity: 0.5
- onClicked: captureImage()
visible: controlsVisible
onExited: {
if (mouseX <= 0 || mouseY <= 0 || mouseX > width || mouseY > height) {
// Release outside the button:
- stopAutoFocus()
+ captureControl.canceled = true
}
}
}
Timer {
id: autoFocusTimer
interval: 200
- running: capture.pressed || zoomCapture.zoomPressed
+ running: captureControl.state == "capturing"
repeat: false
onTriggered: {
if (cam.autoFocus.cafStatus != AutoFocus.Success) {
ZoomCaptureButton {
id: zoomCapture
- onReleased: parent.captureImage()
+ }
+
+ CaptureControl {
+ id: captureControl
+ capturePressed: capture.pressed
+ zoomPressed: zoomCapture.zoomPressed
+ proximityClosed: proximitySensor.close
+ onStartCapture: captureImage()
+ onCancelCapture: stopAutoFocus()
}
CaptureCancel {
anchors.fill: parent
- enabled: zoomCapture.zoomPressed
- onPressed: {
- zoomCapture.zoomPressed = false
- if (!autoFocusTimer.running) {
- stopAutoFocus()
- }
- }
+ enabled: captureControl.showCancelBanner
+ onPressed: captureControl.canceled = true
}
CameraToolBar {
function stopAutoFocus() {
if (!overlay.cam.quirks.hasQuirk(Quirks.NoAutoFocus)) {
- cam.autoFocus.stopAutoFocus()
+ if (!autoFocusTimer.running) {
+ cam.autoFocus.stopAutoFocus()
+ }
}
}
ZoomCaptureButton {
id: zoomCapture
- onReleased: overlay.toggleRecording()
+ }
+
+ CaptureControl {
+ id: captureControl
+ capturePressed: capture.pressed
+ zoomPressed: zoomCapture.zoomPressed
+ proximityClosed: proximitySensor.close
+ onStartCapture: overlay.toggleRecording()
}
CaptureCancel {
anchors.fill: parent
- enabled: zoomCapture.zoomPressed
- onPressed: zoomCapture.zoomPressed = false
+ enabled: captureControl.showCancelBanner
+ onPressed: captureControl.canceled = true
}
CaptureButton {
height: 75
opacity: 0.5
- onClicked: overlay.toggleRecording()
-
visible: controlsVisible
+
+ onExited: {
+ if (mouseX <= 0 || mouseY <= 0 || mouseX > width || mouseY > height) {
+ // Release outside the button:
+ captureControl.canceled = true
+ }
+ }
}
CameraToolBar {
<file>ZoomCaptureButton.qml</file>
<file>CaptureCancel.qml</file>
<file>ZoomSlider.qml</file>
+ <file>CaptureControl.qml</file>
</qresource>
</RCC>