Skip to content

Commit

Permalink
Merge pull request #125 from yilun-zhangs/main
Browse files Browse the repository at this point in the history
1, Update mix_presentation_id after intelligently selecting mix presentation 2, Support decoding MP4 when IAMF is not the first track
  • Loading branch information
yilun-zhangs authored Oct 8, 2024
2 parents 3bbb184 + 3da4c44 commit 4b76ccf
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 6 deletions.
4 changes: 3 additions & 1 deletion code/src/iamf_dec/IAMF_decoder.c
Original file line number Diff line number Diff line change
Expand Up @@ -4277,8 +4277,10 @@ int iamf_decoder_internal_configure(IAMF_DecoderHandle handle,
IAMF_MixPresentation *mixp = 0;
if (ctx->mix_presentation_id != INVALID_ID)
mixp = iamf_database_get_mix_presentation(db, ctx->mix_presentation_id);
else
else {
mixp = iamf_decoder_get_best_mix_presentation(handle);
ctx->mix_presentation_id = mixp->mix_presentation_id;
}

if (mixp) {
ia_logi("get mix presentation id %" PRId64,
Expand Down
17 changes: 12 additions & 5 deletions code/test/tools/iamfdec/src/mp4demux.c
Original file line number Diff line number Diff line change
Expand Up @@ -419,7 +419,6 @@ int mov_read_stbl(mp4r_t *mp4r, int size) {

int64_t apos = ftell(mp4r->fin);
avio_context *list[] = {
atoms_stsd,
atoms_stts,
atoms_stsc,
atoms_stsz,
Expand All @@ -429,9 +428,12 @@ int mov_read_stbl(mp4r_t *mp4r, int size) {
atoms_sgpd
#endif
};

STASH_ATOM();
for (int i = 0; i < sizeof(list) / sizeof(avio_context *); ++i)
atom_seek_parse(mp4r, apos, size, list[i]);
if (atom_seek_parse(mp4r, apos, size, atoms_stsd) == ERR_OK) {
for (int i = 0; i < sizeof(list) / sizeof(avio_context *); ++i)
atom_seek_parse(mp4r, apos, size, list[i]);
}
RESTORE_ATOM();
return size;
}
Expand Down Expand Up @@ -504,6 +506,7 @@ int mov_read_stsd(mp4r_t *mp4r, int size) {
#endif

int n;
int ret = size;

// version/flags
avio_rb32();
Expand All @@ -513,10 +516,14 @@ int mov_read_stsd(mp4r_t *mp4r, int size) {

for (int i = 0; i < n; ++i) {
mp4r->atom = atoms_iamf;
parse(mp4r, &size);
ret = parse(mp4r, &size);
if (ret == ERR_OK) {
ret = size;
break;
}
}
RESTORE_ATOM();
return size;
return ret;
}

int mov_read_edts(mp4r_t *mp4r, int size) {
Expand Down

0 comments on commit 4b76ccf

Please sign in to comment.