Don't show rounded corners
[harmattan/cameraplus] / qml / ImagePage.qml
index 8b1cbca..f8023bd 100644 (file)
@@ -1,4 +1,25 @@
 // -*- 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
@@ -11,7 +32,41 @@ CameraPage {
         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
@@ -20,26 +75,33 @@ CameraPage {
                 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 {
@@ -60,7 +122,7 @@ CameraPage {
                 anchors.leftMargin: 20
         }
 
-        EvCompButton {
+        ImageEvCompButton {
                 id: evComp
                 visible: controlsVisible
                 anchors.top: scene.bottom
@@ -69,62 +131,66 @@ CameraPage {
                 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
 
-//                Label {
-                // TODO:
-                        // resolution
-//                }
-
-                Indicator {
-                        id: wbIndicator
-                        source: "image://theme/" + Data.wbIcon(settings.imageWhiteBalance) + "-screen"
-                        width: parent.width
-                        height: width
-                        visible: settings.imageWhiteBalance != WhiteBalance.Auto
+                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: cfIndicator
-                        anchors.top: wbIndicator.bottom
-                        source: "image://theme/" + Data.cfIcon(settings.imageColorFilter) + "-screen"
+                Column {
+                        id: col
                         width: parent.width
-                        height: width
-                        visible: settings.imageColorFilter != ColorTone.Normal
-                }
+                        spacing: 5
 
-                Indicator {
-                        id: isoIndicator
-                        width: parent.width
-                        height: width
-                        visible: settings.imageIso != 0
-                        source: "image://theme/" + Data.isoIcon(settings.imageIso);
-                        anchors.top: cfIndicator.bottom
-                }
+                        Indicator {
+                                id: resolutionIndicator
+                                source: "image://theme/" + Data.imageIcon(settings.imageAspectRatio, settings.imageResolution);
+                        }
 
-                Indicator {
-                        id: gpsIndicator
-                        width: parent.width
-                        height: width
-                        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: 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
+                                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
+                                }
                         }
                 }
         }