X-Git-Url: http://git.xonotic.org/?a=blobdiff_plain;f=cl_video.h;h=97960b89bff97adc966530381ca661366260fe4f;hb=3356797550466b320ca897b33e6972ac6d15cefc;hp=d98c0087d5179e7cd14ad3a85eb28e19c9e055a1;hpb=c1ab987e992c1c56ed9ea09426408f7b62ae5100;p=xonotic%2Fdarkplaces.git diff --git a/cl_video.h b/cl_video.h index d98c0087..97960b89 100644 --- a/cl_video.h +++ b/cl_video.h @@ -21,6 +21,17 @@ typedef enum clvideostate_e CLVIDEO_STATECOUNT } clvideostate_t; +#define CLVIDEO_MAX_SUBTITLES 512 + +extern cvar_t cl_video_subtitles; +extern cvar_t cl_video_subtitles_lines; +extern cvar_t cl_video_subtitles_textsize; +extern cvar_t cl_video_scale; +extern cvar_t cl_video_scale_vpos; +extern cvar_t cl_video_stipple; +extern cvar_t cl_video_brightness; +extern cvar_t cl_video_keepaspectratio; + typedef struct clvideo_s { int ownertag; @@ -37,8 +48,21 @@ typedef struct clvideo_s cachepic_t cpif; - // if a video is suspended, it is automatically paused (else we'd still have to process the frames) + // VorteX: subtitles array + int subtitles; + char *subtitle_text[CLVIDEO_MAX_SUBTITLES]; + float subtitle_start[CLVIDEO_MAX_SUBTITLES]; + float subtitle_end[CLVIDEO_MAX_SUBTITLES]; + // this functions gets filled by video format module + void (*close) (void *stream); + unsigned int (*getwidth) (void *stream); + unsigned int (*getheight) (void *stream); + double (*getframerate) (void *stream); + double (*getaspectratio) (void *stream); + int (*decodeframe) (void *stream, void *imagedata, unsigned int Rmask, unsigned int Gmask, unsigned int Bmask, unsigned int bytesperpixel, int imagebytesperrow); + + // if a video is suspended, it is automatically paused (else we'd still have to process the frames) // used to determine whether the video's resources should be freed or not double lasttime; // when lasttime - realtime > THRESHOLD, all but the stream is freed @@ -47,7 +71,7 @@ typedef struct clvideo_s char filename[MAX_QPATH]; } clvideo_t; -clvideo_t* CL_OpenVideo( const char *filename, const char *name, int owner ); +clvideo_t* CL_OpenVideo( const char *filename, const char *name, int owner, const char *subtitlesfile ); clvideo_t* CL_GetVideoByName( const char *name ); void CL_SetVideoState( clvideo_t *video, clvideostate_t state ); void CL_RestartVideo( clvideo_t *video ); @@ -63,7 +87,7 @@ void CL_Video_Shutdown( void ); extern int cl_videoplaying; void CL_DrawVideo( void ); -void CL_VideoStart( char *filename ); +void CL_VideoStart( char *filename, const char *subtitlesfile ); void CL_VideoStop( void ); // new function used for fullscreen videos