summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorWu-cheng Li <wuchengli@google.com>2011-01-05 14:33:00 +0800
committerWu-cheng Li <wuchengli@google.com>2011-01-05 14:33:00 +0800
commit446b319606f90abedfa1927d4d47ce50e6b965c3 (patch)
tree557cb730a9e818a0835a17a87ab7e46b152f5740 /src
parent894696f3f9f068a23696bbd05a5e9fc0d9ae5720 (diff)
downloadLegacyCamera-446b319606f90abedfa1927d4d47ce50e6b965c3.zip
LegacyCamera-446b319606f90abedfa1927d4d47ce50e6b965c3.tar.gz
LegacyCamera-446b319606f90abedfa1927d4d47ce50e6b965c3.tar.bz2
Fix the wrong video duration in time lapse mode.
bug:3320235 Change-Id: I9532684b51f4a5091a27ea4d5a7d0e12d551fff1
Diffstat (limited to 'src')
-rw-r--r--src/com/android/camera/VideoCamera.java15
1 files changed, 7 insertions, 8 deletions
diff --git a/src/com/android/camera/VideoCamera.java b/src/com/android/camera/VideoCamera.java
index 137b4db..053b074 100644
--- a/src/com/android/camera/VideoCamera.java
+++ b/src/com/android/camera/VideoCamera.java
@@ -1222,6 +1222,9 @@ public class VideoCamera extends NoSearchActivity
new File(mCurrentVideoFilename).length());
long duration = SystemClock.uptimeMillis() - mRecordingStartTime;
if (duration > 0) {
+ if (mCaptureTimeLapse) {
+ duration = getTimeLapseVideoLength(duration);
+ }
mCurrentVideoValues.put(Video.Media.DURATION, duration);
} else {
Log.w(TAG, "Video duration <= 0 : " + duration);
@@ -1637,15 +1640,11 @@ public class VideoCamera extends NoSearchActivity
return timeStringBuilder.toString();
}
- // Calculates the time lapse video length till now and returns it in
- // the format hh:mm:ss.dd, where dd are the centi seconds.
- private String getTimeLapseVideoLengthString(long deltaMs) {
+ private long getTimeLapseVideoLength(long deltaMs) {
// For better approximation calculate fractional number of frames captured.
// This will update the video time at a higher resolution.
double numberOfFrames = (double) deltaMs / mTimeBetweenTimeLapseFrameCaptureMs;
- long videoTimeMs =
- (long) (numberOfFrames / (double) mProfile.videoFrameRate * 1000);
- return millisecondToTimeString(videoTimeMs, true);
+ return (long) (numberOfFrames / (double) mProfile.videoFrameRate * 1000);
}
private void updateRecordingTime() {
@@ -1671,8 +1670,8 @@ public class VideoCamera extends NoSearchActivity
} else {
// The length of time lapse video is different from the length
// of the actual wall clock time elapsed. Display the video length
- // only.
- text = getTimeLapseVideoLengthString(delta);
+ // only in format hh:mm:ss.dd, where dd are the centi seconds.
+ text = millisecondToTimeString(getTimeLapseVideoLength(delta), true);
}
mRecordingTimeView.setText(text);