Mercurial > mplayer.hg
diff libmpdemux/demuxer.c @ 25575:f94eee219ee0
wrapper functions to get/set angle: the wrapping is needed to RESYNC the demuxer; patch by oattila chello hu
author | nicodvb |
---|---|
date | Sat, 05 Jan 2008 14:28:57 +0000 |
parents | acaa10e43c52 |
children | cc740dcda27c |
line wrap: on
line diff
--- a/libmpdemux/demuxer.c Sat Jan 05 14:22:48 2008 +0000 +++ b/libmpdemux/demuxer.c Sat Jan 05 14:28:57 2008 +0000 @@ -1287,3 +1287,52 @@ return demuxer->num_chapters; } +int demuxer_angles_count(demuxer_t *demuxer) { + int ris, angles=-1; + + ris = stream_control(demuxer->stream, STREAM_CTRL_GET_NUM_ANGLES, &angles); + if(ris == STREAM_UNSUPPORTED) return -1; + return angles; +} + +int demuxer_get_current_angle(demuxer_t *demuxer) { + int ris, curr_angle=-1; + ris = stream_control(demuxer->stream, STREAM_CTRL_GET_ANGLE, &curr_angle); + if(ris == STREAM_UNSUPPORTED) return -1; + return curr_angle; +} + + +int demuxer_set_angle(demuxer_t *demuxer, int angle) { + int ris, angles=-1; + sh_video_t *sh_video = demuxer->video->sh; + sh_audio_t *sh_audio = demuxer->audio->sh; + + angles = demuxer_angles_count(demuxer); + if((angles < 1) || (angle > angles)) return -1; + + if(demuxer->video->sh) + ds_free_packs(demuxer->video); + + if(demuxer->audio->sh) + ds_free_packs(demuxer->audio); + + if(demuxer->sub->id >= 0) + ds_free_packs(demuxer->sub); + + ris = stream_control(demuxer->stream, STREAM_CTRL_SET_ANGLE, &angle); + if(ris == STREAM_UNSUPPORTED) return -1; + + demux_control(demuxer, DEMUXER_CTRL_RESYNC, NULL); + if(sh_video) { + ds_fill_buffer(demuxer->video); + resync_video_stream(sh_video); + } + + if(sh_audio) { + ds_fill_buffer(demuxer->audio); + resync_audio_stream(sh_audio); + } + + return angle; +}