2002-03-07 01:39:07 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
#include "mp_msg.h"
|
|
|
|
|
|
|
|
#include "vd_internal.h"
|
|
|
|
|
|
|
|
static vd_info_t info = {
|
|
|
|
"RAW Uncompressed Video",
|
|
|
|
"raw",
|
|
|
|
VFM_RAW,
|
|
|
|
"A'rpi",
|
|
|
|
"A'rpi & Alex",
|
|
|
|
"uncompressed"
|
|
|
|
};
|
|
|
|
|
|
|
|
LIBVD_EXTERN(raw)
|
|
|
|
|
|
|
|
// to set/get/query special features/parameters
|
|
|
|
static int control(sh_video_t *sh,int cmd,void* arg,...){
|
|
|
|
switch(cmd){
|
|
|
|
case VDCTRL_QUERY_FORMAT:
|
2002-05-29 22:38:34 +00:00
|
|
|
if( (*((int*)arg)) == sh->bih->biCompression ) return CONTROL_TRUE;
|
2002-03-07 01:39:07 +00:00
|
|
|
return CONTROL_FALSE;
|
|
|
|
}
|
|
|
|
return CONTROL_UNKNOWN;
|
|
|
|
}
|
|
|
|
|
|
|
|
// init driver
|
|
|
|
static int init(sh_video_t *sh){
|
2002-05-29 22:38:34 +00:00
|
|
|
if(!sh->bih) return 0; // bih is required
|
2002-03-07 01:39:07 +00:00
|
|
|
// set format fourcc for raw RGB:
|
2002-05-29 22:38:34 +00:00
|
|
|
if(sh->bih->biCompression==0){ // set based on bit depth
|
2002-03-07 01:39:07 +00:00
|
|
|
switch(sh->bih->biBitCount){
|
2002-05-29 22:38:34 +00:00
|
|
|
case 8: sh->bih->biCompression=IMGFMT_BGR8; break;
|
|
|
|
case 15: sh->bih->biCompression=IMGFMT_BGR15; break;
|
|
|
|
// workaround bitcount==16 => bgr15 case for avi files:
|
|
|
|
case 16: sh->bih->biCompression=(sh->format)?IMGFMT_BGR16:IMGFMT_BGR15; break;
|
|
|
|
case 24: sh->bih->biCompression=IMGFMT_BGR24; break;
|
|
|
|
case 32: sh->bih->biCompression=IMGFMT_BGR32; break;
|
2002-03-07 01:39:07 +00:00
|
|
|
default:
|
|
|
|
mp_msg(MSGT_DECVIDEO,MSGL_WARN,"RAW: depth %d not supported\n",sh->bih->biBitCount);
|
|
|
|
}
|
|
|
|
}
|
2002-05-29 22:38:34 +00:00
|
|
|
return mpcodecs_config_vo(sh,sh->disp_w,sh->disp_h,sh->bih->biCompression);
|
2002-03-07 01:39:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// uninit driver
|
|
|
|
static void uninit(sh_video_t *sh){
|
|
|
|
}
|
|
|
|
|
|
|
|
//mp_image_t* mpcodecs_get_image(sh_video_t *sh, int mp_imgtype, int mp_imgflag, int w, int h);
|
|
|
|
|
|
|
|
// decode a frame
|
|
|
|
static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){
|
|
|
|
mp_image_t* mpi;
|
|
|
|
if(len<=0) return NULL; // skipped frame
|
|
|
|
|
|
|
|
mpi=mpcodecs_get_image(sh, MP_IMGTYPE_EXPORT, 0,
|
|
|
|
sh->disp_w, sh->disp_h);
|
|
|
|
if(!mpi) return NULL;
|
|
|
|
|
|
|
|
if(mpi->flags&MP_IMGFLAG_PLANAR){
|
|
|
|
// TODO !!!
|
|
|
|
mpi->planes[0]=data;
|
|
|
|
mpi->stride[0]=mpi->width;
|
2002-03-23 14:26:53 +00:00
|
|
|
if(mpi->bpp == 12 && mpi->flags&MP_IMGFLAG_YUV) {
|
|
|
|
// Support for some common Planar YUV formats
|
2002-06-21 16:37:37 +00:00
|
|
|
/* YV12,I420,IYUV */
|
2002-05-03 19:45:43 +00:00
|
|
|
int cb=2, cr=1;
|
2002-05-04 05:46:36 +00:00
|
|
|
if(mpi->flags&MP_IMGFLAG_SWAPPED) {
|
2002-05-03 19:45:43 +00:00
|
|
|
cb=1; cr=2;
|
|
|
|
}
|
|
|
|
mpi->planes[cb]=data+mpi->width*mpi->height;
|
|
|
|
mpi->stride[cb]=mpi->width/2;
|
|
|
|
mpi->planes[cr]=data+5*mpi->width*mpi->height/4;
|
|
|
|
mpi->stride[cr]=mpi->width/2;
|
2002-03-23 14:26:53 +00:00
|
|
|
}
|
2002-06-21 16:37:37 +00:00
|
|
|
else if (mpi->bpp==9 && mpi->flags&MP_IMGFLAG_YUV) {
|
|
|
|
/* YVU9 ! */
|
|
|
|
mpi->stride[1]=mpi->stride[2]=mpi->width/4;
|
|
|
|
mpi->planes[2]=mpi->planes[0]+mpi->width*mpi->height;
|
|
|
|
mpi->planes[1]=mpi->planes[2]+(mpi->width>>2)*(mpi->height>>2);
|
|
|
|
}
|
2002-03-07 01:39:07 +00:00
|
|
|
} else {
|
|
|
|
mpi->planes[0]=data;
|
|
|
|
mpi->stride[0]=mpi->width*(mpi->bpp/8);
|
2002-05-29 22:38:34 +00:00
|
|
|
// .AVI files has uncompressed lines 4-byte aligned:
|
|
|
|
if(sh->format==0 || sh->format==3) mpi->stride[0]=(mpi->stride[0]+3)&(~3);
|
2002-04-29 16:03:37 +00:00
|
|
|
if(mpi->imgfmt==IMGFMT_RGB8 || mpi->imgfmt==IMGFMT_BGR8){
|
|
|
|
// export palette:
|
|
|
|
mpi->planes[1]=((unsigned char*)&sh->bih)+40;
|
|
|
|
}
|
2002-03-07 01:39:07 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return mpi;
|
|
|
|
}
|
|
|
|
|