h264转avi,编译通过源码 下载本文

static void bs_write1( bs_t *s, uint32_t i_bit ) {

if( s->p < s->p_end ) {

*s->p <<= 1; *s->p |= i_bit; s->i_left--;

if( s->i_left == 0 ) {

s->p++; s->i_left = 8; } } }

static void bs_align_0( bs_t *s ) {

if( s->i_left != 8 ) {

*s->p <<= s->i_left; s->i_left = 8; s->p++; } }

static void bs_align_1( bs_t *s ) {

if( s->i_left != 8 ) {

*s->p <<= s->i_left;

*s->p |= (1 << s->i_left) - 1; s->i_left = 8; s->p++; } }

static void bs_align( bs_t *s ) {

bs_align_0( s ); }

/* golomb functions */

static void bs_write_ue( bs_t *s, unsigned int val )

{

int i_size = 0;

static const int i_size0_255[256] = {

1,1,2,2,3,3,3,3,4,4,4,4,4,4,4,4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5, 6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6,6, 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, 7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7,7, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8, 8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8 };

if( val == 0 ) {

bs_write1( s, 1 ); } else {

unsigned int tmp = ++val;

if( tmp >= 0x00010000 ) {

i_size += 16; tmp >>= 16; }

if( tmp >= 0x100 ) {

i_size += 8; tmp >>= 8; }

i_size += i_size0_255[tmp];

bs_write( s, 2 * i_size - 1, val ); } }

static void bs_write_se( bs_t *s, int val ) {

bs_write_ue( s, val <= 0 ? -val * 2 : val * 2 - 1); }

static void bs_write_te( bs_t *s, int x, int val )

{

if( x == 1 ) {

bs_write1( s, 1&~val ); }

else if( x > 1 ) {

bs_write_ue( s, val ); } }

static void bs_rbsp_trailing( bs_t *s ) {

bs_write1( s, 1 ); if( s->i_left != 8 ) {

bs_write( s, s->i_left, 0x00 ); } }

static int bs_size_ue( unsigned int val ) {

static const int i_size0_254[255] = {

1, 3, 3, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9,

11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11,11, 11,11,11,11,11,11,11,11,11,13,13,13,13,13,13,13,13,13,13,13,13,13,13, 13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13, 13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13,13, 13,13,13,13,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15, 15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15, 15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15, 15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15, 15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15, 15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15,15 };

if( val < 255 ) {

return i_size0_254[val]; } else {

int i_size = 0;

val++;

if( val >= 0x10000 ) {

i_size += 32;

val = (val >> 16) - 1; }

if( val >= 0x100 ) {

i_size += 16;

val = (val >> 8) - 1; }

return i_size0_254[val] + i_size; } }

static int bs_size_se( int val ) {

return bs_size_ue( val <= 0 ? -val * 2 : val * 2 - 1); }

static int bs_size_te( int x, int val ) {

if( x == 1 ) {

return 1; }

else if( x > 1 ) {

return bs_size_ue( val ); }

return 0; }

#endif