348 |
return 0; |
return 0; |
349 |
} |
} |
350 |
|
|
|
static int exit_dll(CODEC* codec) |
|
|
{ |
|
|
if(codec->m_hdll) |
|
|
{ |
|
|
FreeLibrary(codec->m_hdll); |
|
|
codec->m_hdll = NULL; |
|
|
codec->xvid_global_func = NULL; |
|
|
codec->xvid_encore_func = NULL; |
|
|
codec->xvid_decore_func = NULL; |
|
|
codec->xvid_plugin_single_func = NULL; |
|
|
codec->xvid_plugin_2pass1_func = NULL; |
|
|
codec->xvid_plugin_2pass2_func = NULL; |
|
|
codec->xvid_plugin_lumimasking_func = NULL; |
|
|
codec->xvid_plugin_psnr_func = NULL; |
|
|
} |
|
|
return 0; |
|
|
} |
|
|
|
|
351 |
/* constant-quant zones for fixed quant encoding */ |
/* constant-quant zones for fixed quant encoding */ |
352 |
static void |
static void |
353 |
prepare_cquant_zones(CONFIG * config) { |
prepare_cquant_zones(CONFIG * config) { |
502 |
pass2.kfthreshold = codec->config.kfthreshold; |
pass2.kfthreshold = codec->config.kfthreshold; |
503 |
pass2.container_frame_overhead = 24; /* AVI */ |
pass2.container_frame_overhead = 24; /* AVI */ |
504 |
|
|
505 |
|
/* VBV */ |
506 |
|
pass2.vbv_size = profiles[codec->config.profile].max_vbv_size; |
507 |
|
pass2.vbv_initial = (profiles[codec->config.profile].max_vbv_size*3)/4; |
508 |
|
pass2.vbv_maxrate = 1000*profiles[codec->config.profile].max_bitrate; |
509 |
|
pass2.vbv_peakrate = 10000000; /* 10mbps -- fixme */ |
510 |
|
|
511 |
plugins[create.num_plugins].func = codec->xvid_plugin_2pass2_func; |
plugins[create.num_plugins].func = codec->xvid_plugin_2pass2_func; |
512 |
plugins[create.num_plugins].param = &pass2; |
plugins[create.num_plugins].param = &pass2; |
513 |
create.num_plugins++; |
create.num_plugins++; |
570 |
if (codec->config.packed) |
if (codec->config.packed) |
571 |
create.global |= XVID_GLOBAL_PACKED; |
create.global |= XVID_GLOBAL_PACKED; |
572 |
|
|
|
if (codec->config.closed_gov) |
|
573 |
create.global |= XVID_GLOBAL_CLOSED_GOP; |
create.global |= XVID_GLOBAL_CLOSED_GOP; |
574 |
|
|
575 |
} |
} |
593 |
return ICERR_UNSUPPORTED; |
return ICERR_UNSUPPORTED; |
594 |
} |
} |
595 |
|
|
596 |
|
free(create.zones); |
597 |
codec->ehandle = create.handle; |
codec->ehandle = create.handle; |
598 |
codec->framenum = 0; |
codec->framenum = 0; |
599 |
codec->keyspacing = 0; |
codec->keyspacing = 0; |
614 |
codec->xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
codec->xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
615 |
codec->ehandle = NULL; |
codec->ehandle = NULL; |
616 |
} |
} |
|
exit_dll(codec); |
|
617 |
} |
} |
618 |
|
|
619 |
if (codec->config.display_status) |
if (codec->config.display_status) |
642 |
frame->vop_flags |= XVID_VOP_CHROMAOPT; |
frame->vop_flags |= XVID_VOP_CHROMAOPT; |
643 |
} |
} |
644 |
|
|
645 |
|
if (config->zones[i].cartoon_mode) { |
646 |
|
frame->vop_flags |= XVID_VOP_CARTOON; |
647 |
|
frame->motion |= XVID_ME_DETECT_STATIC_MOTION; |
648 |
|
} |
649 |
|
|
650 |
if ((profiles[config->profile].flags & PROFILE_BVOP) && config->use_bvop) { |
if ((profiles[config->profile].flags & PROFILE_BVOP) && config->use_bvop) { |
651 |
frame->bframe_threshold = config->zones[i].bvop_threshold; |
frame->bframe_threshold = config->zones[i].bvop_threshold; |
652 |
} |
} |
653 |
} |
} |
654 |
|
|
655 |
|
|
656 |
|
#define CALC_BI_STRIDE(width,bitcount) ((((width * bitcount) + 31) & ~31) >> 3) |
657 |
|
|
658 |
LRESULT compress(CODEC * codec, ICCOMPRESS * icc) |
LRESULT compress(CODEC * codec, ICCOMPRESS * icc) |
659 |
{ |
{ |
660 |
BITMAPINFOHEADER * inhdr = icc->lpbiInput; |
BITMAPINFOHEADER * inhdr = icc->lpbiInput; |
684 |
} |
} |
685 |
} |
} |
686 |
|
|
|
if ((profiles[codec->config.profile].flags & PROFILE_REDUCED) && |
|
|
codec->config.reduced_resolution) { |
|
|
frame.vol_flags |= XVID_VOL_REDUCED_ENABLE; |
|
|
frame.vop_flags |= XVID_VOP_REDUCED; /* XXX: need auto decion mode */ |
|
|
} |
|
|
|
|
687 |
if ((profiles[codec->config.profile].flags & PROFILE_QPEL) && codec->config.qpel) { |
if ((profiles[codec->config.profile].flags & PROFILE_QPEL) && codec->config.qpel) { |
688 |
frame.vol_flags |= XVID_VOL_QUARTERPEL; |
frame.vol_flags |= XVID_VOL_QUARTERPEL; |
689 |
frame.motion |= XVID_ME_QUARTERPELREFINE16 | XVID_ME_QUARTERPELREFINE8; |
frame.motion |= XVID_ME_QUARTERPELREFINE16 | XVID_ME_QUARTERPELREFINE8; |
717 |
frame.vop_flags |= XVID_VOP_HALFPEL; |
frame.vop_flags |= XVID_VOP_HALFPEL; |
718 |
frame.vop_flags |= XVID_VOP_HQACPRED; |
frame.vop_flags |= XVID_VOP_HQACPRED; |
719 |
|
|
720 |
|
if (codec->config.interlacing && codec->config.tff) |
721 |
|
frame.vop_flags |= XVID_VOP_TOPFIELDFIRST; |
722 |
|
|
723 |
|
|
724 |
if (codec->config.vop_debug) |
if (codec->config.vop_debug) |
725 |
frame.vop_flags |= XVID_VOP_DEBUG; |
frame.vop_flags |= XVID_VOP_DEBUG; |
726 |
|
|
734 |
if (codec->config.chromame) |
if (codec->config.chromame) |
735 |
frame.motion |= XVID_ME_CHROMA_PVOP + XVID_ME_CHROMA_BVOP; |
frame.motion |= XVID_ME_CHROMA_PVOP + XVID_ME_CHROMA_BVOP; |
736 |
|
|
|
if (codec->config.cartoon_mode) { |
|
|
frame.vop_flags |= XVID_VOP_CARTOON; |
|
|
frame.motion |= XVID_ME_DETECT_STATIC_MOTION; |
|
|
} |
|
|
|
|
737 |
if (codec->config.turbo) |
if (codec->config.turbo) |
738 |
frame.motion |= XVID_ME_FASTREFINE16 | XVID_ME_FASTREFINE8 | |
frame.motion |= XVID_ME_FASTREFINE16 | XVID_ME_FASTREFINE8 | |
739 |
XVID_ME_SKIP_DELTASEARCH | XVID_ME_FAST_MODEINTERPOLATE | |
XVID_ME_SKIP_DELTASEARCH | XVID_ME_FAST_MODEINTERPOLATE | |
741 |
|
|
742 |
frame.motion |= pmvfast_presets[codec->config.motion_search]; |
frame.motion |= pmvfast_presets[codec->config.motion_search]; |
743 |
|
|
744 |
|
if (codec->config.vhq_bframe) frame.vop_flags |= XVID_VOP_RD_BVOP; |
745 |
|
|
746 |
|
|
747 |
switch (codec->config.vhq_mode) |
switch (codec->config.vhq_mode) |
748 |
{ |
{ |
749 |
case VHQ_MODE_DECISION : |
case VHQ_MODE_DECISION : |
780 |
} |
} |
781 |
|
|
782 |
frame.input.plane[0] = icc->lpInput; |
frame.input.plane[0] = icc->lpInput; |
783 |
frame.input.stride[0] = (((icc->lpbiInput->biWidth * icc->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
frame.input.stride[0] = CALC_BI_STRIDE(icc->lpbiInput->biWidth, icc->lpbiInput->biBitCount); |
784 |
|
|
785 |
if ((frame.input.csp = get_colorspace(inhdr)) == XVID_CSP_NULL) |
if ((frame.input.csp = get_colorspace(inhdr)) == XVID_CSP_NULL) |
786 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
933 |
outhdr->biPlanes = 1; |
outhdr->biPlanes = 1; |
934 |
outhdr->biBitCount = 24; |
outhdr->biBitCount = 24; |
935 |
outhdr->biCompression = BI_RGB; /* sonic foundry vegas video v3 only supports BI_RGB */ |
outhdr->biCompression = BI_RGB; /* sonic foundry vegas video v3 only supports BI_RGB */ |
936 |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount; |
outhdr->biSizeImage = outhdr->biHeight * CALC_BI_STRIDE(outhdr->biWidth, outhdr->biBitCount); |
937 |
|
|
938 |
outhdr->biXPelsPerMeter = 0; |
outhdr->biXPelsPerMeter = 0; |
939 |
outhdr->biYPelsPerMeter = 0; |
outhdr->biYPelsPerMeter = 0; |
940 |
outhdr->biClrUsed = 0; |
outhdr->biClrUsed = 0; |
962 |
memset(&init, 0, sizeof(init)); |
memset(&init, 0, sizeof(init)); |
963 |
init.version = XVID_VERSION; |
init.version = XVID_VERSION; |
964 |
init.cpu_flags = codec->config.cpu; |
init.cpu_flags = codec->config.cpu; |
965 |
|
init.debug = codec->config.debug; |
966 |
codec->xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
codec->xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
967 |
|
|
968 |
memset(&create, 0, sizeof(create)); |
memset(&create, 0, sizeof(create)); |
992 |
REG_GET_N("Brightness", pp_brightness, 0); |
REG_GET_N("Brightness", pp_brightness, 0); |
993 |
REG_GET_N("Deblock_Y", pp_dy, 0) |
REG_GET_N("Deblock_Y", pp_dy, 0) |
994 |
REG_GET_N("Deblock_UV", pp_duv, 0) |
REG_GET_N("Deblock_UV", pp_duv, 0) |
995 |
REG_GET_N("Dering", pp_dr, 0) |
REG_GET_N("Dering_Y", pp_dry, 0) |
996 |
|
REG_GET_N("Dering_UV", pp_druv, 0) |
997 |
REG_GET_N("FilmEffect", pp_fe, 0) |
REG_GET_N("FilmEffect", pp_fe, 0) |
998 |
|
|
999 |
RegCloseKey(hKey); |
RegCloseKey(hKey); |
1009 |
codec->xvid_decore_func(codec->dhandle, XVID_DEC_DESTROY, NULL, NULL); |
codec->xvid_decore_func(codec->dhandle, XVID_DEC_DESTROY, NULL, NULL); |
1010 |
codec->dhandle = NULL; |
codec->dhandle = NULL; |
1011 |
} |
} |
|
exit_dll(codec); |
|
1012 |
} |
} |
1013 |
|
|
1014 |
return ICERR_OK; |
return ICERR_OK; |
1041 |
|
|
1042 |
convert.input.csp = get_colorspace(icd->lpbiInput); |
convert.input.csp = get_colorspace(icd->lpbiInput); |
1043 |
convert.input.plane[0] = icd->lpInput; |
convert.input.plane[0] = icd->lpInput; |
1044 |
convert.input.stride[0] = (((icd->lpbiInput->biWidth *icd->lpbiInput->biBitCount) + 31) & ~31) >> 3; |
convert.input.stride[0] = CALC_BI_STRIDE(icd->lpbiInput->biWidth, icd->lpbiInput->biBitCount); |
1045 |
if (convert.input.csp == XVID_CSP_I420 || convert.input.csp == XVID_CSP_YV12) |
if (convert.input.csp == XVID_CSP_I420 || convert.input.csp == XVID_CSP_YV12) |
1046 |
convert.input.stride[0] = (convert.input.stride[0]*2)/3; |
convert.input.stride[0] = (convert.input.stride[0]*2)/3; |
1047 |
|
|
1048 |
convert.output.csp = get_colorspace(icd->lpbiOutput); |
convert.output.csp = get_colorspace(icd->lpbiOutput); |
1049 |
convert.output.plane[0] = icd->lpOutput; |
convert.output.plane[0] = icd->lpOutput; |
1050 |
convert.output.stride[0] = (((icd->lpbiOutput->biWidth *icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
convert.output.stride[0] = CALC_BI_STRIDE(icd->lpbiOutput->biWidth, icd->lpbiOutput->biBitCount); |
1051 |
if (convert.output.csp == XVID_CSP_I420 || convert.output.csp == XVID_CSP_YV12) |
if (convert.output.csp == XVID_CSP_I420 || convert.output.csp == XVID_CSP_YV12) |
1052 |
convert.output.stride[0] = (convert.output.stride[0]*2)/3; |
convert.output.stride[0] = (convert.output.stride[0]*2)/3; |
1053 |
|
|
1077 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
1078 |
} |
} |
1079 |
frame.output.plane[0] = icd->lpOutput; |
frame.output.plane[0] = icd->lpOutput; |
1080 |
frame.output.stride[0] = (((icd->lpbiOutput->biWidth * icd->lpbiOutput->biBitCount) + 31) & ~31) >> 3; |
frame.output.stride[0] = CALC_BI_STRIDE(icd->lpbiOutput->biWidth, icd->lpbiOutput->biBitCount); |
1081 |
if (frame.output.csp == XVID_CSP_I420 || frame.output.csp == XVID_CSP_YV12) |
if (frame.output.csp == XVID_CSP_I420 || frame.output.csp == XVID_CSP_YV12) |
1082 |
frame.output.stride[0] = (frame.output.stride[0]*2)/3; |
frame.output.stride[0] = CALC_BI_STRIDE(icd->lpbiOutput->biWidth, 8); |
1083 |
} |
} |
1084 |
else |
else |
1085 |
{ |
{ |
1088 |
|
|
1089 |
if (pp_dy)frame.general |= XVID_DEBLOCKY; |
if (pp_dy)frame.general |= XVID_DEBLOCKY; |
1090 |
if (pp_duv) frame.general |= XVID_DEBLOCKUV; |
if (pp_duv) frame.general |= XVID_DEBLOCKUV; |
1091 |
/* if (pp_dr) frame.general |= XVID_DERING; */ |
if (pp_dry) frame.general |= XVID_DERINGY; |
1092 |
|
if (pp_druv) frame.general |= XVID_DERINGUV; |
1093 |
if (pp_fe) frame.general |= XVID_FILMEFFECT; |
if (pp_fe) frame.general |= XVID_FILMEFFECT; |
1094 |
|
|
1095 |
frame.brightness = pp_brightness; |
frame.brightness = pp_brightness; |