From c6cbb0864a40effe1219116f0f2b541c46d96024 Mon Sep 17 00:00:00 2001 From: Stefan Pöschel Date: Mon, 13 Apr 2015 22:39:18 +0200 Subject: Fix continuity index at MOT data group --- src/mot-encoder.cpp | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/src/mot-encoder.cpp b/src/mot-encoder.cpp index 37a2657..0c39556 100644 --- a/src/mot-encoder.cpp +++ b/src/mot-encoder.cpp @@ -212,7 +212,7 @@ void createMotHeader( int* mothdrlen, bool jfif_not_png); -void createMscDG(MSCDG* msc, unsigned short int dgtype, unsigned short int cindex, +void createMscDG(MSCDG* msc, unsigned short int dgtype, int *cindex, unsigned short int segnum, unsigned short int lastseg, unsigned short int tid, unsigned char* data, unsigned short int datalen); @@ -232,6 +232,11 @@ size_t get_xpadlength(int mask); #define ALLOWED_PADLEN "6 (short X-PAD; only DLS), 23, 26, 34, 42, 58" +// MOT Slideshow related +static int cindex_header = 0; +static int cindex_body = 0; + + // DLS related #define DLS_SEG_LEN_PREFIX 2 #define DLS_SEG_LEN_CHAR_MAX 16 @@ -745,7 +750,7 @@ int encodeFile(int output_fd, std::string& fname, int fidx, int padlen, bool raw createMotHeader(blobsize, fidx, mothdr, &mothdrlen, jfif_not_png); // Create the MSC Data Group C-Structure - createMscDG(&msc, 3, 0, 1, fidx, mothdr, mothdrlen); + createMscDG(&msc, 3, &cindex_header, 0, 1, fidx, mothdr, mothdrlen); // Generate the MSC DG frame (Figure 9 en 300 401) packMscDG(mscblob, &msc, &mscblobsize); writeMotPAD(output_fd, mscblob, mscblobsize, padlen); @@ -761,7 +766,7 @@ int encodeFile(int output_fd, std::string& fname, int fidx, int padlen, bool raw last = 0; } - createMscDG(&msc, 4, i, last, fidx, curseg, curseglen); + createMscDG(&msc, 4, &cindex_body, i, last, fidx, curseg, curseglen); packMscDG(mscblob, &msc, &mscblobsize); writeMotPAD(output_fd, mscblob, mscblobsize, padlen); } @@ -822,7 +827,7 @@ void createMotHeader(size_t blobsize, int fidx, unsigned char* mothdr, int* moth } void createMscDG(MSCDG* msc, unsigned short int dgtype, - unsigned short int cindex, unsigned short int lastseg, + int *cindex, unsigned short int segnum, unsigned short int lastseg, unsigned short int tid, unsigned char* data, unsigned short int datalen) { @@ -831,10 +836,10 @@ void createMscDG(MSCDG* msc, unsigned short int dgtype, msc->segflag = 1; msc->accflag = 1; msc->dgtype = dgtype; - msc->cindex = cindex; + msc->cindex = *cindex; msc->rindex = 0; msc->last = lastseg; - msc->segnum = cindex; + msc->segnum = segnum; msc->rfa = 0; msc->tidflag = 1; msc->lenid = 2; @@ -842,6 +847,8 @@ void createMscDG(MSCDG* msc, unsigned short int dgtype, msc->segdata = data; msc->rcount = 0; msc->seglen = datalen; + + *cindex = (*cindex + 1) % 16; // increment continuity index } -- cgit v1.2.3