Mercurial > mplayer.hg
annotate libmpcodecs/vd_vfw.c @ 7121:6abc330b5b32
subtitle/osd cache - pre-render text to a buffer with alpha and bitmap separated
- it solves overlapping alpha problem
- speed up osd rendering (it renders bigger area but in a single pass)
patch by Jindrich Makovicka <makovick@kmlinux.fjfi.cvut.cz>
some cleanup by me
author | arpi |
---|---|
date | Wed, 28 Aug 2002 20:45:42 +0000 |
parents | e69615f1c309 |
children | f8b147aab1a5 |
rev | line source |
---|---|
4968 | 1 #include <stdio.h> |
2 #include <stdlib.h> | |
3 | |
4 #include "config.h" | |
5 #ifdef USE_WIN32DLL | |
6 | |
7 #include "mp_msg.h" | |
8 #include "help_mp.h" | |
9 | |
10 #include "vd_internal.h" | |
11 | |
12 #include "dll_init.h" | |
13 | |
14 static vd_info_t info_vfw = { | |
15 "Win32/VfW video codecs", | |
16 "vfw", | |
17 VFM_VFW, | |
18 "A'rpi", | |
19 "based on http://avifile.sf.net", | |
20 "win32 codecs" | |
21 }; | |
22 | |
23 static vd_info_t info_vfwex = { | |
24 "Win32/VfWex video codecs", | |
25 "vfwex", | |
26 VFM_VFWEX, | |
27 "A'rpi", | |
28 "based on http://avifile.sf.net", | |
29 "win32 codecs" | |
30 }; | |
31 | |
32 #define info info_vfw | |
33 LIBVD_EXTERN(vfw) | |
34 #undef info | |
35 | |
36 #define info info_vfwex | |
37 LIBVD_EXTERN(vfwex) | |
38 #undef info | |
39 | |
40 // to set/get/query special features/parameters | |
41 static int control(sh_video_t *sh,int cmd,void* arg,...){ | |
42 switch(cmd){ | |
43 case VDCTRL_QUERY_MAX_PP_LEVEL: | |
44 return 9; | |
45 case VDCTRL_SET_PP_LEVEL: | |
46 vfw_set_postproc(sh,10*(*((int*)arg))); | |
47 return CONTROL_OK; | |
48 } | |
49 return CONTROL_UNKNOWN; | |
50 } | |
51 | |
52 // init driver | |
53 static int init(sh_video_t *sh){ | |
5153 | 54 if(!mpcodecs_config_vo(sh,sh->disp_w,sh->disp_h,IMGFMT_YUY2)) return 0; |
4968 | 55 if(!init_vfw_video_codec(sh,(sh->codec->driver==VFM_VFWEX))) return 0; |
56 mp_msg(MSGT_DECVIDEO,MSGL_V,"INFO: Win32 video codec init OK!\n"); | |
5153 | 57 return 1; |
4968 | 58 } |
59 | |
60 // uninit driver | |
61 static void uninit(sh_video_t *sh){ | |
5451 | 62 vfw_close_video_codec(sh, (sh->codec->driver==VFM_VFWEX)); |
4968 | 63 } |
64 | |
65 //mp_image_t* mpcodecs_get_image(sh_video_t *sh, int mp_imgtype, int mp_imgflag, int w, int h); | |
66 | |
67 // decode a frame | |
68 static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ | |
69 mp_image_t* mpi; | |
70 int ret; | |
71 if(len<=0) return NULL; // skipped frame | |
72 | |
6105
b77b984120f9
iive is right - we shouldn't use IP buffering for vfw. it was changed
arpi
parents:
5769
diff
changeset
|
73 mpi=mpcodecs_get_image(sh, |
b77b984120f9
iive is right - we shouldn't use IP buffering for vfw. it was changed
arpi
parents:
5769
diff
changeset
|
74 (sh->codec->outflags[sh->outfmtidx] & CODECS_FLAG_STATIC) ? |
b77b984120f9
iive is right - we shouldn't use IP buffering for vfw. it was changed
arpi
parents:
5769
diff
changeset
|
75 MP_IMGTYPE_STATIC : MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_WIDTH, |
4968 | 76 sh->disp_w, sh->disp_h); |
77 if(!mpi){ // temporary! | |
78 printf("couldn't allocate image for cinepak codec\n"); | |
79 return NULL; | |
80 } | |
81 | |
82 // set buffer: | |
83 sh->our_out_buffer=mpi->planes[0]; | |
84 | |
85 // set stride: (trick discovered by Andreas Ackermann - thanx!) | |
86 sh->bih->biWidth=mpi->width; //mpi->stride[0]/(mpi->bpp/8); | |
87 sh->o_bih.biWidth=mpi->width; //mpi->stride[0]/(mpi->bpp/8); | |
88 | |
89 if((ret=vfw_decode_video(sh,data,len,flags&3,(sh->codec->driver==VFM_VFWEX) ))){ | |
90 mp_msg(MSGT_DECVIDEO,MSGL_WARN,"Error decompressing frame, err=%d\n",ret); | |
91 return NULL; | |
92 } | |
93 | |
5769 | 94 if(mpi->imgfmt==IMGFMT_RGB8 || mpi->imgfmt==IMGFMT_BGR8){ |
95 // export palette: | |
6232 | 96 // FIXME: sh->o_bih is cutted down to 40 bytes!!! |
97 // if(sh->o_bih->biSize>40) | |
98 // mpi->planes[1]=((unsigned char*)&sh->o_bih)+40; | |
99 // else | |
100 mpi->planes[1]=NULL; | |
5769 | 101 } |
102 | |
4968 | 103 return mpi; |
104 } | |
105 | |
106 #endif |