--- xvid.h 2003/03/15 14:32:56 1.27.2.6 +++ xvid.h 2003/03/16 12:04:14 1.27.2.9 @@ -19,7 +19,7 @@ * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * - * $Id: xvid.h,v 1.27.2.6 2003/03/15 14:32:56 suxen_drol Exp $ + * $Id: xvid.h,v 1.27.2.9 2003/03/16 12:04:14 suxen_drol Exp $ * ****************************************************************************/ @@ -239,7 +239,7 @@ int time_increment; /* [out] time increment */ /* XXX: external deblocking stuff */ - unsigned char * qscale; /* [out] pointer to quantizer table */ + int * qscale; /* [out] pointer to quantizer table */ int qscale_stride; /* [out] quantizer scale stride */ } vop; @@ -272,6 +272,8 @@ /* xvid_plg_info_t.flags */ #define XVID_REQORIGINAL 1 /* plugin requires a copy of the original (uncompressed) image */ +#define XVID_REQPSNR 2 /* plugin requires psnr between the uncompressed and compressed image*/ +#define XVID_REQDQUANTS 3 /* plugin requires access to the dquant table */ typedef struct @@ -285,8 +287,12 @@ { int version; - int width, height; - int fincr, fbase; + int width; + int height; + int mb_width; + int mb_height; + int fincr; + int fbase; void * param; } xvid_plg_create_t; @@ -298,6 +304,8 @@ int width; /* [out] */ int height; /* [out] */ + int mb_width; /* [out] */ + int mb_height; /* [out] */ int fincr; /* [out] */ int fbase; /* [out] */ @@ -309,8 +317,8 @@ int type; /* [in,out] */ int quant; /* [in,out] */ - unsigned char * qscale; /* [in,out] pointer to quantizer table */ - int qscale_stride; /* [in,out] quantizer scale stride */ + int * dquant; /* [in,out] pointer to diff quantizer table */ + int dquant_stride; /* [in,out] diff quantizer stride */ int vop_flags; /* [in,out] */ int vol_flags; /* [in,out] */ @@ -318,6 +326,7 @@ int length; /* [out] after: length of encoded frame */ int kblks, mblks, ublks; /* [out] after: */ + int sse_y, sse_u, sse_v; /* [out] */ } xvid_plg_data_t; @@ -349,9 +358,9 @@ void * param; } xvid_enc_plugin_t; -xvid_plugin_func xvid_plugin_psnr; /* stdout psnr calculator */ +xvid_plugin_func xvid_plugin_psnr; /* write psnr values to stdout */ xvid_plugin_func xvid_plugin_dump; /* dump before and after yuvpgms */ - +xvid_plugin_func xvid_plugin_lumimasking; /* lumimasking */ /***************************************************************************** @@ -372,6 +381,7 @@ { XVID_PACKED = 0x00000001, /* packed bitstream */ XVID_CLOSED_GOP = 0x00000002, /* closed_gop: was DX50BVOP dx50 bvop compatibility */ + XVID_EXTRASTATS_ENABLE = 0x00000004 /*define XVID_VOL_AT_IVOP 0x00000008 write vol at every ivop: WIN32/divx compatibility */ /*define XVID_FORCE_VOL 0x00000008 XXX: when vol-based parameters are changed, insert an ivop NOT recommended */ } xvid_global_t; @@ -381,6 +391,7 @@ /* vol-based flags */ typedef enum { XVID_MPEGQUANT = 0x00000001, + XVID_EXTRASTATS = 0x00000002, XVID_QUARTERPEL = 0x00000004, /* enable quarterpel: frames will encoded as quarterpel */ XVID_GMC = 0x00000008, /* enable GMC; frames will be checked for gmc suitability */ XVID_REDUCED_ENABLE = 0x00000010, /* enable reduced resolution vops: frames will be checked for rrv suitability */ @@ -394,7 +405,6 @@ XVID_HALFPEL = 0x00000004, /* use halfpel interpolation */ XVID_INTER4V = 0x00000008, - XVID_LUMIMASKING = 0x00000010, XVID_CHROMAOPT = 0x00000020, /* enable chroma optimization pre-filter */ XVID_GREYSCALE = 0x00000040, /* enable greyscale only mode (even for @@ -530,6 +540,7 @@ int par_height; /* [in:opt] aspect ratio height */ /* ^^^----------------------------------------------------------------------------------*/ + int fincr; /* framerate increment, for variable framerate only */ xvid_vop_t vop_flags; /* [in] (general)vop-based flags */ xvid_motion_t motion; /* [in] ME options */ @@ -537,7 +548,6 @@ int type; /* [in:opt] coding type */ int quant; /* [in] frame quantizer; if <=0, automatatic (ratecontrol) */ - int bquant; /* [in:opt] bframe quantizer; if <=0, automatic*/ void *bitstream; /* [in:opt] bitstream ptr (written to)*/ int length; /* [in:opt] bitstream length (bytes) */