X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;ds=sidebyside;f=modules%2Fcodec%2Fcvdsub.c;h=9406db5d3ab8f9374d7b277237a5a8730e8e6f58;hb=88f6d80d7ef9819edf8f280d18bdaf646a846ba2;hp=eb934b5ca75143e70f1ad277c1779ac3410f2b43;hpb=8f83ef4b74b37d92e95fc9bcebabf67e9aeef291;p=vlc diff --git a/modules/codec/cvdsub.c b/modules/codec/cvdsub.c index eb934b5ca7..9406db5d3a 100644 --- a/modules/codec/cvdsub.c +++ b/modules/codec/cvdsub.c @@ -33,10 +33,9 @@ #include #include -#include #include -#include "vlc_bits.h" +#include #define DEBUG_CVDSUB 1 @@ -47,16 +46,16 @@ static int DecoderOpen ( vlc_object_t * ); static int PacketizerOpen( vlc_object_t * ); static void DecoderClose ( vlc_object_t * ); -vlc_module_begin(); - set_description( N_("CVD subtitle decoder") ); - set_capability( "decoder", 50 ); - set_callbacks( DecoderOpen, DecoderClose ); +vlc_module_begin () + set_description( N_("CVD subtitle decoder") ) + set_capability( "decoder", 50 ) + set_callbacks( DecoderOpen, DecoderClose ) - add_submodule(); - set_description( N_("Chaoji VCD subtitle packetizer") ); - set_capability( "packetizer", 50 ); - set_callbacks( PacketizerOpen, DecoderClose ); -vlc_module_end(); + add_submodule () + set_description( N_("Chaoji VCD subtitle packetizer") ) + set_capability( "packetizer", 50 ) + set_callbacks( PacketizerOpen, DecoderClose ) +vlc_module_end () /***************************************************************************** * Local prototypes @@ -111,10 +110,8 @@ static int DecoderOpen( vlc_object_t *p_this ) decoder_t *p_dec = (decoder_t*)p_this; decoder_sys_t *p_sys; - if( p_dec->fmt_in.i_codec != VLC_FOURCC( 'c','v','d',' ' ) ) - { + if( p_dec->fmt_in.i_codec != VLC_CODEC_CVD ) return VLC_EGENERIC; - } p_dec->p_sys = p_sys = malloc( sizeof( decoder_sys_t ) ); if( !p_sys ) @@ -125,11 +122,12 @@ static int DecoderOpen( vlc_object_t *p_this ) p_sys->i_state = SUBTITLE_BLOCK_EMPTY; p_sys->p_spu = NULL; - es_format_Init( &p_dec->fmt_out, SPU_ES, VLC_FOURCC( 'c','v','d',' ' ) ); - p_dec->pf_decode_sub = Decode; p_dec->pf_packetize = Packetize; + p_dec->fmt_out.i_cat = SPU_ES; + p_dec->fmt_out.i_codec = VLC_CODEC_YUVP; + return VLC_SUCCESS; } @@ -232,7 +230,7 @@ static block_t *Reassemble( decoder_t *p_dec, block_t *p_block ) * to detect the first packet in a subtitle. The first packet * seems to have a valid PTS while later packets for the same * image don't. */ - if( p_sys->i_state == SUBTITLE_BLOCK_EMPTY && p_block->i_pts == 0 ) + if( p_sys->i_state == SUBTITLE_BLOCK_EMPTY && p_block->i_pts <= VLC_TS_INVALID ) { msg_Warn( p_dec, "first packet expected but no PTS present"); return NULL; @@ -498,10 +496,11 @@ static subpicture_t *DecodePacket( decoder_t *p_dec, block_t *p_data ) subpicture_t *p_spu; subpicture_region_t *p_region; video_format_t fmt; + video_palette_t palette; int i; /* Allocate the subpicture internal data. */ - p_spu = p_dec->pf_spu_buffer_new( p_dec ); + p_spu = decoder_NewSubpicture( p_dec, NULL ); if( !p_spu ) return NULL; p_spu->i_start = p_data->i_pts; @@ -510,16 +509,28 @@ static subpicture_t *DecodePacket( decoder_t *p_dec, block_t *p_data ) /* Create new SPU region */ memset( &fmt, 0, sizeof(video_format_t) ); - fmt.i_chroma = VLC_FOURCC('Y','U','V','P'); - fmt.i_aspect = VOUT_ASPECT_FACTOR; + fmt.i_chroma = VLC_CODEC_YUVP; + fmt.i_sar_num = 1; + fmt.i_sar_den = 1; fmt.i_width = fmt.i_visible_width = p_sys->i_width; fmt.i_height = fmt.i_visible_height = p_sys->i_height; fmt.i_x_offset = fmt.i_y_offset = 0; - p_region = p_spu->pf_create_region( VLC_OBJECT(p_dec), &fmt ); + fmt.p_palette = &palette; + fmt.p_palette->i_entries = 4; + for( i = 0; i < fmt.p_palette->i_entries; i++ ) + { + fmt.p_palette->palette[i][0] = p_sys->p_palette[i][0]; + fmt.p_palette->palette[i][1] = p_sys->p_palette[i][1]; + fmt.p_palette->palette[i][2] = p_sys->p_palette[i][2]; + fmt.p_palette->palette[i][3] = p_sys->p_palette[i][3]; + } + + p_region = subpicture_region_New( &fmt ); if( !p_region ) { msg_Err( p_dec, "cannot allocate SPU region" ); - //goto error; + decoder_DeleteSubpicture( p_dec, p_spu ); + return NULL; } p_spu->p_region = p_region; @@ -527,16 +538,6 @@ static subpicture_t *DecodePacket( decoder_t *p_dec, block_t *p_data ) p_region->i_x = p_region->i_x * 3 / 4; /* FIXME: use aspect ratio for x? */ p_region->i_y = p_sys->i_y_start; - /* Build palette */ - fmt.p_palette->i_entries = 4; - for( i = 0; i < fmt.p_palette->i_entries; i++ ) - { - fmt.p_palette->palette[i][0] = p_sys->p_palette[i][0]; - fmt.p_palette->palette[i][1] = p_sys->p_palette[i][1]; - fmt.p_palette->palette[i][2] = p_sys->p_palette[i][2]; - fmt.p_palette->palette[i][3] = p_sys->p_palette[i][3]; - } - RenderImage( p_dec, p_data, p_region ); return p_spu;