Mercurial > libavcodec.hg
changeset 3816:6eba53afa0b0 libavcodec
Original Commit: r10 | ods15 | 2006-09-17 19:37:17 +0300 (Sun, 17 Sep 2006) | 2 lines
mappings header syntax
author | ods15 |
---|---|
date | Mon, 02 Oct 2006 05:55:28 +0000 |
parents | 3fa081422f78 |
children | 3ca15f0d4882 |
files | vorbis_enc.c |
diffstat | 1 files changed, 22 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/vorbis_enc.c Mon Oct 02 05:55:26 2006 +0000 +++ b/vorbis_enc.c Mon Oct 02 05:55:28 2006 +0000 @@ -80,6 +80,10 @@ } residue_t; typedef struct { + int submaps; + int * mux; + int * floor; + int * residue; } mapping_t; typedef struct { @@ -296,6 +300,24 @@ // mappings put_bits(&pb, 6, venc->nmappings - 1); for (i = 0; i < venc->nmappings; i++) { + mapping_t * mc = &venc->mappings[i]; + int j; + put_bits(&pb, 16, 0); // mapping type + + put_bits(&pb, 1, mc->submaps > 1); + if (mc->submaps > 1) put_bits(&pb, 4, mc->submaps - 1); + + put_bits(&pb, 1, 0); // channel coupling + + put_bits(&pb, 2, 0); // reserved + + if (mc->submaps > 1) for (j = 0; j < venc->channels; j++) put_bits(&pb, 4, mc->mux[j]); + + for (j = 0; j < mc->submaps; j++) { + put_bits(&pb, 8, 0); // reserved time configuration + put_bits(&pb, 8, mc->floor[j]); + put_bits(&pb, 8, mc->residue[j]); + } } flush_put_bits(&pb);