summaryrefslogtreecommitdiffstats
path: root/experimental/Camera/RecordingTime.qml
diff options
context:
space:
mode:
authorYoann Lopes <yoann.lopes@digia.com>2013-06-24 15:47:31 +0200
committerEirik Aavitsland <eirik.aavitsland@digia.com>2013-09-23 12:54:29 +0300
commit35edc19994995491aaf44e9bac851e1f8cda17ce (patch)
tree986e0114b63f846619601b89e550bf28b431bdcc /experimental/Camera/RecordingTime.qml
parentd571f4769863bfb8035ff9ab61a7fbd797ae0452 (diff)
Added Mediaplayer and Camera demos.
It's currently in the experimental directory since it has been tested only on the Nexus 7. Change-Id: I9503ded9504841b80a88c6e2541bed0234d73cfc Reviewed-by: Eirik Aavitsland <eirik.aavitsland@digia.com>
Diffstat (limited to 'experimental/Camera/RecordingTime.qml')
-rw-r--r--experimental/Camera/RecordingTime.qml70
1 files changed, 70 insertions, 0 deletions
diff --git a/experimental/Camera/RecordingTime.qml b/experimental/Camera/RecordingTime.qml
new file mode 100644
index 0000000..504d232
--- /dev/null
+++ b/experimental/Camera/RecordingTime.qml
@@ -0,0 +1,70 @@
+import QtQuick 2.0
+
+Rectangle {
+ id: recRoot
+ width: row.width + 14 * root.contentScale
+ height: circle.height + 14 * root.contentScale
+ color: "#77333333"
+ radius: 5 * root.contentScale
+ rotation: root.contentRotation
+ Behavior on rotation { NumberAnimation { } }
+
+ Row {
+ id: row
+ anchors.centerIn: parent
+ spacing: 10 * root.contentScale
+
+ Item {
+ anchors.verticalCenter: timeText.verticalCenter
+ width: 18 * root.contentScale
+ height: width
+
+ Rectangle {
+ id: circle
+ width: parent.width
+ height: parent.height
+ radius: width / 2
+ color: "#fa334f"
+
+ SequentialAnimation {
+ loops: Animation.Infinite
+ running: recRoot.visible
+ PropertyAction { target: circle; property: "visible"; value: true }
+ PauseAnimation { duration: 1000 }
+ PropertyAction { target: circle; property: "visible"; value: false }
+ PauseAnimation { duration: 1000 }
+ }
+ }
+ }
+
+ Text {
+ id: timeText
+ color: "white"
+ font.pixelSize: 24 * root.contentScale
+ text: formatTime(camera.videoRecorder.duration)
+ }
+ }
+
+ function formatTime(time) {
+ time = time / 1000
+ var hours = Math.floor(time / 3600);
+ time = time - hours * 3600;
+ var minutes = Math.floor(time / 60);
+ var seconds = Math.floor(time - minutes * 60);
+
+ if (hours > 0)
+ return formatTimeBlock(hours) + ":" + formatTimeBlock(minutes) + ":" + formatTimeBlock(seconds);
+ else
+ return formatTimeBlock(minutes) + ":" + formatTimeBlock(seconds);
+
+ }
+
+ function formatTimeBlock(time) {
+ if (time === 0)
+ return "00"
+ if (time < 10)
+ return "0" + time;
+ else
+ return time.toString();
+ }
+}