Commit 84a86ed7 authored by Sam Hocevar's avatar Sam Hocevar

  * Added support for some terribly braindead DVD subtitles in Kenshin
    which do not have a "stop display" command. Anime fans rejoice!
  * Fixed the BeOS interface to use p_aout_bank instead of p_main->p_aout.
  * Coding-style butchery (mostly tabs).
parent 58ab8de5
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* includes all common video types and constants. * includes all common video types and constants.
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000 VideoLAN * Copyright (C) 1999, 2000 VideoLAN
* $Id: video.h,v 1.29 2001/03/21 13:42:33 sam Exp $ * $Id: video.h,v 1.30 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Vincent Seguin <seguin@via.ecp.fr> * Authors: Vincent Seguin <seguin@via.ecp.fr>
* *
...@@ -123,9 +123,10 @@ typedef struct subpicture_s ...@@ -123,9 +123,10 @@ typedef struct subpicture_s
int i_size; /* data size */ int i_size; /* data size */
struct subpicture_s * p_next; /* next subtitle to be displayed */ struct subpicture_s * p_next; /* next subtitle to be displayed */
/* Other properties */ /* Date properties */
mtime_t begin_date; /* beginning of display date */ mtime_t i_start; /* beginning of display date */
mtime_t end_date; /* end of display date */ mtime_t i_stop; /* end of display date */
boolean_t b_ephemer; /* does the subtitle have a TTL ? */
/* Display properties - these properties are only indicative and may be /* Display properties - these properties are only indicative and may be
* changed by the video output thread, or simply ignored depending of the * changed by the video output thread, or simply ignored depending of the
......
This diff is collapsed.
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* dvd_ifo.c: Functions for ifo parsing * dvd_ifo.c: Functions for ifo parsing
***************************************************************************** *****************************************************************************
* Copyright (C) 1999-2001 VideoLAN * Copyright (C) 1999-2001 VideoLAN
* $Id: dvd_ifo.c,v 1.25 2001/05/07 03:14:09 stef Exp $ * $Id: dvd_ifo.c,v 1.26 2001/05/07 04:42:42 sam Exp $
* *
* Author: Stphane Borel <stef@via.ecp.fr> * Author: Stphane Borel <stef@via.ecp.fr>
* *
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* -dvd_udf to find files * -dvd_udf to find files
***************************************************************************** *****************************************************************************
* Copyright (C) 1998-2001 VideoLAN * Copyright (C) 1998-2001 VideoLAN
* $Id: input_dvd.c,v 1.56 2001/05/07 03:14:09 stef Exp $ * $Id: input_dvd.c,v 1.57 2001/05/07 04:42:42 sam Exp $
* *
* Author: Stphane Borel <stef@via.ecp.fr> * Author: Stphane Borel <stef@via.ecp.fr>
* *
...@@ -668,7 +668,6 @@ static int DVDSetArea( input_thread_t * p_input, input_area_t * p_area ) ...@@ -668,7 +668,6 @@ static int DVDSetArea( input_thread_t * p_input, input_area_t * p_area )
p_dvd->i_cell = vts.cell_inf.i_cell_nb - 1; p_dvd->i_cell = vts.cell_inf.i_cell_nb - 1;
} }
p_dvd->i_sector = 0; p_dvd->i_sector = 0;
p_dvd->i_size = DVD_LB_SIZE * p_dvd->i_size = DVD_LB_SIZE *
(off_t)( vts.cell_inf.p_cell_map[p_dvd->i_cell].i_end_sector ); (off_t)( vts.cell_inf.p_cell_map[p_dvd->i_cell].i_end_sector );
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* input_ps.c: PS demux and packet management * input_ps.c: PS demux and packet management
***************************************************************************** *****************************************************************************
* Copyright (C) 1998, 1999, 2000 VideoLAN * Copyright (C) 1998, 1999, 2000 VideoLAN
* $Id: input_ps.c,v 1.21 2001/05/07 03:14:09 stef Exp $ * $Id: input_ps.c,v 1.22 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Christophe Massiot <massiot@via.ecp.fr> * Authors: Christophe Massiot <massiot@via.ecp.fr>
* Cyril Deguet <asmax@via.ecp.fr> * Cyril Deguet <asmax@via.ecp.fr>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* vout_sdl.c: SDL video output display method * vout_sdl.c: SDL video output display method
***************************************************************************** *****************************************************************************
* Copyright (C) 1998, 1999, 2000 VideoLAN * Copyright (C) 1998, 1999, 2000 VideoLAN
* $Id: vout_sdl.c,v 1.50 2001/05/07 03:14:09 stef Exp $ * $Id: vout_sdl.c,v 1.51 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Samuel Hocevar <sam@zoy.org> * Authors: Samuel Hocevar <sam@zoy.org>
* Pierre Baillet <oct@zoy.org> * Pierre Baillet <oct@zoy.org>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* vout_xvideo.c: Xvideo video output display method * vout_xvideo.c: Xvideo video output display method
***************************************************************************** *****************************************************************************
* Copyright (C) 1998, 1999, 2000, 2001 VideoLAN * Copyright (C) 1998, 1999, 2000, 2001 VideoLAN
* $Id: vout_xvideo.c,v 1.15 2001/05/07 03:14:09 stef Exp $ * $Id: vout_xvideo.c,v 1.16 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Shane Harper <shanegh@optusnet.com.au> * Authors: Shane Harper <shanegh@optusnet.com.au>
* Vincent Seguin <seguin@via.ecp.fr> * Vincent Seguin <seguin@via.ecp.fr>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* ac3_parse.c: ac3 parsing procedures * ac3_parse.c: ac3 parsing procedures
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000, 2001 VideoLAN * Copyright (C) 1999, 2000, 2001 VideoLAN
* $Id: ac3_parse.c,v 1.20 2001/05/06 04:32:02 sam Exp $ * $Id: ac3_parse.c,v 1.21 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Michel Kaempf <maxx@via.ecp.fr> * Authors: Michel Kaempf <maxx@via.ecp.fr>
* Aaron Holtzman <aholtzma@engr.uvic.ca> * Aaron Holtzman <aholtzma@engr.uvic.ca>
......
...@@ -3,7 +3,7 @@ ...@@ -3,7 +3,7 @@
* Functions are prototyped in mtime.h. * Functions are prototyped in mtime.h.
***************************************************************************** *****************************************************************************
* Copyright (C) 1998, 1999, 2000 VideoLAN * Copyright (C) 1998, 1999, 2000 VideoLAN
* $Id: mtime.c,v 1.17 2001/04/28 03:36:25 sam Exp $ * $Id: mtime.c,v 1.18 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Vincent Seguin <seguin@via.ecp.fr> * Authors: Vincent Seguin <seguin@via.ecp.fr>
* *
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* netutils.c: various network functions * netutils.c: various network functions
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000, 2001 VideoLAN * Copyright (C) 1999, 2000, 2001 VideoLAN
* $Id: netutils.c,v 1.28 2001/04/28 03:36:25 sam Exp $ * $Id: netutils.c,v 1.29 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Vincent Seguin <seguin@via.ecp.fr> * Authors: Vincent Seguin <seguin@via.ecp.fr>
* Benoit Steiner <benny@via.ecp.fr> * Benoit Steiner <benny@via.ecp.fr>
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* spu_decoder.c : spu decoder thread * spu_decoder.c : spu decoder thread
***************************************************************************** *****************************************************************************
* Copyright (C) 2000 VideoLAN * Copyright (C) 2000 VideoLAN
* $Id: spu_decoder.c,v 1.41 2001/05/07 03:14:09 stef Exp $ * $Id: spu_decoder.c,v 1.42 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Samuel Hocevar <sam@zoy.org> * Authors: Samuel Hocevar <sam@zoy.org>
* *
...@@ -49,8 +49,6 @@ ...@@ -49,8 +49,6 @@
#include "spu_decoder.h" #include "spu_decoder.h"
#include "main.h" /* XXX: remove this later */
/***************************************************************************** /*****************************************************************************
* Local prototypes * Local prototypes
*****************************************************************************/ *****************************************************************************/
...@@ -88,14 +86,12 @@ vlc_thread_t spudec_CreateThread( vdec_config_t * p_config ) ...@@ -88,14 +86,12 @@ vlc_thread_t spudec_CreateThread( vdec_config_t * p_config )
p_spudec->p_fifo = p_config->decoder_config.p_decoder_fifo; p_spudec->p_fifo = p_config->decoder_config.p_decoder_fifo;
/* XXX: The vout request and fifo opening will eventually be here */ /* Spawn a video output if there is none */
/* Spawn an audio output if there is none */
vlc_mutex_lock( &p_vout_bank->lock ); vlc_mutex_lock( &p_vout_bank->lock );
if( p_vout_bank->i_count == 0 ) if( p_vout_bank->i_count == 0 )
{ {
intf_Msg( "spudec: no vout present, spawning one" ); intf_WarnMsg( 1, "spudec: no vout present, spawning one" );
p_spudec->p_vout = vout_CreateThread( NULL ); p_spudec->p_vout = vout_CreateThread( NULL );
...@@ -275,9 +271,13 @@ static void ParsePacket( spudec_thread_t *p_spudec ) ...@@ -275,9 +271,13 @@ static void ParsePacket( spudec_thread_t *p_spudec )
subpicture_t * p_spu; subpicture_t * p_spu;
u8 * p_src; u8 * p_src;
intf_WarnMsg( 3, "spudec: trying to gather a 0x%.2x long subtitle",
p_spudec->i_spu_size );
/* We cannot display a subpicture with no date */ /* We cannot display a subpicture with no date */
if( DECODER_FIFO_START(*p_spudec->p_fifo)->i_pts == 0 ) if( DECODER_FIFO_START(*p_spudec->p_fifo)->i_pts == 0 )
{ {
intf_WarnMsg( 3, "spudec error: subtitle without a date" );
return; return;
} }
...@@ -294,9 +294,8 @@ static void ParsePacket( spudec_thread_t *p_spudec ) ...@@ -294,9 +294,8 @@ static void ParsePacket( spudec_thread_t *p_spudec )
return; return;
} }
/* Get display time now. If we do it later, we may miss a PTS. */ /* Get display time now. If we do it later, we may miss the PTS. */
p_spu->begin_date = p_spu->end_date p_spudec->i_pts = DECODER_FIFO_START(*p_spudec->p_fifo)->i_pts;
= DECODER_FIFO_START(*p_spudec->p_fifo)->i_pts;
/* Allocate the temporary buffer we will parse */ /* Allocate the temporary buffer we will parse */
p_src = malloc( p_spudec->i_rle_size ); p_src = malloc( p_spudec->i_rle_size );
...@@ -313,7 +312,7 @@ static void ParsePacket( spudec_thread_t *p_spudec ) ...@@ -313,7 +312,7 @@ static void ParsePacket( spudec_thread_t *p_spudec )
#if 0 #if 0
/* Dump the subtitle info */ /* Dump the subtitle info */
intf_WarnHexDump( 0, p_spu->p_data, p_spudec->i_rle_size ); intf_WarnHexDump( 5, p_spu->p_data, p_spudec->i_rle_size );
#endif #endif
/* Getting the control part */ /* Getting the control part */
...@@ -333,9 +332,11 @@ static void ParsePacket( spudec_thread_t *p_spudec ) ...@@ -333,9 +332,11 @@ static void ParsePacket( spudec_thread_t *p_spudec )
return; return;
} }
intf_WarnMsg( 3, "spudec: got a valid %ix%i subtitle at (%i,%i), " intf_WarnMsg( 3, "spudec: valid subtitle, size: %ix%i, position: %i,%i",
"RLE offsets: 0x%x 0x%x", p_spu->i_width, p_spu->i_height, p_spu->i_x, p_spu->i_y );
p_spu->i_width, p_spu->i_height, p_spu->i_x, p_spu->i_y,
intf_WarnMsg( 3, "spudec: total size: 0x%x, RLE offsets: 0x%x 0x%x",
p_spudec->i_spu_size,
p_spu->type.spu.i_offset[0], p_spu->type.spu.i_offset[1] ); p_spu->type.spu.i_offset[0], p_spu->type.spu.i_offset[1] );
/* SPU is finished - we can ask the video output to display it */ /* SPU is finished - we can ask the video output to display it */
...@@ -359,20 +360,24 @@ static int ParseControlSequences( spudec_thread_t *p_spudec, ...@@ -359,20 +360,24 @@ static int ParseControlSequences( spudec_thread_t *p_spudec,
int i_index = p_spudec->i_rle_size + 4; int i_index = p_spudec->i_rle_size + 4;
/* The next start-of-control-sequence index and the previous one */ /* The next start-of-control-sequence index and the previous one */
int i_next_index = 0, i_prev_index; int i_next_seq, i_cur_seq;
/* Command time and date */ /* Command time and date */
u8 i_command; u8 i_command;
int i_date; int i_date;
/* Initialize the structure */
p_spu->i_start = p_spu->i_stop = 0;
p_spu->b_ephemer = 0;
do do
{ {
/* Get the control sequence date */ /* Get the control sequence date */
i_date = GetBits( &p_spudec->bit_stream, 16 ); i_date = GetBits( &p_spudec->bit_stream, 16 );
/* Next offset */ /* Next offset */
i_prev_index = i_next_index; i_cur_seq = i_index;
i_next_index = GetBits( &p_spudec->bit_stream, 16 ); i_next_seq = GetBits( &p_spudec->bit_stream, 16 );
/* Skip what we just read */ /* Skip what we just read */
i_index += 4; i_index += 4;
...@@ -387,20 +392,24 @@ static int ParseControlSequences( spudec_thread_t *p_spudec, ...@@ -387,20 +392,24 @@ static int ParseControlSequences( spudec_thread_t *p_spudec,
case SPU_CMD_FORCE_DISPLAY: case SPU_CMD_FORCE_DISPLAY:
/* 00 (force displaying) */ /* 00 (force displaying) */
intf_ErrMsg( "spudec: \"force display\" command" );
intf_ErrMsg( "spudec: send mail to <sam@zoy.org> if you "
"want to help debugging this" );
break; break;
/* Convert the dates in seconds to PTS values */ /* Convert the dates in seconds to PTS values */
case SPU_CMD_START_DISPLAY: case SPU_CMD_START_DISPLAY:
/* 01 (start displaying) */ /* 01 (start displaying) */
p_spu->begin_date += ( i_date * 11000 ); p_spu->i_start = p_spudec->i_pts + ( i_date * 11000 );
break; break;
case SPU_CMD_STOP_DISPLAY: case SPU_CMD_STOP_DISPLAY:
/* 02 (stop displaying) */ /* 02 (stop displaying) */
p_spu->end_date += ( i_date * 11000 ); p_spu->i_stop = p_spudec->i_pts + ( i_date * 11000 );
break; break;
...@@ -463,13 +472,13 @@ static int ParseControlSequences( spudec_thread_t *p_spudec, ...@@ -463,13 +472,13 @@ static int ParseControlSequences( spudec_thread_t *p_spudec,
} while( i_command != SPU_CMD_END ); } while( i_command != SPU_CMD_END );
} while( i_index == i_next_index ); } while( i_index == i_next_seq );
/* Check that the last index matches the previous one */ /* Check that the next sequence index matches the current one */
if( i_next_index != i_prev_index ) if( i_next_seq != i_cur_seq )
{ {
intf_ErrMsg( "spudec error: index mismatch (0x%.4x != 0x%.4x)", intf_ErrMsg( "spudec error: index mismatch (0x%.4x != 0x%.4x)",
i_next_index, i_prev_index ); i_next_seq, i_cur_seq );
return( 1 ); return( 1 );
} }
...@@ -480,18 +489,26 @@ static int ParseControlSequences( spudec_thread_t *p_spudec, ...@@ -480,18 +489,26 @@ static int ParseControlSequences( spudec_thread_t *p_spudec,
return( 1 ); return( 1 );
} }
if( !p_spu->i_start )
{
intf_ErrMsg( "spudec error: no `start display' command" );
}
if( !p_spu->i_stop )
{
/* This subtitle will live for 5 seconds or until the next subtitle */
p_spu->i_stop = p_spu->i_start + 500 * 11000;
p_spu->b_ephemer = 1;
}
/* Get rid of padding bytes */ /* Get rid of padding bytes */
switch( p_spudec->i_spu_size - i_index ) switch( p_spudec->i_spu_size - i_index )
{ {
case 1: case 1:
RemoveBits( &p_spudec->bit_stream, 8 ); RemoveBits( &p_spudec->bit_stream, 8 );
i_index++; i_index++;
case 0: case 0:
/* Zero or one padding byte, quite usual */ /* Zero or one padding byte, quite usual */
break; break;
default: default:
......
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* spu_decoder.h : sub picture unit decoder thread interface * spu_decoder.h : sub picture unit decoder thread interface
***************************************************************************** *****************************************************************************
* Copyright (C) 1999, 2000 VideoLAN * Copyright (C) 1999, 2000 VideoLAN
* $Id: spu_decoder.h,v 1.7 2001/03/21 13:42:34 sam Exp $ * $Id: spu_decoder.h,v 1.8 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Samuel Hocevar <sam@zoy.org> * Authors: Samuel Hocevar <sam@zoy.org>
* *
...@@ -47,6 +47,7 @@ typedef struct spudec_thread_s ...@@ -47,6 +47,7 @@ typedef struct spudec_thread_s
/* /*
* Private properties * Private properties
*/ */
mtime_t i_pts; /* presentation timestamp */
int i_spu_size; /* size of current SPU packet */ int i_spu_size; /* size of current SPU packet */
int i_rle_size; /* size of the RLE part */ int i_rle_size; /* size of the RLE part */
subpicture_t * p_spu; subpicture_t * p_spu;
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
* thread, and destroy a previously oppened video output thread. * thread, and destroy a previously oppened video output thread.
***************************************************************************** *****************************************************************************
* Copyright (C) 2000 VideoLAN * Copyright (C) 2000 VideoLAN
* $Id: video_output.c,v 1.125 2001/05/07 03:14:10 stef Exp $ * $Id: video_output.c,v 1.126 2001/05/07 04:42:42 sam Exp $
* *
* Authors: Vincent Seguin <seguin@via.ecp.fr> * Authors: Vincent Seguin <seguin@via.ecp.fr>
* *
...@@ -217,11 +217,13 @@ vout_thread_t * vout_CreateThread ( int *pi_status ) ...@@ -217,11 +217,13 @@ vout_thread_t * vout_CreateThread ( int *pi_status )
p_vout->p_picture[i_index].i_type = EMPTY_PICTURE; p_vout->p_picture[i_index].i_type = EMPTY_PICTURE;
p_vout->p_picture[i_index].i_status = FREE_PICTURE; p_vout->p_picture[i_index].i_status = FREE_PICTURE;
} }
for( i_index = 0; i_index < VOUT_MAX_SUBPICTURES; i_index++) for( i_index = 0; i_index < VOUT_MAX_SUBPICTURES; i_index++)
{ {
p_vout->p_subpicture[i_index].i_type = EMPTY_SUBPICTURE; p_vout->p_subpicture[i_index].i_type = EMPTY_SUBPICTURE;
p_vout->p_subpicture[i_index].i_status= FREE_SUBPICTURE; p_vout->p_subpicture[i_index].i_status = FREE_SUBPICTURE;
} }
p_vout->i_pictures = 0; p_vout->i_pictures = 0;
/* Create and initialize system-dependant method - this function issues its /* Create and initialize system-dependant method - this function issues its
...@@ -232,6 +234,7 @@ vout_thread_t * vout_CreateThread ( int *pi_status ) ...@@ -232,6 +234,7 @@ vout_thread_t * vout_CreateThread ( int *pi_status )
free( p_vout ); free( p_vout );
return( NULL ); return( NULL );
} }
intf_WarnMsg( 3, "actual configuration: %dx%d, %d/%d bpp (%d Bpl), " intf_WarnMsg( 3, "actual configuration: %dx%d, %d/%d bpp (%d Bpl), "
"masks: 0x%x/0x%x/0x%x", "masks: 0x%x/0x%x/0x%x",
p_vout->i_width, p_vout->i_height, p_vout->i_screen_depth, p_vout->i_width, p_vout->i_height, p_vout->i_screen_depth,
...@@ -337,15 +340,15 @@ void vout_DestroyThread( vout_thread_t *p_vout, int *pi_status ) ...@@ -337,15 +340,15 @@ void vout_DestroyThread( vout_thread_t *p_vout, int *pi_status )
/***************************************************************************** /*****************************************************************************
* vout_DisplaySubPicture: display a subpicture unit * vout_DisplaySubPicture: display a subpicture unit
***************************************************************************** *****************************************************************************
* Remove the reservation flag of an subpicture, which will cause it to be ready * Remove the reservation flag of a subpicture, which will cause it to be ready
* for display. The picture does not need to be locked, since it is ignored by * for display. The picture does not need to be locked, since it is ignored by
* the output thread if is reserved. * the output thread if is reserved.
*****************************************************************************/ *****************************************************************************/
void vout_DisplaySubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic ) void vout_DisplaySubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic )
{ {
#ifdef TRACE_VOUT #ifdef TRACE_VOUT
char psz_begin_date[MSTRTIME_MAX_SIZE]; /* buffer for date string */ char psz_start[ MSTRTIME_MAX_SIZE ]; /* buffer for date string */
char psz_end_date[MSTRTIME_MAX_SIZE]; /* buffer for date string */ char psz_stop[ MSTRTIME_MAX_SIZE ]; /* buffer for date string */
#endif #endif
#ifdef DEBUG #ifdef DEBUG
...@@ -364,8 +367,8 @@ void vout_DisplaySubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic ) ...@@ -364,8 +367,8 @@ void vout_DisplaySubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic )
/* Send subpicture information */ /* Send subpicture information */
intf_DbgMsg("subpicture %p: type=%d, begin date=%s, end date=%s", intf_DbgMsg("subpicture %p: type=%d, begin date=%s, end date=%s",
p_subpic, p_subpic->i_type, p_subpic, p_subpic->i_type,
mstrtime( psz_begin_date, p_subpic->begin_date ), mstrtime( psz_start, p_subpic->i_start ),
mstrtime( psz_end_date, p_subpic->end_date ) ); mstrtime( psz_stop, p_subpic->i_stop ) );
#endif #endif
} }
...@@ -1065,6 +1068,7 @@ static void RunThread( vout_thread_t *p_vout) ...@@ -1065,6 +1068,7 @@ static void RunThread( vout_thread_t *p_vout)
display_date = 0; display_date = 0;
} }
} }
/* /*
* Find the subpictures to display - this operation does not need * Find the subpictures to display - this operation does not need
* lock, since only READY_SUBPICTURE are handled. If no picture * lock, since only READY_SUBPICTURE are handled. If no picture
...@@ -1090,9 +1094,6 @@ static void RunThread( vout_thread_t *p_vout) ...@@ -1090,9 +1094,6 @@ static void RunThread( vout_thread_t *p_vout)
p_vout->last_display_date = display_date; p_vout->last_display_date = display_date;
p_vout->p_rendered_pic = p_pic; p_vout->p_rendered_pic = p_pic;
/* Set picture dimensions and clear buffer */ /* Set picture dimensions and clear buffer */
SetBufferPicture( p_vout, p_pic ); SetBufferPicture( p_vout, p_pic );
...@@ -1951,6 +1952,43 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic ) ...@@ -1951,6 +1952,43 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic )
{ {
p_vout_font_t p_font; /* text font */ p_vout_font_t p_font; /* text font */
int i_width, i_height; /* subpicture dimensions */ int i_width, i_height; /* subpicture dimensions */
mtime_t i_date = mdate();
subpicture_t *p_ephemer = NULL;
subpicture_t *p_tmp = p_subpic;
/* Look for the youngest ephemer */
while( p_tmp != NULL )
{
if( p_tmp->i_type == DVD_SUBPICTURE && p_tmp->b_ephemer
&& i_date >= p_tmp->i_start && i_date <= p_tmp->i_stop )
{
if( p_ephemer == NULL || p_tmp->i_start < p_ephemer->i_start )
{
p_ephemer = p_tmp;
}
}
p_tmp = p_tmp->p_next;
}
/* If we found an ephemer, kill it if we find a more recent one */
if( p_ephemer != NULL )
{
p_tmp = p_subpic;
while( p_tmp != NULL )
{
if( p_tmp->i_type == DVD_SUBPICTURE
&& i_date >= p_tmp->i_start && i_date >= p_tmp->i_start
&& p_tmp != p_ephemer && p_tmp->i_start > p_ephemer->i_start )
{
p_ephemer->i_stop = 0;
}
p_tmp = p_tmp->p_next;
}
}
while( p_subpic != NULL ) while( p_subpic != NULL )
{ {
...@@ -1958,12 +1996,12 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic ) ...@@ -1958,12 +1996,12 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic )
{ {
case DVD_SUBPICTURE: /* DVD subpicture unit */ case DVD_SUBPICTURE: /* DVD subpicture unit */
/* test if the picture really has to be displayed */ /* test if the picture really has to be displayed */
if( mdate() < p_subpic->begin_date ) if( i_date < p_subpic->i_start )
{ {
/* not yet, see you later */ /* not yet, see you later */
break; break;
} }
if( mdate() > p_subpic->end_date ) if( i_date > p_subpic->i_stop )
{ {
/* too late, destroying the subpic */ /* too late, destroying the subpic */
vout_DestroySubPicture( p_vout, p_subpic ); vout_DestroySubPicture( p_vout, p_subpic );
...@@ -1973,6 +2011,7 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic ) ...@@ -1973,6 +2011,7 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic )
p_subpic, p_vout->i_bytes_per_pixel, p_subpic, p_vout->i_bytes_per_pixel,
p_vout->i_bytes_per_line ); p_vout->i_bytes_per_line );
break; break;
case TEXT_SUBPICTURE: /* single line text */ case TEXT_SUBPICTURE: /* single line text */
/* Select default font if not specified */ /* Select default font if not specified */
p_font = p_subpic->type.text.p_font; p_font = p_subpic->type.text.p_font;
...@@ -2003,11 +2042,12 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic ) ...@@ -2003,11 +2042,12 @@ static void RenderSubPicture( vout_thread_t *p_vout, subpicture_t *p_subpic )
} }
break; break;
#ifdef DEBUG
default: default:
#ifdef DEBUG
intf_ErrMsg( "error: unknown subpicture %p type %d", intf_ErrMsg( "error: unknown subpicture %p type %d",
p_subpic, p_subpic->i_type ); p_subpic, p_subpic->i_type );
#endif #endif
break;
} }
p_subpic = p_subpic->p_next; p_subpic = p_subpic->p_next;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment