193 |
|
|
194 |
if (lpbiOutput == NULL) |
if (lpbiOutput == NULL) |
195 |
{ |
{ |
196 |
return sizeof(BITMAPV4HEADER); |
return sizeof(BITMAPINFOHEADER); |
197 |
} |
} |
198 |
|
|
199 |
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
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 |
return 2 * lpbiOutput->bmiHeader.biWidth * lpbiOutput->bmiHeader.biHeight * 3; |
|
#ifdef BFRAMES |
|
|
2 * |
|
|
#endif |
|
|
lpbiOutput->bmiHeader.biWidth * lpbiOutput->bmiHeader.biHeight * 3; |
|
227 |
} |
} |
228 |
|
|
229 |
|
|
298 |
param.num_threads = codec->config.num_threads; |
param.num_threads = codec->config.num_threads; |
299 |
#endif |
#endif |
300 |
|
|
|
#ifdef BFRAMES |
|
301 |
param.global = 0; |
param.global = 0; |
302 |
if (codec->config.packed) param.global |= XVID_GLOBAL_PACKED; |
if (codec->config.packed) param.global |= XVID_GLOBAL_PACKED; |
303 |
if (codec->config.dx50bvop) param.global |= XVID_GLOBAL_DX50BVOP; |
if (codec->config.dx50bvop) param.global |= XVID_GLOBAL_DX50BVOP; |
304 |
if (codec->config.debug) param.global |= XVID_GLOBAL_DEBUG; |
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; |
param.max_bframes = codec->config.max_bframes; |
307 |
param.bquant_ratio = codec->config.bquant_ratio; |
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; |
param.frame_drop_ratio = codec->config.frame_drop_ratio; |
|
#endif |
|
310 |
|
|
311 |
switch(xvid_encore(0, XVID_ENC_CREATE, ¶m, NULL)) |
switch(xvid_encore(0, XVID_ENC_CREATE, ¶m, NULL)) |
312 |
{ |
{ |
386 |
frame.general |= XVID_HALFPEL; |
frame.general |= XVID_HALFPEL; |
387 |
// frame.general |= XVID_ME_EPZS; |
// frame.general |= XVID_ME_EPZS; |
388 |
|
|
389 |
|
frame.general |= XVID_HQACPRED; |
390 |
|
|
391 |
|
frame.bframe_threshold = 255; |
392 |
|
|
393 |
if (codec->config.motion_search > 4) |
if (codec->config.motion_search > 4) |
394 |
frame.general |= XVID_INTER4V; |
frame.general |= XVID_INTER4V; |
399 |
if (codec->config.interlacing) |
if (codec->config.interlacing) |
400 |
frame.general |= XVID_INTERLACING; |
frame.general |= XVID_INTERLACING; |
401 |
|
|
402 |
|
if (codec->config.qpel) { |
403 |
|
frame.general |= XVID_QUARTERPEL; |
404 |
|
frame.motion |= PMV_QUARTERPELREFINE16 | PMV_QUARTERPELREFINE8; |
405 |
|
} |
406 |
|
|
407 |
|
if (codec->config.gmc) |
408 |
|
frame.general |= XVID_GMC; |
409 |
|
|
410 |
|
if (codec->config.chromame) |
411 |
|
frame.motion |= PMV_CHROMA16 + PMV_CHROMA8; |
412 |
|
|
413 |
|
if (codec->config.reduced_resolution) |
414 |
|
frame.general |= XVID_REDUCED; |
415 |
|
|
416 |
|
if (codec->config.chroma_opt) |
417 |
|
frame.general |= XVID_CHROMAOPT; |
418 |
// added by koepi for credits greyscale |
// added by koepi for credits greyscale |
419 |
|
|
420 |
check_greyscale_mode(&codec->config, &frame, codec->framenum); |
check_greyscale_mode(&codec->config, &frame, codec->framenum); |
461 |
} |
} |
462 |
} |
} |
463 |
|
|
464 |
frame.motion = pmvfast_presets[codec->config.motion_search]; |
frame.motion |= pmvfast_presets[codec->config.motion_search]; |
465 |
|
|
466 |
|
switch (codec->config.vhq_mode) |
467 |
|
{ |
468 |
|
case VHQ_MODE_DECISION : |
469 |
|
frame.general |= XVID_MODEDECISION_BITS; |
470 |
|
break; |
471 |
|
|
472 |
|
case VHQ_LIMITED_SEARCH : |
473 |
|
frame.general |= XVID_MODEDECISION_BITS; |
474 |
|
frame.motion |= HALFPELREFINE16_BITS; |
475 |
|
frame.motion |= QUARTERPELREFINE16_BITS; |
476 |
|
break; |
477 |
|
|
478 |
|
case VHQ_MEDIUM_SEARCH : |
479 |
|
frame.general |= XVID_MODEDECISION_BITS; |
480 |
|
frame.motion |= HALFPELREFINE16_BITS; |
481 |
|
frame.motion |= HALFPELREFINE8_BITS; |
482 |
|
frame.motion |= QUARTERPELREFINE16_BITS; |
483 |
|
frame.motion |= QUARTERPELREFINE8_BITS; |
484 |
|
frame.motion |= CHECKPREDICTION_BITS; |
485 |
|
break; |
486 |
|
|
487 |
|
case VHQ_WIDE_SEARCH : |
488 |
|
frame.general |= XVID_MODEDECISION_BITS; |
489 |
|
frame.motion |= HALFPELREFINE16_BITS; |
490 |
|
frame.motion |= HALFPELREFINE8_BITS; |
491 |
|
frame.motion |= QUARTERPELREFINE16_BITS; |
492 |
|
frame.motion |= QUARTERPELREFINE8_BITS; |
493 |
|
frame.motion |= CHECKPREDICTION_BITS; |
494 |
|
frame.motion |= EXTSEARCH_BITS; |
495 |
|
break; |
496 |
|
|
497 |
|
default : |
498 |
|
break; |
499 |
|
} |
500 |
|
|
501 |
frame.image = icc->lpInput; |
frame.image = icc->lpInput; |
|
// dev-api-3 |
|
502 |
frame.stride = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
frame.stride = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
503 |
|
|
504 |
if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL) |
if ((frame.colorspace = get_colorspace(inhdr)) == XVID_CSP_NULL) |
505 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
506 |
|
|
507 |
|
if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12) |
508 |
|
frame.stride = (frame.stride*2)/3; |
509 |
|
|
510 |
frame.bitstream = icc->lpOutput; |
frame.bitstream = icc->lpOutput; |
511 |
frame.length = icc->lpbiOutput->biSizeImage; |
frame.length = icc->lpbiOutput->biSizeImage; |
512 |
|
|
583 |
frame.intra = 0; |
frame.intra = 0; |
584 |
} |
} |
585 |
|
|
|
#ifdef BFRAMES |
|
586 |
frame.bquant = 0; |
frame.bquant = 0; |
587 |
#endif |
frame.bframe_threshold = 0; |
588 |
|
|
589 |
// OutputDebugString(" "); |
// OutputDebugString(" "); |
590 |
switch (xvid_encore(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats)) |
switch (xvid_encore(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats)) |
599 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
600 |
} |
} |
601 |
|
|
602 |
if (frame.intra) |
if (frame.intra==1) |
603 |
{ |
{ |
604 |
codec->keyspacing = 0; |
codec->keyspacing = 0; |
605 |
*icc->lpdwFlags = AVIIF_KEYFRAME; |
*icc->lpdwFlags = AVIIF_KEYFRAME; |
608 |
{ |
{ |
609 |
*icc->lpdwFlags = 0; |
*icc->lpdwFlags = 0; |
610 |
} |
} |
611 |
|
if (frame.length == 0) { frame.length = 1; *((unsigned char*)frame.bitstream) = 0x7f; } |
612 |
|
|
613 |
outhdr->biSizeImage = frame.length; |
outhdr->biSizeImage = frame.length; |
614 |
|
|
639 |
} |
} |
640 |
} |
} |
641 |
|
|
642 |
|
//quick fix for delayed frames |
643 |
|
// if (frame.intra != 5) |
644 |
codec_2pass_update(codec, &frame, &stats); |
codec_2pass_update(codec, &frame, &stats); |
645 |
|
|
646 |
++codec->framenum; |
++codec->framenum; |
663 |
return ICERR_ERROR; |
return ICERR_ERROR; |
664 |
} |
} |
665 |
|
|
666 |
if (inhdr->biCompression != FOURCC_XVID && |
if (inhdr->biCompression != FOURCC_XVID && inhdr->biCompression != FOURCC_DIVX && inhdr->biCompression != FOURCC_DX50 && get_colorspace(inhdr) == XVID_CSP_NULL) |
|
inhdr->biCompression != FOURCC_DIVX && |
|
|
inhdr->biCompression != FOURCC_DX50 && |
|
|
get_colorspace(inhdr) == XVID_CSP_NULL) |
|
667 |
{ |
{ |
668 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
669 |
} |
} |
696 |
} |
} |
697 |
|
|
698 |
/* --- yv12 --- */ |
/* --- yv12 --- */ |
699 |
|
|
700 |
if (get_colorspace(inhdr) != XVID_CSP_NULL) { |
if (get_colorspace(inhdr) != XVID_CSP_NULL) { |
701 |
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
702 |
// XXX: should we set outhdr->biSize ?? |
// XXX: should we set outhdr->biSize ?? |
704 |
} |
} |
705 |
/* --- yv12 --- */ |
/* --- yv12 --- */ |
706 |
|
|
707 |
result = decompress_query(codec, lpbiInput, lpbiOutput); |
result = decompress_query(codec, lpbiInput, NULL); |
708 |
if (result != ICERR_OK) |
if (result != ICERR_OK) |
709 |
{ |
{ |
710 |
return result; |
return result; |
711 |
} |
} |
712 |
|
|
|
memcpy(outhdr, inhdr, sizeof(BITMAPINFOHEADER)); |
|
713 |
outhdr->biSize = sizeof(BITMAPINFOHEADER); |
outhdr->biSize = sizeof(BITMAPINFOHEADER); |
714 |
outhdr->biCompression = FOURCC_YUY2; |
outhdr->biWidth = inhdr->biWidth; |
715 |
|
outhdr->biHeight = inhdr->biHeight; |
716 |
|
outhdr->biPlanes = 1; |
717 |
|
outhdr->biBitCount = 24; |
718 |
|
outhdr->biCompression = BI_RGB; /* sonic foundry vegas video v3 only supports BI_RGB */ |
719 |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount; |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount; |
720 |
outhdr->biXPelsPerMeter = 0; |
outhdr->biXPelsPerMeter = 0; |
721 |
outhdr->biYPelsPerMeter = 0; |
outhdr->biYPelsPerMeter = 0; |
776 |
|
|
777 |
frame.bitstream = icd->lpInput; |
frame.bitstream = icd->lpInput; |
778 |
frame.length = icd->lpbiInput->biSizeImage; |
frame.length = icd->lpbiInput->biSizeImage; |
779 |
|
frame.general = XVID_DEC_LOWDELAY; /* force low_delay_default mode */ |
780 |
|
if (codec->config.deblock_y) |
781 |
|
frame.general |= XVID_DEC_DEBLOCKY; |
782 |
|
if (codec->config.deblock_uv) |
783 |
|
frame.general |= XVID_DEC_DEBLOCKUV; |
784 |
|
|
785 |
frame.image = icd->lpOutput; |
frame.image = icd->lpOutput; |
|
//frame.stride = icd->lpbiOutput->biWidth; |
|
|
// dev-api-3: |
|
786 |
frame.stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
frame.stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
787 |
|
|
788 |
/* --- yv12 --- */ |
/* --- yv12 --- */ |
791 |
icd->lpbiInput->biCompression != FOURCC_DX50) |
icd->lpbiInput->biCompression != FOURCC_DX50) |
792 |
{ |
{ |
793 |
XVID_INIT_CONVERTINFO convert; |
XVID_INIT_CONVERTINFO convert; |
|
|
|
794 |
DEBUGFOURCC("input", icd->lpbiInput->biCompression); |
DEBUGFOURCC("input", icd->lpbiInput->biCompression); |
795 |
DEBUGFOURCC("output", icd->lpbiOutput->biCompression); |
DEBUGFOURCC("output", icd->lpbiOutput->biCompression); |
|
|
|
796 |
convert.input.colorspace = get_colorspace(icd->lpbiInput); |
convert.input.colorspace = get_colorspace(icd->lpbiInput); |
797 |
convert.input.y = icd->lpInput; |
convert.input.y = icd->lpInput; |
798 |
convert.input.y_stride = (((icd->lpbiInput->biWidth * icd->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
convert.input.y_stride = (((icd->lpbiInput->biWidth * icd->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
799 |
|
if (convert.input.colorspace == XVID_CSP_I420 || convert.input.colorspace == XVID_CSP_YV12) |
800 |
|
convert.input.y_stride = (convert.input.y_stride*2)/3; |
801 |
|
|
802 |
convert.output.colorspace = get_colorspace(icd->lpbiOutput); |
convert.output.colorspace = get_colorspace(icd->lpbiOutput); |
803 |
convert.output.y = icd->lpOutput; |
convert.output.y = icd->lpOutput; |
804 |
convert.output.y_stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
convert.output.y_stride = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
805 |
|
if (convert.output.colorspace == XVID_CSP_I420 || convert.output.colorspace == XVID_CSP_YV12) |
806 |
|
convert.output.y_stride = (convert.output.y_stride*2)/3; |
807 |
|
|
808 |
convert.width = icd->lpbiInput->biWidth; |
convert.width = icd->lpbiInput->biWidth; |
809 |
convert.height = icd->lpbiInput->biHeight; |
convert.height = icd->lpbiInput->biHeight; |
810 |
convert.interlacing = 0; |
convert.interlacing = 0; |
|
|
|
811 |
if (convert.input.colorspace == XVID_CSP_NULL || |
if (convert.input.colorspace == XVID_CSP_NULL || |
812 |
convert.output.colorspace == XVID_CSP_NULL || |
convert.output.colorspace == XVID_CSP_NULL || |
813 |
xvid_init(NULL, XVID_INIT_CONVERT, &convert, NULL) != XVID_ERR_OK) |
xvid_init(NULL, XVID_INIT_CONVERT, &convert, NULL) != XVID_ERR_OK) |
814 |
{ |
{ |
815 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
816 |
} |
} |
|
|
|
817 |
return ICERR_OK; |
return ICERR_OK; |
818 |
} |
} |
819 |
/* --- yv12 --- */ |
/* --- yv12 --- */ |
831 |
frame.colorspace = XVID_CSP_NULL; |
frame.colorspace = XVID_CSP_NULL; |
832 |
} |
} |
833 |
|
|
834 |
|
if (frame.colorspace == XVID_CSP_I420 || frame.colorspace == XVID_CSP_YV12) |
835 |
|
frame.stride = (frame.stride*2)/3; |
836 |
|
|
837 |
switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
switch (xvid_decore(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
838 |
{ |
{ |
839 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |