Initial ui reimplementation. Still in its early phase.
[harmattan/cameraplus] / qml / CameraPage.qml
index b89aec5..7ba3aa8 100644 (file)
@@ -1,4 +1,25 @@
 // -*- 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 1.1
 import com.nokia.meego 1.1
 import QtCamera 1.0
@@ -7,108 +28,40 @@ import CameraPlus 1.0
 Page {
         id: page
 
-        property alias standbyWidget: standby
-
-        property bool needsPipeline: true
         property int policyMode: CameraResources.None
 
-        Component.onCompleted: {
-                if (Qt.application.active && needsPipeline) {
-                        resourcePolicy.acquire(page.policyMode);
-                }
-        }
+        property Camera cam: null
+        property Item dimmer: null
+        property ControlsActivationData activationData: ControlsActivationData {}
+        property bool controlsVisible: cam.running && !standby.visible
+        property bool focusReticleVisible: true
+        property bool enableViewfinder: true
 
-        onStatusChanged: {
-                if (Qt.application.active && status == PageStatus.Activating) {
-                        resourcePolicy.acquire(page.policyMode);
-                }
-        }
-/*
-        onStatusChanged: {
-                if (status == PageStatus.Active && !page.needsPipeline) {
-                        cam.stop();
-                }
-        }
-*/
+        property alias previewAnimationRunning: preview.animationRunning
 
-        onPolicyModeChanged: {
-                if (Qt.application.active) {
-                        resourcePolicy.acquire(page.policyMode);
-                }
-        }
+        signal batteryLow
 
-        function handlePipeline() {
-                if (!Qt.application.active) {
-                        // TODO: force if we lost resources ?
-                        cam.stop();
-                }
-                else if (resourcePolicy.acquired && page.needsPipeline && !cam.running) {
-                        // TODO: error
-                        cam.start();
-                }
-                else if (!resourcePolicy.acquired) {
-                        // TODO: force
-                        cam.stop();
-                }
+        function cameraError() {
+                // Nothing
         }
 
-        Connections {
-                target: resourcePolicy
-                onAcquiredChanged: handlePipeline();
+        function policyLost() {
+                // Nothing
         }
 
-        Connections {
-                target: Qt.application
-                onActiveChanged: {
-                        if (!Qt.application.active) {
-                                // This is a noop if camera is not
-                                // idle so calling it will not hurt
-                                if (cam.stop()) {
-                                        resourcePolicy.acquire(CameraResources.None);
-                                }
-                        }
-                        else if (page.needsPipeline) {
-                                resourcePolicy.acquire(page.policyMode);
-                        }
+        onStatusChanged: {
+                if (status == PageStatus.Activating && enableViewfinder) {
+                        cam.renderingEnabled = true;
                 }
-        }
+                else if (status == PageStatus.Active) {
+                        focusReticle.resetReticle();
 
-        Connections {
-                target: cam
-                onIdleChanged: {
-                        if (cam.idle && !Qt.application.active) {
-                                cam.stop();
-                                resourcePolicy.acquire(CameraResources.None);
+                        if (!enableViewfinder) {
+                                cam.renderingEnabled = false;
                         }
-/*
-                        else if (cam.idle && !page.needsPipeline) {
-                                cam.stop();
-                        }
-*/
-                }
-        }
-
-        Rectangle {
-                // TODO: color
-                // TODO: fade out transition
-                // TODO: there is a toolbar visible on the first startup
-                id: standby
-                color: "black"
-                anchors.fill: parent
-                visible: !Qt.application.active || !cam.running || !resourcePolicy.acquired
-                Image {
-                        source: "image://theme/icon-l-camera-standby"
-                        anchors.centerIn: parent
                 }
         }
 
-        property Camera cam: null
-        property bool controlsVisible: cam.running && !standby.visible
-
-        anchors.fill: parent
-
-        property alias previewAnimationRunning: preview.animationRunning
-
         function setPreview(image) {
                 preview.setPreview(image);
         }
@@ -118,7 +71,7 @@ Page {
                 anchors.right: parent.right
                 anchors.rightMargin: 20
                 anchors.bottomMargin: 20
-                visible: controlsVisible
+                visible: controlsVisible && activationData.modeSelectorVisible
         }
 
         PreviewImage {
@@ -131,6 +84,10 @@ Page {
                 anchors.top: parent.top
                 anchors.topMargin: 0
                 anchors.horizontalCenter: parent.horizontalCenter
-                visible: controlsVisible
+                visible: controlsVisible && activationData.zoomBarVisible
+        }
+
+        function checkDiskSpace() {
+                return fileSystem.hasFreeSpace(fileNaming.path);
         }
 }