23 |
* |
* |
24 |
* History: |
* History: |
25 |
* |
* |
26 |
|
* 12.07.2002 num_threads |
27 |
|
* 23.06.2002 XVID_CPU_CHKONLY; loading speed up |
28 |
|
* 25.04.2002 ICDECOMPRESS_PREROLL |
29 |
|
* 17.04.2002 re-enabled lumi masking for 1st pass |
30 |
|
* 15.04.2002 updated cbr support |
31 |
* 04.04.2002 separated 2-pass code to 2pass.c |
* 04.04.2002 separated 2-pass code to 2pass.c |
32 |
* interlacing support |
* interlacing support |
33 |
* hinted ME support |
* hinted ME support |
43 |
* motion search precision = 0 now effective in 2-pass |
* motion search precision = 0 now effective in 2-pass |
44 |
* modulated quantization |
* modulated quantization |
45 |
* added DX50 fourcc |
* added DX50 fourcc |
46 |
* 01.12.2001 inital version; (c)2001 peter ross <suxen_drol@hotmail.com> |
* 01.12.2001 inital version; (c)2001 peter ross <pross@xvid.org> |
47 |
* |
* |
48 |
*************************************************************************/ |
*************************************************************************/ |
49 |
|
|
54 |
#include "2pass.h" |
#include "2pass.h" |
55 |
|
|
56 |
int pmvfast_presets[7] = { |
int pmvfast_presets[7] = { |
57 |
0, PMV_QUICKSTOP16, PMV_EARLYSTOP16, PMV_EARLYSTOP16 | PMV_EARLYSTOP8, |
0, PMV_QUICKSTOP16, 0, 0, |
58 |
PMV_EARLYSTOP16 | PMV_HALFPELREFINE16 | PMV_EARLYSTOP8 | PMV_HALFPELDIAMOND8, |
0 | PMV_HALFPELREFINE16 | PMV_HALFPELDIAMOND8, |
59 |
PMV_EARLYSTOP16 | PMV_HALFPELREFINE16 | PMV_EARLYSTOP8 | PMV_HALFPELDIAMOND8, |
0 | PMV_HALFPELREFINE16 | PMV_HALFPELDIAMOND8 | |
60 |
PMV_EARLYSTOP16 | PMV_HALFPELREFINE16 | PMV_EXTSEARCH16 | |
PMV_ADVANCEDDIAMOND16, PMV_HALFPELREFINE16 | PMV_EXTSEARCH16 | |
61 |
PMV_EARLYSTOP8 | PMV_HALFPELREFINE8 | PMV_HALFPELDIAMOND8 |
PMV_HALFPELREFINE8 | PMV_HALFPELDIAMOND8 | PMV_USESQUARES16 |
62 |
}; |
}; |
63 |
|
|
64 |
/* return xvid compatbile colorspace, |
/* return xvid compatbile colorspace, |
67 |
|
|
68 |
int get_colorspace(BITMAPINFOHEADER * hdr) |
int get_colorspace(BITMAPINFOHEADER * hdr) |
69 |
{ |
{ |
70 |
if (hdr->biHeight < 0) |
/* rgb only: negative height specifies top down image */ |
71 |
{ |
int rgb_flip = (hdr->biHeight < 0 ? 0 : XVID_CSP_VFLIP); |
|
DEBUGERR("colorspace: inverted input format not supported"); |
|
|
return XVID_CSP_NULL; |
|
|
} |
|
72 |
|
|
73 |
switch(hdr->biCompression) |
switch(hdr->biCompression) |
74 |
{ |
{ |
76 |
if (hdr->biBitCount == 16) |
if (hdr->biBitCount == 16) |
77 |
{ |
{ |
78 |
DEBUG("RGB16 (RGB555)"); |
DEBUG("RGB16 (RGB555)"); |
79 |
return XVID_CSP_VFLIP | XVID_CSP_RGB555; |
return rgb_flip | XVID_CSP_RGB555; |
80 |
} |
} |
81 |
if (hdr->biBitCount == 24) |
if (hdr->biBitCount == 24) |
82 |
{ |
{ |
83 |
DEBUG("RGB24"); |
DEBUG("RGB24"); |
84 |
return XVID_CSP_VFLIP | XVID_CSP_RGB24; |
return rgb_flip | XVID_CSP_RGB24; |
85 |
} |
} |
86 |
if (hdr->biBitCount == 32) |
if (hdr->biBitCount == 32) |
87 |
{ |
{ |
88 |
DEBUG("RGB32"); |
DEBUG("RGB32"); |
89 |
return XVID_CSP_VFLIP | XVID_CSP_RGB32; |
return rgb_flip | XVID_CSP_RGB32; |
90 |
} |
} |
91 |
|
|
92 |
DEBUG1("BI_RGB unsupported", hdr->biBitCount); |
DEBUG1("unsupported BI_RGB biBitCount", hdr->biBitCount); |
93 |
return XVID_CSP_NULL; |
return XVID_CSP_NULL; |
94 |
|
|
95 |
// how do these work in BITMAPINFOHEADER ??? |
case BI_BITFIELDS : |
96 |
/* case BI_BITFIELDS : |
if (hdr->biSize >= sizeof(BITMAPV4HEADER)) |
97 |
if (hdr->biBitCount == 16 |
{ |
98 |
if(hdr->biBitCount == 16 && |
BITMAPV4HEADER * hdr4 = (BITMAPV4HEADER *)hdr; |
99 |
hdr->bV4RedMask == 0x7c00 && |
|
100 |
hdr->bV4GreenMask == 0x3e0 && |
if (hdr4->bV4BitCount == 16 && |
101 |
hdr->bV4BlueMask == 0x1f) |
hdr4->bV4RedMask == 0x7c00 && |
102 |
|
hdr4->bV4GreenMask == 0x3e0 && |
103 |
|
hdr4->bV4BlueMask == 0x1f) |
104 |
{ |
{ |
105 |
DEBUG("RGB555"); |
DEBUG("RGB555"); |
106 |
return XVID_CSP_VFLIP | XVID_CSP_RGB555; |
return rgb_flip | XVID_CSP_RGB555; |
107 |
} |
} |
108 |
if(hdr->bV4BitCount == 16 && |
|
109 |
hdr->bV4RedMask == 0xf800 && |
if(hdr4->bV4BitCount == 16 && |
110 |
hdr->bV4GreenMask == 0x7e0 && |
hdr4->bV4RedMask == 0xf800 && |
111 |
hdr->bV4BlueMask == 0x1f) |
hdr4->bV4GreenMask == 0x7e0 && |
112 |
|
hdr4->bV4BlueMask == 0x1f) |
113 |
{ |
{ |
114 |
DEBUG("RGB565"); |
DEBUG("RGB565"); |
115 |
return XVID_CSP_VFLIP | XVID_CSP_RGB565; |
return rgb_flip | XVID_CSP_RGB565; |
116 |
} |
} |
117 |
|
|
118 |
DEBUG1("BI_FIELDS unsupported", hdr->bV4BitCount); |
DEBUG("unsupported BI_BITFIELDS mode"); |
119 |
return XVID_CSP_NULL; |
return XVID_CSP_NULL; |
120 |
*/ |
} |
121 |
|
|
122 |
|
DEBUG("unsupported BI_BITFIELDS/BITMAPHEADER combination"); |
123 |
|
return XVID_CSP_NULL; |
124 |
|
|
125 |
case FOURCC_I420: |
case FOURCC_I420: |
126 |
case FOURCC_IYUV: |
case FOURCC_IYUV: |
127 |
DEBUG("IYUY"); |
DEBUG("IYUY"); |
133 |
|
|
134 |
case FOURCC_YUYV : |
case FOURCC_YUYV : |
135 |
case FOURCC_YUY2 : |
case FOURCC_YUY2 : |
|
case FOURCC_V422 : |
|
136 |
DEBUG("YUY2"); |
DEBUG("YUY2"); |
137 |
return XVID_CSP_YUY2; |
return XVID_CSP_YUY2; |
138 |
|
|
144 |
DEBUG("UYVY"); |
DEBUG("UYVY"); |
145 |
return XVID_CSP_UYVY; |
return XVID_CSP_UYVY; |
146 |
|
|
147 |
} |
default : |
148 |
DEBUGFOURCC("colorspace: unknown", hdr->biCompression); |
DEBUGFOURCC("unsupported colorspace", hdr->biCompression); |
149 |
return XVID_CSP_NULL; |
return XVID_CSP_NULL; |
150 |
} |
} |
151 |
|
} |
152 |
|
|
153 |
|
|
154 |
/* compressor */ |
/* compressor */ |
172 |
} |
} |
173 |
|
|
174 |
if (inhdr->biWidth != outhdr->biWidth || inhdr->biHeight != outhdr->biHeight || |
if (inhdr->biWidth != outhdr->biWidth || inhdr->biHeight != outhdr->biHeight || |
175 |
(outhdr->biCompression != FOURCC_XVID && outhdr->biCompression != FOURCC_DIVX)) |
(outhdr->biCompression != FOURCC_XVID && outhdr->biCompression != FOURCC_DIVX && outhdr->biCompression != FOURCC_DX50)) |
176 |
{ |
{ |
177 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
178 |
} |
} |
198 |
|
|
199 |
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
200 |
outhdr->biSize = sizeof(BITMAPINFOHEADER); |
outhdr->biSize = sizeof(BITMAPINFOHEADER); |
|
outhdr->biBitCount = 24; // or 16 |
|
201 |
outhdr->biSizeImage = compress_get_size(codec, lpbiInput, lpbiOutput); |
outhdr->biSizeImage = compress_get_size(codec, lpbiInput, lpbiOutput); |
202 |
outhdr->biXPelsPerMeter = 0; |
outhdr->biXPelsPerMeter = 0; |
203 |
outhdr->biYPelsPerMeter = 0; |
outhdr->biYPelsPerMeter = 0; |
223 |
|
|
224 |
LRESULT compress_get_size(CODEC * codec, BITMAPINFO * lpbiInput, BITMAPINFO * lpbiOutput) |
LRESULT compress_get_size(CODEC * codec, BITMAPINFO * lpbiInput, BITMAPINFO * lpbiOutput) |
225 |
{ |
{ |
226 |
return lpbiOutput->bmiHeader.biWidth * lpbiOutput->bmiHeader.biHeight * 3; |
return 2 * lpbiOutput->bmiHeader.biWidth * lpbiOutput->bmiHeader.biHeight * 3; |
227 |
} |
} |
228 |
|
|
229 |
|
|
244 |
switch (codec->config.mode) |
switch (codec->config.mode) |
245 |
{ |
{ |
246 |
case DLG_MODE_CBR : |
case DLG_MODE_CBR : |
247 |
param.bitrate = codec->config.bitrate; |
param.rc_bitrate = codec->config.rc_bitrate; |
248 |
param.rc_buffersize = codec->config.rc_buffersize; |
param.rc_reaction_delay_factor = codec->config.rc_reaction_delay_factor; |
249 |
|
param.rc_averaging_period = codec->config.rc_averaging_period; |
250 |
|
param.rc_buffer = codec->config.rc_buffer; |
251 |
break; |
break; |
252 |
|
|
253 |
case DLG_MODE_VBR_QUAL : |
case DLG_MODE_VBR_QUAL : |
254 |
codec->config.fquant = 0; |
codec->config.fquant = 0; |
255 |
param.bitrate = 0; |
param.rc_bitrate = 0; |
256 |
break; |
break; |
257 |
|
|
258 |
case DLG_MODE_VBR_QUANT : |
case DLG_MODE_VBR_QUANT : |
259 |
codec->config.fquant = (float) codec->config.quant; |
codec->config.fquant = (float) codec->config.quant; |
260 |
param.bitrate = 0; |
param.rc_bitrate = 0; |
261 |
break; |
break; |
262 |
|
|
263 |
case DLG_MODE_2PASS_1 : |
case DLG_MODE_2PASS_1 : |
264 |
case DLG_MODE_2PASS_2_INT : |
case DLG_MODE_2PASS_2_INT : |
265 |
case DLG_MODE_2PASS_2_EXT : |
case DLG_MODE_2PASS_2_EXT : |
266 |
param.bitrate = 0; |
param.rc_bitrate = 0; |
267 |
|
codec->twopass.max_framesize = (int)((double)codec->config.twopass_max_bitrate / 8.0 / ((double)codec->fbase / (double)codec->fincr)); |
268 |
break; |
break; |
269 |
|
|
270 |
case DLG_MODE_NULL : |
case DLG_MODE_NULL : |
290 |
param.fincr = codec->fincr; |
param.fincr = codec->fincr; |
291 |
param.fbase = codec->fbase; |
param.fbase = codec->fbase; |
292 |
|
|
|
param.rc_buffersize = codec->config.rc_buffersize; |
|
|
|
|
293 |
param.min_quantizer = codec->config.min_pquant; |
param.min_quantizer = codec->config.min_pquant; |
294 |
param.max_quantizer = codec->config.max_pquant; |
param.max_quantizer = codec->config.max_pquant; |
295 |
param.max_key_interval = codec->config.max_key_interval; |
param.max_key_interval = codec->config.max_key_interval; |
296 |
|
|
297 |
|
#ifdef _SMP |
298 |
|
param.num_threads = codec->config.num_threads; |
299 |
|
#endif |
300 |
|
|
301 |
|
param.global = 0; |
302 |
|
if (codec->config.packed) param.global |= XVID_GLOBAL_PACKED; |
303 |
|
if (codec->config.dx50bvop) param.global |= XVID_GLOBAL_DX50BVOP; |
304 |
|
if (codec->config.debug) param.global |= XVID_GLOBAL_DEBUG; |
305 |
|
if (codec->config.reduced_resolution) param.global |= XVID_GLOBAL_REDUCED; |
306 |
|
param.max_bframes = codec->config.max_bframes; |
307 |
|
param.bquant_ratio = codec->config.bquant_ratio; |
308 |
|
param.bquant_offset = codec->config.bquant_offset; |
309 |
|
param.frame_drop_ratio = codec->config.frame_drop_ratio; |
310 |
|
|
311 |
switch(xvid_encore(0, XVID_ENC_CREATE, ¶m, NULL)) |
switch(xvid_encore(0, XVID_ENC_CREATE, ¶m, NULL)) |
312 |
{ |
{ |
313 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
355 |
} |
} |
356 |
|
|
357 |
codec->ehandle = NULL; |
codec->ehandle = NULL; |
358 |
|
|
359 |
|
codec_2pass_finish(codec); |
360 |
} |
} |
361 |
|
|
362 |
return ICERR_OK; |
return ICERR_OK; |
384 |
frame.intra = -1; |
frame.intra = -1; |
385 |
|
|
386 |
frame.general |= XVID_HALFPEL; |
frame.general |= XVID_HALFPEL; |
387 |
|
// frame.general |= XVID_ME_EPZS; |
388 |
|
|
389 |
|
frame.general |= XVID_HQACPRED; |
390 |
|
|
391 |
if(codec->config.motion_search > 4) |
if(codec->config.motion_search > 4) |
392 |
frame.general |= XVID_INTER4V; |
frame.general |= XVID_INTER4V; |
393 |
|
|
394 |
if(((codec->config.mode == DLG_MODE_2PASS_1) ? 0 : codec->config.lum_masking) == 1) |
if (codec->config.lum_masking) |
395 |
frame.general |= XVID_LUMIMASKING; |
frame.general |= XVID_LUMIMASKING; |
396 |
|
|
397 |
if (codec->config.interlacing) |
if (codec->config.interlacing) |
398 |
frame.general |= XVID_INTERLACING; |
frame.general |= XVID_INTERLACING; |
399 |
|
|
400 |
|
if (codec->config.qpel) { |
401 |
|
frame.general |= XVID_QUARTERPEL; |
402 |
|
frame.motion |= PMV_QUARTERPELREFINE16 | PMV_QUARTERPELREFINE8; |
403 |
|
} |
404 |
|
|
405 |
|
if (codec->config.gmc) |
406 |
|
frame.general |= XVID_GMC; |
407 |
|
|
408 |
|
if (codec->config.chromame) |
409 |
|
frame.motion |= PMV_CHROMA16 + PMV_CHROMA8; |
410 |
|
|
411 |
|
if (codec->config.reduced_resolution) |
412 |
|
frame.general |= XVID_REDUCED; |
413 |
|
|
414 |
|
if (codec->config.chroma_opt) |
415 |
|
frame.general |= XVID_CHROMAOPT; |
416 |
|
// added by koepi for credits greyscale |
417 |
|
|
418 |
|
check_greyscale_mode(&codec->config, &frame, codec->framenum); |
419 |
|
|
420 |
|
// end of koepi's addition |
421 |
|
|
422 |
|
|
423 |
|
// fix 1pass modes/hinted MV by koepi |
424 |
|
if (codec->config.hinted_me && (codec->config.mode == DLG_MODE_CBR || codec->config.mode == DLG_MODE_VBR_QUAL || codec->config.mode == DLG_MODE_VBR_QUANT)) |
425 |
|
{ |
426 |
|
codec->config.hinted_me = 0; |
427 |
|
} |
428 |
|
// end of ugly hack |
429 |
|
|
430 |
if (codec->config.hinted_me && codec->config.mode == DLG_MODE_2PASS_1) |
if (codec->config.hinted_me && codec->config.mode == DLG_MODE_2PASS_1) |
431 |
{ |
{ |
432 |
frame.hint.hintstream = codec->twopass.hintstream; |
frame.hint.hintstream = codec->twopass.hintstream; |
433 |
frame.hint.rawhints = 0; |
frame.hint.rawhints = 0; |
434 |
frame.general |= XVID_HINTEDME_GET; |
frame.general |= XVID_HINTEDME_GET; |
435 |
} |
} |
436 |
else if (codec->config.mode == DLG_MODE_2PASS_2_EXT || codec->config.mode == DLG_MODE_2PASS_2_INT) |
else if (codec->config.hinted_me && (codec->config.mode == DLG_MODE_2PASS_2_EXT || codec->config.mode == DLG_MODE_2PASS_2_INT)) |
437 |
{ |
{ |
438 |
DWORD read; |
DWORD read; |
439 |
DWORD blocksize; |
DWORD blocksize; |
459 |
} |
} |
460 |
} |
} |
461 |
|
|
462 |
frame.motion = pmvfast_presets[codec->config.motion_search]; |
frame.motion |= pmvfast_presets[codec->config.motion_search]; |
463 |
|
|
464 |
|
switch (codec->config.vhq_mode) |
465 |
|
{ |
466 |
|
case VHQ_MODE_DECISION : |
467 |
|
frame.general |= XVID_MODEDECISION_BITS; |
468 |
|
break; |
469 |
|
|
470 |
|
case VHQ_LIMITED_SEARCH : |
471 |
|
frame.general |= XVID_MODEDECISION_BITS; |
472 |
|
frame.motion |= HALFPELREFINE16_BITS; |
473 |
|
frame.motion |= QUARTERPELREFINE16_BITS; |
474 |
|
break; |
475 |
|
|
476 |
|
case VHQ_MEDIUM_SEARCH : |
477 |
|
frame.general |= XVID_MODEDECISION_BITS; |
478 |
|
frame.motion |= HALFPELREFINE16_BITS; |
479 |
|
frame.motion |= HALFPELREFINE8_BITS; |
480 |
|
frame.motion |= QUARTERPELREFINE16_BITS; |
481 |
|
frame.motion |= QUARTERPELREFINE8_BITS; |
482 |
|
frame.motion |= CHECKPREDICTION_BITS; |
483 |
|
break; |
484 |
|
|
485 |
|
case VHQ_WIDE_SEARCH : |
486 |
|
frame.general |= XVID_MODEDECISION_BITS; |
487 |
|
frame.motion |= HALFPELREFINE16_BITS; |
488 |
|
frame.motion |= HALFPELREFINE8_BITS; |
489 |
|
frame.motion |= QUARTERPELREFINE16_BITS; |
490 |
|
frame.motion |= QUARTERPELREFINE8_BITS; |
491 |
|
frame.motion |= CHECKPREDICTION_BITS; |
492 |
|
frame.motion |= EXTSEARCH_BITS; |
493 |
|
break; |
494 |
|
|
495 |
|
default : |
496 |
|
break; |
497 |
|
} |
498 |
|
|
499 |
frame.image = icc->lpInput; |
frame.image = icc->lpInput; |
500 |
|
frame.stride = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
501 |
|
|
502 |
if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL) |
if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL) |
503 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
504 |
|
|
505 |
|
if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12) |
506 |
|
frame.stride = (frame.stride*2)/3; |
507 |
|
|
508 |
frame.bitstream = icc->lpOutput; |
frame.bitstream = icc->lpOutput; |
509 |
frame.length = icc->lpbiOutput->biSizeImage; |
frame.length = icc->lpbiOutput->biSizeImage; |
510 |
|
|
575 |
{ |
{ |
576 |
frame.intra = 1; |
frame.intra = 1; |
577 |
} |
} |
578 |
else if ((codec->keyspacing < codec->config.min_key_interval && codec->framenum) && |
else if (codec->keyspacing < codec->config.min_key_interval && codec->framenum) |
|
(codec->config.mode == DLG_MODE_2PASS_1)) |
|
579 |
{ |
{ |
580 |
DEBUG("current frame forced to p-frame"); |
DEBUG("current frame forced to p-frame"); |
581 |
frame.intra = 0; |
frame.intra = 0; |
582 |
} |
} |
583 |
|
|
584 |
|
frame.bquant = 0; |
585 |
|
|
586 |
|
// OutputDebugString(" "); |
587 |
switch (xvid_encore(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats)) |
switch (xvid_encore(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats)) |
588 |
{ |
{ |
589 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
596 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
597 |
} |
} |
598 |
|
|
599 |
if (frame.intra) |
if (frame.intra==1) |
600 |
{ |
{ |
601 |
codec->keyspacing = 0; |
codec->keyspacing = 0; |
602 |
*icc->lpdwFlags = AVIIF_KEYFRAME; |
*icc->lpdwFlags = AVIIF_KEYFRAME; |
635 |
} |
} |
636 |
} |
} |
637 |
|
|
638 |
|
//quick fix for delayed frames |
639 |
|
// if (frame.intra != 5) |
640 |
codec_2pass_update(codec, &frame, &stats); |
codec_2pass_update(codec, &frame, &stats); |
641 |
|
|
642 |
++codec->framenum; |
++codec->framenum; |
659 |
return ICERR_ERROR; |
return ICERR_ERROR; |
660 |
} |
} |
661 |
|
|
662 |
if (inhdr->biCompression != FOURCC_XVID && inhdr->biCompression != FOURCC_DIVX) |
if (inhdr->biCompression != FOURCC_XVID && inhdr->biCompression != FOURCC_DIVX && inhdr->biCompression != FOURCC_DX50 && get_colorspace(inhdr) == XVID_CSP_NULL) |
663 |
{ |
{ |
664 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
665 |
} |
} |
691 |
return sizeof(BITMAPINFOHEADER); |
return sizeof(BITMAPINFOHEADER); |
692 |
} |
} |
693 |
|
|
694 |
result = decompress_query(codec, lpbiInput, lpbiOutput); |
/* --- yv12 --- */ |
695 |
|
|
696 |
|
if (get_colorspace(inhdr) != XVID_CSP_NULL) { |
697 |
|
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
698 |
|
// XXX: should we set outhdr->biSize ?? |
699 |
|
return ICERR_OK; |
700 |
|
} |
701 |
|
/* --- yv12 --- */ |
702 |
|
|
703 |
|
result = decompress_query(codec, lpbiInput, NULL); |
704 |
if (result != ICERR_OK) |
if (result != ICERR_OK) |
705 |
{ |
{ |
706 |
return result; |
return result; |
707 |
} |
} |
708 |
|
|
|
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
|
709 |
outhdr->biSize = sizeof(BITMAPINFOHEADER); |
outhdr->biSize = sizeof(BITMAPINFOHEADER); |
710 |
outhdr->biCompression = FOURCC_YUY2; |
outhdr->biWidth = inhdr->biWidth; |
711 |
|
outhdr->biHeight = inhdr->biHeight; |
712 |
|
outhdr->biPlanes = 1; |
713 |
|
outhdr->biBitCount = 24; |
714 |
|
outhdr->biCompression = BI_RGB; /* sonic foundry vegas video v3 only supports BI_RGB */ |
715 |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount; |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount; |
716 |
outhdr->biXPelsPerMeter = 0; |
outhdr->biXPelsPerMeter = 0; |
717 |
outhdr->biYPelsPerMeter = 0; |
outhdr->biYPelsPerMeter = 0; |
772 |
|
|
773 |
frame.bitstream = icd->lpInput; |
frame.bitstream = icd->lpInput; |
774 |
frame.length = icd->lpbiInput->biSizeImage; |
frame.length = icd->lpbiInput->biSizeImage; |
775 |
|
frame.general = XVID_DEC_LOWDELAY; /* force low_delay_default mode */ |
776 |
|
if (codec->config.deblock_y) |
777 |
|
frame.general |= XVID_DEC_DEBLOCKY; |
778 |
|
if (codec->config.deblock_uv) |
779 |
|
frame.general |= XVID_DEC_DEBLOCKUV; |
780 |
|
|
781 |
frame.image = icd->lpOutput; |
frame.image = icd->lpOutput; |
782 |
frame.stride = icd->lpbiOutput->biWidth; |
frame.stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
783 |
|
|
784 |
if (~((icd->dwFlags & ICDECOMPRESS_HURRYUP) | (icd->dwFlags & ICDECOMPRESS_UPDATE))) |
/* --- yv12 --- */ |
785 |
|
if (icd->lpbiInput->biCompression != FOURCC_XVID && |
786 |
|
icd->lpbiInput->biCompression != FOURCC_DIVX && |
787 |
|
icd->lpbiInput->biCompression != FOURCC_DX50) |
788 |
|
{ |
789 |
|
XVID_INIT_CONVERTINFO convert; |
790 |
|
DEBUGFOURCC("input", icd->lpbiInput->biCompression); |
791 |
|
DEBUGFOURCC("output", icd->lpbiOutput->biCompression); |
792 |
|
convert.input.colorspace = get_colorspace(icd->lpbiInput); |
793 |
|
convert.input.y = icd->lpInput; |
794 |
|
convert.input.y_stride = (((icd->lpbiInput->biWidth *icd->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
795 |
|
if (convert.input.colorspace == XVID_CSP_I420 || convert.input.colorspace == XVID_CSP_YV12) |
796 |
|
convert.input.y_stride = (convert.input.y_stride*2)/3; |
797 |
|
|
798 |
|
convert.output.colorspace = get_colorspace(icd->lpbiOutput); |
799 |
|
convert.output.y = icd->lpOutput; |
800 |
|
convert.output.y_stride = (((icd->lpbiOutput->biWidth *icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
801 |
|
if (convert.output.colorspace == XVID_CSP_I420 || convert.output.colorspace == XVID_CSP_YV12) |
802 |
|
convert.output.y_stride = (convert.output.y_stride*2)/3; |
803 |
|
|
804 |
|
convert.width = icd->lpbiInput->biWidth; |
805 |
|
convert.height = icd->lpbiInput->biHeight; |
806 |
|
convert.interlacing = 0; |
807 |
|
if (convert.input.colorspace == XVID_CSP_NULL || |
808 |
|
convert.output.colorspace == XVID_CSP_NULL || |
809 |
|
xvid_init(NULL, XVID_INIT_CONVERT, &convert, NULL) != XVID_ERR_OK) |
810 |
|
{ |
811 |
|
return ICERR_BADFORMAT; |
812 |
|
} |
813 |
|
return ICERR_OK; |
814 |
|
} |
815 |
|
/* --- yv12 --- */ |
816 |
|
|
817 |
|
|
818 |
|
if (~((icd->dwFlags & ICDECOMPRESS_HURRYUP) | (icd->dwFlags & ICDECOMPRESS_UPDATE) | (icd->dwFlags & ICDECOMPRESS_PREROLL))) |
819 |
{ |
{ |
820 |
if ((frame.colorspace = get_colorspace(icd->lpbiOutput)) == XVID_CSP_NULL) |
if ((frame.colorspace = get_colorspace(icd->lpbiOutput)) == XVID_CSP_NULL) |
821 |
{ |
{ |
827 |
frame.colorspace = XVID_CSP_NULL; |
frame.colorspace = XVID_CSP_NULL; |
828 |
} |
} |
829 |
|
|
830 |
|
if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12) |
831 |
|
frame.stride = (frame.stride*2)/3; |
832 |
|
|
833 |
switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
834 |
{ |
{ |
835 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
852 |
case DLG_MODE_VBR_QUAL : |
case DLG_MODE_VBR_QUAL : |
853 |
if (codec_is_in_credits(&codec->config, codec->framenum)) |
if (codec_is_in_credits(&codec->config, codec->framenum)) |
854 |
{ |
{ |
855 |
|
// added by koepi for credits greyscale |
856 |
|
|
857 |
|
check_greyscale_mode(&codec->config, frame, codec->framenum); |
858 |
|
|
859 |
|
// end of koepi's addition |
860 |
|
|
861 |
switch (codec->config.credits_mode) |
switch (codec->config.credits_mode) |
862 |
{ |
{ |
863 |
case CREDITS_MODE_RATE : |
case CREDITS_MODE_RATE : |
875 |
} |
} |
876 |
else |
else |
877 |
{ |
{ |
878 |
|
// added by koepi for credits greyscale |
879 |
|
|
880 |
|
check_greyscale_mode(&codec->config, frame, codec->framenum); |
881 |
|
|
882 |
|
// end of koepi's addition |
883 |
|
|
884 |
frame->quant = codec_get_vbr_quant(&codec->config, codec->config.quality); |
frame->quant = codec_get_vbr_quant(&codec->config, codec->config.quality); |
885 |
} |
} |
886 |
return ICERR_OK; |
return ICERR_OK; |
888 |
case DLG_MODE_VBR_QUANT : |
case DLG_MODE_VBR_QUANT : |
889 |
if (codec_is_in_credits(&codec->config, codec->framenum)) |
if (codec_is_in_credits(&codec->config, codec->framenum)) |
890 |
{ |
{ |
891 |
|
// added by koepi for credits greyscale |
892 |
|
|
893 |
|
check_greyscale_mode(&codec->config, frame, codec->framenum); |
894 |
|
|
895 |
|
// end of koepi's addition |
896 |
|
|
897 |
switch (codec->config.credits_mode) |
switch (codec->config.credits_mode) |
898 |
{ |
{ |
899 |
case CREDITS_MODE_RATE : |
case CREDITS_MODE_RATE : |
913 |
} |
} |
914 |
else |
else |
915 |
{ |
{ |
916 |
|
// added by koepi for credits greyscale |
917 |
|
|
918 |
|
check_greyscale_mode(&codec->config, frame, codec->framenum); |
919 |
|
|
920 |
|
// end of koepi's addition |
921 |
|
|
922 |
frame->quant = codec->config.quant; |
frame->quant = codec->config.quant; |
923 |
} |
} |
924 |
return ICERR_OK; |
return ICERR_OK; |
925 |
|
|
926 |
case DLG_MODE_2PASS_1 : |
case DLG_MODE_2PASS_1 : |
927 |
|
// added by koepi for credits greyscale |
928 |
|
|
929 |
|
check_greyscale_mode(&codec->config, frame, codec->framenum); |
930 |
|
|
931 |
|
// end of koepi's addition |
932 |
|
|
933 |
if (codec->config.credits_mode == CREDITS_MODE_QUANT) |
if (codec->config.credits_mode == CREDITS_MODE_QUANT) |
934 |
{ |
{ |
935 |
if (codec_is_in_credits(&codec->config, codec->framenum)) |
if (codec_is_in_credits(&codec->config, codec->framenum)) |
1020 |
return quant; |
return quant; |
1021 |
} |
} |
1022 |
|
|
1023 |
|
// added by koepi for credits greyscale |
1024 |
|
|
1025 |
|
int check_greyscale_mode(CONFIG* config, XVID_ENC_FRAME* frame, int framenum) |
1026 |
|
|
1027 |
|
{ |
1028 |
|
|
1029 |
|
if ((codec_is_in_credits(config, framenum)) && (config->mode!=DLG_MODE_CBR)) |
1030 |
|
|
1031 |
|
{ |
1032 |
|
|
1033 |
|
if (config->credits_greyscale) |
1034 |
|
|
1035 |
|
{ |
1036 |
|
|
1037 |
|
if ((frame->general && XVID_GREYSCALE)) // use only if not already in greyscale |
1038 |
|
|
1039 |
|
frame->general |= XVID_GREYSCALE; |
1040 |
|
|
1041 |
|
} else { |
1042 |
|
|
1043 |
|
if (!(frame->general && XVID_GREYSCALE)) // if movie is in greyscale, switch back |
1044 |
|
|
1045 |
|
frame->general |= XVID_GREYSCALE; |
1046 |
|
|
1047 |
|
} |
1048 |
|
|
1049 |
|
} else { |
1050 |
|
|
1051 |
|
if (config->greyscale) |
1052 |
|
|
1053 |
|
{ |
1054 |
|
|
1055 |
|
if ((frame->general && XVID_GREYSCALE)) // use only if not already in greyscale |
1056 |
|
|
1057 |
|
frame->general |= XVID_GREYSCALE; |
1058 |
|
|
1059 |
|
} else { |
1060 |
|
|
1061 |
|
if (!(frame->general && XVID_GREYSCALE)) // if credits is in greyscale, switch back |
1062 |
|
|
1063 |
|
frame->general |= XVID_GREYSCALE; |
1064 |
|
|
1065 |
|
} |
1066 |
|
|
1067 |
|
} |
1068 |
|
|
1069 |
|
return 0; |
1070 |
|
|
1071 |
|
} |
1072 |
|
|
1073 |
|
// end of koepi's addition |
1074 |
|
|