📄 headers.c
字号:
}/*printf("mpeg3video_picture_coding_extension %d\n", video->repeat_count); */ composite_display_flag = mpeg3bits_getbit_noptr(video->vstream); if(composite_display_flag) { v_axis = mpeg3bits_getbit_noptr(video->vstream); field_sequence = mpeg3bits_getbits(video->vstream, 3); sub_carrier = mpeg3bits_getbit_noptr(video->vstream); burst_amplitude = mpeg3bits_getbits(video->vstream, 7); sub_carrier_phase = mpeg3bits_getbyte_noptr(video->vstream); } return 0;}/* decode picture spatial scalable extension */int mpeg3video_picture_spatial_scalable_extension(mpeg3video_t *video){ video->pict_scal = 1; /* use spatial scalability in this picture */ video->lltempref = mpeg3bits_getbits(video->vstream, 10); mpeg3bits_getbit_noptr(video->vstream); video->llx0 = mpeg3bits_getbits(video->vstream, 15); if(video->llx0 >= 16384) video->llx0 -= 32768; mpeg3bits_getbit_noptr(video->vstream); video->lly0 = mpeg3bits_getbits(video->vstream, 15); if(video->lly0 >= 16384) video->lly0 -= 32768; video->stwc_table_index = mpeg3bits_getbits(video->vstream, 2); video->llprog_frame = mpeg3bits_getbit_noptr(video->vstream); video->llfieldsel = mpeg3bits_getbit_noptr(video->vstream); return 0;}/* decode picture temporal scalable extension * * not implemented * */int mpeg3video_picture_temporal_scalable_extension(mpeg3video_t *video){ fprintf(stderr, "mpeg3video_picture_temporal_scalable_extension: temporal scalability not supported\n"); return 0;}/* decode extension and user data */int mpeg3video_ext_user_data(mpeg3video_t *video){ int code = mpeg3bits_next_startcode(video->vstream); while((code == MPEG3_EXT_START_CODE || code == MPEG3_USER_START_CODE) && !mpeg3bits_eof(video->vstream)) { mpeg3bits_refill(video->vstream); if(code == MPEG3_EXT_START_CODE) { int ext_id = mpeg3bits_getbits(video->vstream, 4); switch(ext_id) { case SEQ_ID: mpeg3video_sequence_extension(video); break; case DISP_ID: mpeg3video_sequence_display_extension(video); break; case QUANT_ID: mpeg3video_quant_matrix_extension(video); break; case SEQSCAL_ID: mpeg3video_sequence_scalable_extension(video); break; case PANSCAN_ID: mpeg3video_picture_display_extension(video); break; case CODING_ID: mpeg3video_picture_coding_extension(video); break; case SPATSCAL_ID: mpeg3video_picture_spatial_scalable_extension(video); break; case TEMPSCAL_ID: mpeg3video_picture_temporal_scalable_extension(video); break; default: fprintf(stderr,"mpeg3video_ext_user_data: reserved extension start code ID %d\n", ext_id); break; } } code = mpeg3bits_next_startcode(video->vstream); } return 0;}/* decode group of pictures header */int mpeg3video_getgophdr(mpeg3video_t *video){ int drop_flag, closed_gop, broken_link;//printf("%x\n", mpeg3bits_tell(video->vstream)); video->has_gops = 1; drop_flag = mpeg3bits_getbit_noptr(video->vstream); video->gop_timecode.hour = mpeg3bits_getbits(video->vstream, 5); video->gop_timecode.minute = mpeg3bits_getbits(video->vstream, 6); mpeg3bits_getbit_noptr(video->vstream); video->gop_timecode.second = mpeg3bits_getbits(video->vstream, 6); video->gop_timecode.frame = mpeg3bits_getbits(video->vstream, 6); closed_gop = mpeg3bits_getbit_noptr(video->vstream); broken_link = mpeg3bits_getbit_noptr(video->vstream);/* * printf("%d:%d:%d:%d %d %d %d\n", video->gop_timecode.hour, video->gop_timecode.minute, video->gop_timecode.second, video->gop_timecode.frame, * drop_flag, closed_gop, broken_link); */ return mpeg3bits_error(video->vstream);}/* decode picture header */int mpeg3video_getpicturehdr(mpeg3video_t *video){ int temp_ref, vbv_delay; video->pict_scal = 0; /* unless overwritten by pict. spat. scal. ext. */ temp_ref = mpeg3bits_getbits(video->vstream, 10); video->pict_type = mpeg3bits_getbits(video->vstream, 3); vbv_delay = mpeg3bits_getbits(video->vstream, 16); if(video->pict_type == P_TYPE || video->pict_type == B_TYPE) { video->full_forw = mpeg3bits_getbit_noptr(video->vstream); video->forw_r_size = mpeg3bits_getbits(video->vstream, 3) - 1; } if(video->pict_type == B_TYPE) { video->full_back = mpeg3bits_getbit_noptr(video->vstream); video->back_r_size = mpeg3bits_getbits(video->vstream, 3) - 1; }/* get extra bit picture */ while(mpeg3bits_getbit_noptr(video->vstream) && !mpeg3bits_eof(video->vstream)) mpeg3bits_getbyte_noptr(video->vstream); return 0;}int mpeg3video_get_header(mpeg3video_t *video, int dont_repeat){ unsigned int code;/* a sequence header should be found before returning from `getheader' the *//* first time (this is to set horizontal/vertical size properly) *//* Repeat the frame until it's less than 1 count from repeat_count */ if(video->repeat_count - video->current_repeat >= 100 && !dont_repeat) { return 0; } if(dont_repeat) { video->repeat_count = 0; video->current_repeat = 0; } else video->repeat_count -= video->current_repeat;//printf("mpeg3video_get_header 1 %d %d\n", // video->vstream->demuxer->titles[0]->fs->current_byte, // video->vstream->demuxer->titles[0]->fs->total_bytes); while(1) {//printf("mpeg3video_get_header 1 %llx\n", mpeg3bits_tell(video->vstream));/* look for startcode */ code = mpeg3bits_next_startcode(video->vstream);//printf("mpeg3video_get_header 2 %x %x %08x\n", // video->vstream->demuxer->titles[0]->fs->current_byte, // video->vstream->demuxer->titles[0]->fs->total_bytes,// code);//printf("mpeg3video_get_header 2 %d\n", mpeg3bits_eof(video->vstream)); if(mpeg3bits_eof(video->vstream)) return 1; if(code != MPEG3_SEQUENCE_END_CODE) mpeg3bits_refill(video->vstream); switch(code) { case MPEG3_SEQUENCE_START_CODE: video->found_seqhdr = 1; mpeg3video_getseqhdr(video); mpeg3video_ext_user_data(video); break; case MPEG3_GOP_START_CODE: mpeg3video_getgophdr(video); mpeg3video_ext_user_data(video); break; case MPEG3_PICTURE_START_CODE://printf("%x\n", mpeg3bits_tell(video->vstream)); mpeg3video_getpicturehdr(video); mpeg3video_ext_user_data(video); if(video->found_seqhdr) return 0; /* Exit here */ break; case MPEG3_SEQUENCE_END_CODE:// Continue until the end mpeg3bits_refill(video->vstream); break; default: break; } } return 1; /* Shouldn't be reached. */}int mpeg3video_ext_bit_info(mpeg3_slice_buffer_t *slice_buffer){ while(mpeg3slice_getbit(slice_buffer)) mpeg3slice_getbyte(slice_buffer); return 0;}/* decode slice header */int mpeg3video_getslicehdr(mpeg3_slice_t *slice, mpeg3video_t *video){ int slice_vertical_position_extension, intra_slice; int qs; slice_vertical_position_extension = (video->mpeg2 && video->vertical_size > 2800) ? mpeg3slice_getbits(slice->slice_buffer, 3) : 0; if(video->scalable_mode == SC_DP) slice->pri_brk = mpeg3slice_getbits(slice->slice_buffer, 7); qs = mpeg3slice_getbits(slice->slice_buffer, 5); slice->quant_scale = video->mpeg2 ? (video->qscale_type ? mpeg3_non_linear_mquant_table[qs] : (qs << 1)) : qs; if(mpeg3slice_getbit(slice->slice_buffer)) { intra_slice = mpeg3slice_getbit(slice->slice_buffer); mpeg3slice_getbits(slice->slice_buffer, 7); mpeg3video_ext_bit_info(slice->slice_buffer); } else intra_slice = 0; return slice_vertical_position_extension;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -