X-Git-Url: http://de.git.xonotic.org/?p=xonotic%2Fdarkplaces.git;a=blobdiff_plain;f=cl_video.h;h=05bf4a160cbca5f8fd5d64a73db3132cbe0be753;hp=9a6ad8c1bdd1341aed077ed11b9144c682270c5f;hb=f9efec5d9bd92a5b614aab549f8b0a009051fbbc;hpb=afe94889d0a86a7372936cf870bfe2951d449cb8 diff --git a/cl_video.h b/cl_video.h index 9a6ad8c1..05bf4a16 100644 --- a/cl_video.h +++ b/cl_video.h @@ -2,17 +2,24 @@ #ifndef CL_VIDEO_H #define CL_VIDEO_H +#include "cl_dyntexture.h" + #define MAXCLVIDEOS 64 + 1 // 1 video is reserved for the cinematic mode -#define CLVIDEOPREFIX "_" +// yields DYNAMIC_TEXTURE_PATH_PREFIX CLVIDEOPREFIX video name for a path +#define CLVIDEOPREFIX CLDYNTEXTUREPREFIX "video/" #define CLTHRESHOLD 2.0 -typedef enum clvideostate_s +#define MENUOWNER 1 + +typedef enum clvideostate_e { CLVIDEO_UNUSED, CLVIDEO_PLAY, CLVIDEO_LOOP, CLVIDEO_PAUSE, CLVIDEO_FIRSTFRAME, + CLVIDEO_RESETONWAKEUP, + CLVIDEO_STATECOUNT } clvideostate_t; typedef struct clvideo_s @@ -32,23 +39,24 @@ 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) - double lasttime; // used to determine whether the video's resources should be freed or not - qboolean suspended; // when lasttime - realtime > THRESHOLD, all but the stream is freed + + // 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 + qboolean suspended; char filename[MAX_QPATH]; } clvideo_t; -clvideo_t* CL_OpenVideo( char *filename, char *name, int owner ); -clvideo_t* CL_GetVideo( char *name ); -void CL_StartVideo( clvideo_t * video ); -void CL_LoopVideo( clvideo_t * video ); -void CL_PauseVideo( clvideo_t * video ); -void CL_StopVideo( clvideo_t * video ); +clvideo_t* CL_OpenVideo( const char *filename, const char *name, int owner ); +clvideo_t* CL_GetVideoByName( const char *name ); +void CL_SetVideoState( clvideo_t *video, clvideostate_t state ); void CL_RestartVideo( clvideo_t *video ); + void CL_CloseVideo( clvideo_t * video ); void CL_PurgeOwner( int owner ); -void CL_VideoFrame( void ); // update all videos +void CL_Video_Frame( void ); // update all videos void CL_Video_Init( void ); void CL_Video_Shutdown( void ); @@ -59,4 +67,8 @@ void CL_DrawVideo( void ); void CL_VideoStart( char *filename ); void CL_VideoStop( void ); +// new function used for fullscreen videos +// TODO: Andreas Kirsch: move this subsystem somewhere else (preferably host) since the cl_video system shouldnt do such work like managing key events.. +void CL_Video_KeyEvent( int key, int ascii, qboolean down ); + #endif