[FFmpeg-cvslog] avformat/mov: Also export loci altitude
Michael Niedermayer
git at videolan.org
Sat May 30 16:46:47 CEST 2015
ffmpeg | branch: master | Michael Niedermayer <michaelni at gmx.at> | Sat May 30 15:28:31 2015 +0200| [08b7d19deff96a0adae93ba7d585176036442f31] | committer: Michael Niedermayer
avformat/mov: Also export loci altitude
Signed-off-by: Michael Niedermayer <michaelni at gmx.at>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=08b7d19deff96a0adae93ba7d585176036442f31
---
libavformat/mov.c | 9 +++++++--
1 file changed, 7 insertions(+), 2 deletions(-)
diff --git a/libavformat/mov.c b/libavformat/mov.c
index a2f746b..e3c2e1d 100644
--- a/libavformat/mov.c
+++ b/libavformat/mov.c
@@ -208,7 +208,7 @@ static int mov_metadata_loci(MOVContext *c, AVIOContext *pb, unsigned len)
char language[4] = { 0 };
char buf[200], place[100];
uint16_t langcode = 0;
- double longitude, latitude;
+ double longitude, latitude, altitude;
const char *key = "location";
if (len < 4 + 2 + 1 + 1 + 4 + 4 + 4) {
@@ -235,9 +235,14 @@ static int mov_metadata_loci(MOVContext *c, AVIOContext *pb, unsigned len)
}
longitude = ((int32_t) avio_rb32(pb)) / (float) (1 << 16);
latitude = ((int32_t) avio_rb32(pb)) / (float) (1 << 16);
+ altitude = ((int32_t) avio_rb32(pb)) / (float) (1 << 16);
// Try to output in the same format as the ?xyz field
- snprintf(buf, sizeof(buf), "%+08.4f%+09.4f/%s", latitude, longitude, place);
+ snprintf(buf, sizeof(buf), "%+08.4f%+09.4f", latitude, longitude);
+ if (altitude)
+ av_strlcatf(buf, sizeof(buf), "%+f", altitude);
+ av_strlcatf(buf, sizeof(buf), "/%s", place);
+
if (*language && strcmp(language, "und")) {
char key2[16];
snprintf(key2, sizeof(key2), "%s-%s", key, language);
More information about the ffmpeg-cvslog
mailing list