// -*- qml -*-
+
+/*!
+ * This file is part of CameraPlus.
+ *
+ * Copyright (C) 2012 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 1.1
import com.nokia.meego 1.1
import QtCamera 1.0
policyMode: CameraResources.Image
controlsVisible: capture.visible && cam.running && !standbyWidget.visible
- Button {
+ orientationLock: PageOrientation.LockLandscape
+
+ function captureImage() {
+ if (!checkBattery()) {
+ showError(qsTr("Not enough battery to capture images."));
+ return;
+ }
+
+ if (!checkDiskSpace()) {
+ showError(qsTr("Not enough space to capture images."));
+ return;
+ }
+
+ if (!fileSystem.available) {
+ showError(qsTr("Camera cannot capture images in mass storage mode."));
+ return;
+ }
+
+ if (!mountProtector.lock()) {
+ showError(qsTr("Failed to lock images directory."));
+ return;
+ }
+
+ metaData.setMetaData();
+
+ var fileName = fileNaming.imageFileName();
+ if (!imageMode.capture(fileName)) {
+ showError(qsTr("Failed to capture image. Please restart the camera."));
+ return;
+ }
+
+ trackerStore.storeImage(fileName);
+ }
+
+ CaptureButton {
id: capture
anchors.right: parent.right
anchors.rightMargin: 20
width: 75
height: 75
opacity: 0.5
- onClicked: {
- if (!fileSystem.available) {
- showError(qsTr("Camera cannot capture images in mass storage mode."));
- return;
- }
-
- metaData.setMetaData();
+ onClicked: captureImage();
+ visible: imageMode.canCapture && !cameraMode.animationRunning && !previewAnimationRunning && cam.running
- if (!imageMode.capture(fileNaming.imageFileName())) {
- showError(qsTr("Failed to capture image. Please restart the camera."));
+ onExited: {
+ if (mouseX <= 0 || mouseY <= 0 || mouseX > width || mouseY > height) {
+ // Release outside the button:
+ cam.autoFocus.stopAutoFocus();
}
}
- visible: imageMode.canCapture && !cameraMode.animationRunning && !previewAnimationRunning && cam.running
+ Timer {
+ interval: 200
+ running: capture.pressed
+ repeat: false
+ onTriggered: {
+ if (cam.autoFocus.cafStatus != AutoFocus.Success) {
+ cam.autoFocus.startAutoFocus();
+ }
+ }
+ }
}
ImageMode {
id: imageMode
camera: cam
- onPreviewAvailable: page.setPreview(preview);
+ onPreviewAvailable: { page.setPreview(preview); cam.autoFocus.stopAutoFocus(); }
+ onSaved: mountProtector.unlock();
}
FlashButton {
anchors.leftMargin: 20
}
- EvCompButton {
+ ImageEvCompButton {
id: evComp
visible: controlsVisible
anchors.top: scene.bottom
anchors.leftMargin: 20
}
- Indicators {
- visible: controlsVisible
+ MouseArea {
+ id: indicators
anchors.bottom: parent.bottom
anchors.bottomMargin: 20
anchors.left: parent.left
anchors.leftMargin: 20
-
+ width: 48
+ height: col.height
onClicked: openFile("ImageSettingsPage.qml");
+ visible: controlsVisible
- Indicator {
- id: resolutionIndicator
- // TODO:
+ BorderImage {
+ id: image
+ anchors.fill: parent
+ smooth: true
+ source: indicators.pressed ? "image://theme/meegotouch-camera-settings-indicators-background-pressed" : "image://theme/meegotouch-camera-settings-indicators-background"
}
- Indicator {
- id: wbIndicator
- anchors.top: resolutionIndicator.bottom
- source: "image://theme/" + Data.wbIcon(settings.imageWhiteBalance) + "-screen"
- visible: settings.imageWhiteBalance != WhiteBalance.Auto
- }
+ Column {
+ id: col
+ width: parent.width
+ spacing: 5
- Indicator {
- id: cfIndicator
- anchors.top: wbIndicator.bottom
- source: "image://theme/" + Data.cfIcon(settings.imageColorFilter) + "-screen"
- visible: settings.imageColorFilter != ColorTone.Normal
- }
+ Indicator {
+ id: resolutionIndicator
+ source: "image://theme/" + Data.imageIcon(settings.imageAspectRatio, settings.imageResolution);
+ }
- Indicator {
- id: isoIndicator
- visible: settings.imageIso != 0
- source: "image://theme/" + Data.isoIcon(settings.imageIso);
- anchors.top: cfIndicator.bottom
- }
+ Indicator {
+ id: wbIndicator
+ source: "image://theme/" + Data.wbIcon(settings.imageWhiteBalance) + "-screen"
+ visible: settings.imageWhiteBalance != WhiteBalance.Auto
+ }
+
+ Indicator {
+ id: cfIndicator
+ source: "image://theme/" + Data.cfIcon(settings.imageColorFilter) + "-screen"
+ visible: settings.imageColorFilter != ColorTone.Normal
+ }
+
+ Indicator {
+ id: isoIndicator
+ visible: settings.imageIso != 0
+ source: "image://theme/" + Data.isoIcon(settings.imageIso);
+ }
- Indicator {
- id: gpsIndicator
- anchors.top: isoIndicator.bottom
- visible: settings.useGps
- source: "image://theme/icon-m-camera-location"
-
- PropertyAnimation on opacity {
- easing.type: Easing.OutSine
- loops: Animation.Infinite
- from: 0.2
- to: 1.0
- duration: 1000
- running: settings.useGps && !positionSource.position.longitudeValid
- alwaysRunToEnd: true
+ Indicator {
+ id: gpsIndicator
+ visible: settings.useGps
+ source: "image://theme/icon-m-camera-location"
+
+ PropertyAnimation on opacity {
+ easing.type: Easing.OutSine
+ loops: Animation.Infinite
+ from: 0.2
+ to: 1.0
+ duration: 1000
+ running: settings.useGps && !positionSource.position.longitudeValid
+ alwaysRunToEnd: true
+ }
}
}
}