57 |
#include "codec.h" |
#include "codec.h" |
58 |
#include "status.h" |
#include "status.h" |
59 |
|
|
|
HINSTANCE m_hdll; |
|
|
int (*xvid_global_func)(void *handle, int opt, void *param1, void *param2); |
|
|
int (*xvid_encore_func)(void *handle, int opt, void *param1, void *param2); |
|
|
int (*xvid_decore_func)(void *handle, int opt, void *param1, void *param2); |
|
|
|
|
|
xvid_plugin_func *xvid_plugin_single_func, |
|
|
*xvid_plugin_2pass1_func, |
|
|
*xvid_plugin_2pass2_func, |
|
|
*xvid_plugin_lumimasking_func, |
|
|
*xvid_plugin_psnr_func; |
|
|
|
|
60 |
|
|
61 |
|
|
62 |
static const int pmvfast_presets[7] = { |
static const int pmvfast_presets[7] = { |
303 |
|
|
304 |
#define XVID_DLL_NAME "xvidcore.dll" |
#define XVID_DLL_NAME "xvidcore.dll" |
305 |
|
|
306 |
static int init_dll() |
static int init_dll(CODEC* codec) |
307 |
{ |
{ |
308 |
if (m_hdll != NULL) return 0; |
if (codec->m_hdll != NULL) |
309 |
|
return 0; |
310 |
|
|
311 |
DPRINTF("init_dll"); |
DPRINTF("init_dll"); |
312 |
m_hdll = LoadLibrary(XVID_DLL_NAME); |
codec->m_hdll = LoadLibrary(XVID_DLL_NAME); |
313 |
if (m_hdll == NULL) { |
if (codec->m_hdll == NULL) { |
314 |
DPRINTF("dll load failed"); |
DPRINTF("dll load failed"); |
315 |
MessageBox(0, XVID_DLL_NAME " not found!","Error!", MB_ICONEXCLAMATION|MB_OK); |
MessageBox(0, XVID_DLL_NAME " not found!","Error!", MB_ICONEXCLAMATION|MB_OK); |
316 |
return XVID_ERR_FAIL; |
return XVID_ERR_FAIL; |
317 |
} |
} |
318 |
|
|
319 |
xvid_global_func = (int (__cdecl *)(void *, int, void *, void *))GetProcAddress(m_hdll, "xvid_global"); |
codec->xvid_global_func = (int (__cdecl *)(void *, int, void *, void *))GetProcAddress(codec->m_hdll, "xvid_global"); |
320 |
if (xvid_global_func == NULL) { |
if (codec->xvid_global_func == NULL) { |
321 |
MessageBox(0, "xvid_global() not found", "Error", 0); |
MessageBox(0, "xvid_global() not found", "Error", 0); |
322 |
return XVID_ERR_FAIL; |
return XVID_ERR_FAIL; |
323 |
} |
} |
324 |
|
|
325 |
xvid_encore_func = (int (__cdecl *)(void *, int, void *, void *))GetProcAddress(m_hdll, "xvid_encore"); |
codec->xvid_encore_func = (int (__cdecl *)(void *, int, void *, void *))GetProcAddress(codec->m_hdll, "xvid_encore"); |
326 |
if (xvid_encore_func == NULL) { |
if (codec->xvid_encore_func == NULL) { |
327 |
MessageBox(0, "xvid_encore() not found", "Error", 0); |
MessageBox(0, "xvid_encore() not found", "Error", 0); |
328 |
return XVID_ERR_FAIL; |
return XVID_ERR_FAIL; |
329 |
} |
} |
330 |
|
|
331 |
xvid_decore_func = (int (__cdecl *)(void *, int, void *, void *))GetProcAddress(m_hdll, "xvid_decore"); |
codec->xvid_decore_func = (int (__cdecl *)(void *, int, void *, void *))GetProcAddress(codec->m_hdll, "xvid_decore"); |
332 |
if (xvid_decore_func == NULL) { |
if (codec->xvid_decore_func == NULL) { |
333 |
MessageBox(0, "xvid_decore() not found", "Error", 0); |
MessageBox(0, "xvid_decore() not found", "Error", 0); |
334 |
return XVID_ERR_FAIL; |
return XVID_ERR_FAIL; |
335 |
} |
} |
336 |
|
|
337 |
xvid_plugin_single_func = |
codec->xvid_plugin_single_func = |
338 |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(m_hdll, "xvid_plugin_single")); |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(codec->m_hdll, "xvid_plugin_single")); |
339 |
xvid_plugin_2pass1_func = |
codec->xvid_plugin_2pass1_func = |
340 |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(m_hdll, "xvid_plugin_2pass1")); |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(codec->m_hdll, "xvid_plugin_2pass1")); |
341 |
xvid_plugin_2pass2_func = |
codec->xvid_plugin_2pass2_func = |
342 |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(m_hdll, "xvid_plugin_2pass2")); |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(codec->m_hdll, "xvid_plugin_2pass2")); |
343 |
xvid_plugin_lumimasking_func = |
codec->xvid_plugin_lumimasking_func = |
344 |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(m_hdll, "xvid_plugin_lumimasking")); |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(codec->m_hdll, "xvid_plugin_lumimasking")); |
345 |
xvid_plugin_psnr_func = |
codec->xvid_plugin_psnr_func = |
346 |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(m_hdll, "xvid_plugin_psnr")); |
(int (__cdecl *)(void *, int, void *, void *))(GetProcAddress(codec->m_hdll, "xvid_plugin_psnr")); |
347 |
|
|
348 |
return 0; |
return 0; |
349 |
} |
} |
427 |
CONFIG tmpCfg; /* if we want to alter config to suit our needs, it shouldn't be visible to user later */ |
CONFIG tmpCfg; /* if we want to alter config to suit our needs, it shouldn't be visible to user later */ |
428 |
memcpy(&tmpCfg, &codec->config, sizeof(CONFIG)); |
memcpy(&tmpCfg, &codec->config, sizeof(CONFIG)); |
429 |
|
|
430 |
if (init_dll() != 0) return ICERR_ERROR; |
if (init_dll(codec) != 0) return ICERR_ERROR; |
431 |
/* destroy previously created codec */ |
/* destroy previously created codec */ |
432 |
if(codec->ehandle) { |
if(codec->ehandle) { |
433 |
xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
codec->xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
434 |
codec->ehandle = NULL; |
codec->ehandle = NULL; |
435 |
} |
} |
436 |
|
|
438 |
init.version = XVID_VERSION; |
init.version = XVID_VERSION; |
439 |
init.cpu_flags = codec->config.cpu; |
init.cpu_flags = codec->config.cpu; |
440 |
init.debug = codec->config.debug; |
init.debug = codec->config.debug; |
441 |
xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
codec->xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
442 |
|
|
443 |
memset(&create, 0, sizeof(create)); |
memset(&create, 0, sizeof(create)); |
444 |
create.version = XVID_VERSION; |
create.version = XVID_VERSION; |
454 |
single.reaction_delay_factor = codec->config.rc_reaction_delay_factor; |
single.reaction_delay_factor = codec->config.rc_reaction_delay_factor; |
455 |
single.averaging_period = codec->config.rc_averaging_period; |
single.averaging_period = codec->config.rc_averaging_period; |
456 |
single.buffer = codec->config.rc_buffer; |
single.buffer = codec->config.rc_buffer; |
457 |
plugins[create.num_plugins].func = xvid_plugin_single_func; |
plugins[create.num_plugins].func = codec->xvid_plugin_single_func; |
458 |
plugins[create.num_plugins].param = &single; |
plugins[create.num_plugins].param = &single; |
459 |
create.num_plugins++; |
create.num_plugins++; |
460 |
if (!codec->config.use_2pass_bitrate) /* constant-quant mode */ |
if (!codec->config.use_2pass_bitrate) /* constant-quant mode */ |
467 |
pass1.filename = codec->config.stats; |
pass1.filename = codec->config.stats; |
468 |
if (codec->config.full1pass) |
if (codec->config.full1pass) |
469 |
prepare_full1pass_zones(&tmpCfg); |
prepare_full1pass_zones(&tmpCfg); |
470 |
plugins[create.num_plugins].func = xvid_plugin_2pass1_func; |
plugins[create.num_plugins].func = codec->xvid_plugin_2pass1_func; |
471 |
plugins[create.num_plugins].param = &pass1; |
plugins[create.num_plugins].param = &pass1; |
472 |
create.num_plugins++; |
create.num_plugins++; |
473 |
break; |
break; |
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 |
plugins[create.num_plugins].func = xvid_plugin_2pass2_func; |
plugins[create.num_plugins].func = codec->xvid_plugin_2pass2_func; |
506 |
plugins[create.num_plugins].param = &pass2; |
plugins[create.num_plugins].param = &pass2; |
507 |
create.num_plugins++; |
create.num_plugins++; |
508 |
break; |
break; |
531 |
|
|
532 |
/* lumimasking plugin */ |
/* lumimasking plugin */ |
533 |
if ((profiles[codec->config.profile].flags & PROFILE_ADAPTQUANT) && codec->config.lum_masking) { |
if ((profiles[codec->config.profile].flags & PROFILE_ADAPTQUANT) && codec->config.lum_masking) { |
534 |
plugins[create.num_plugins].func = xvid_plugin_lumimasking_func; |
plugins[create.num_plugins].func = codec->xvid_plugin_lumimasking_func; |
535 |
plugins[create.num_plugins].param = NULL; |
plugins[create.num_plugins].param = NULL; |
536 |
create.num_plugins++; |
create.num_plugins++; |
537 |
} |
} |
573 |
|
|
574 |
create.num_threads = codec->config.num_threads; |
create.num_threads = codec->config.num_threads; |
575 |
|
|
576 |
switch(xvid_encore_func(0, XVID_ENC_CREATE, &create, NULL)) |
switch(codec->xvid_encore_func(0, XVID_ENC_CREATE, &create, NULL)) |
577 |
{ |
{ |
578 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
579 |
return ICERR_ERROR; |
return ICERR_ERROR; |
588 |
return ICERR_UNSUPPORTED; |
return ICERR_UNSUPPORTED; |
589 |
} |
} |
590 |
|
|
591 |
|
free(create.zones); |
592 |
codec->ehandle = create.handle; |
codec->ehandle = create.handle; |
593 |
codec->framenum = 0; |
codec->framenum = 0; |
594 |
codec->keyspacing = 0; |
codec->keyspacing = 0; |
604 |
|
|
605 |
LRESULT compress_end(CODEC * codec) |
LRESULT compress_end(CODEC * codec) |
606 |
{ |
{ |
607 |
if (m_hdll != NULL) { |
if (codec->m_hdll != NULL) { |
608 |
if (codec->ehandle != NULL) { |
if (codec->ehandle != NULL) { |
609 |
xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
codec->xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
610 |
codec->ehandle = NULL; |
codec->ehandle = NULL; |
611 |
} |
} |
|
FreeLibrary(m_hdll); |
|
|
m_hdll = NULL; |
|
612 |
} |
} |
613 |
|
|
614 |
if (codec->config.display_status) |
if (codec->config.display_status) |
643 |
} |
} |
644 |
|
|
645 |
|
|
646 |
|
#define CALC_BI_STRIDE(width,bitcount) ((((width * bitcount) + 31) & ~31) >> 3) |
647 |
|
|
648 |
LRESULT compress(CODEC * codec, ICCOMPRESS * icc) |
LRESULT compress(CODEC * codec, ICCOMPRESS * icc) |
649 |
{ |
{ |
650 |
BITMAPINFOHEADER * inhdr = icc->lpbiInput; |
BITMAPINFOHEADER * inhdr = icc->lpbiInput; |
713 |
frame.vop_flags |= XVID_VOP_HALFPEL; |
frame.vop_flags |= XVID_VOP_HALFPEL; |
714 |
frame.vop_flags |= XVID_VOP_HQACPRED; |
frame.vop_flags |= XVID_VOP_HQACPRED; |
715 |
|
|
716 |
|
if (codec->config.interlacing && codec->config.tff) |
717 |
|
frame.vop_flags |= XVID_VOP_TOPFIELDFIRST; |
718 |
|
|
719 |
|
|
720 |
if (codec->config.vop_debug) |
if (codec->config.vop_debug) |
721 |
frame.vop_flags |= XVID_VOP_DEBUG; |
frame.vop_flags |= XVID_VOP_DEBUG; |
722 |
|
|
778 |
} |
} |
779 |
|
|
780 |
frame.input.plane[0] = icc->lpInput; |
frame.input.plane[0] = icc->lpInput; |
781 |
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); |
782 |
|
|
783 |
if ((frame.input.csp = get_colorspace(inhdr)) == XVID_CSP_NULL) |
if ((frame.input.csp = get_colorspace(inhdr)) == XVID_CSP_NULL) |
784 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
811 |
memset(&stats, 0, sizeof(stats)); |
memset(&stats, 0, sizeof(stats)); |
812 |
stats.version = XVID_VERSION; |
stats.version = XVID_VERSION; |
813 |
|
|
814 |
length = xvid_encore_func(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats); |
length = codec->xvid_encore_func(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats); |
815 |
switch (length) |
switch (length) |
816 |
{ |
{ |
817 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
931 |
outhdr->biPlanes = 1; |
outhdr->biPlanes = 1; |
932 |
outhdr->biBitCount = 24; |
outhdr->biBitCount = 24; |
933 |
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 */ |
934 |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount; |
outhdr->biSizeImage = outhdr->biHeight * CALC_BI_STRIDE(outhdr->biWidth, outhdr->biBitCount); |
935 |
|
|
936 |
outhdr->biXPelsPerMeter = 0; |
outhdr->biXPelsPerMeter = 0; |
937 |
outhdr->biYPelsPerMeter = 0; |
outhdr->biYPelsPerMeter = 0; |
938 |
outhdr->biClrUsed = 0; |
outhdr->biClrUsed = 0; |
955 |
xvid_dec_create_t create; |
xvid_dec_create_t create; |
956 |
HKEY hKey; |
HKEY hKey; |
957 |
|
|
958 |
if (init_dll() != 0) return ICERR_ERROR; |
if (init_dll(codec) != 0) return ICERR_ERROR; |
959 |
|
|
960 |
memset(&init, 0, sizeof(init)); |
memset(&init, 0, sizeof(init)); |
961 |
init.version = XVID_VERSION; |
init.version = XVID_VERSION; |
962 |
init.cpu_flags = codec->config.cpu; |
init.cpu_flags = codec->config.cpu; |
963 |
xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
codec->xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
964 |
|
|
965 |
memset(&create, 0, sizeof(create)); |
memset(&create, 0, sizeof(create)); |
966 |
create.version = XVID_VERSION; |
create.version = XVID_VERSION; |
967 |
create.width = lpbiInput->bmiHeader.biWidth; |
create.width = lpbiInput->bmiHeader.biWidth; |
968 |
create.height = lpbiInput->bmiHeader.biHeight; |
create.height = lpbiInput->bmiHeader.biHeight; |
969 |
|
|
970 |
switch(xvid_decore_func(0, XVID_DEC_CREATE, &create, NULL)) |
switch(codec->xvid_decore_func(0, XVID_DEC_CREATE, &create, NULL)) |
971 |
{ |
{ |
972 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
973 |
return ICERR_ERROR; |
return ICERR_ERROR; |
989 |
REG_GET_N("Brightness", pp_brightness, 0); |
REG_GET_N("Brightness", pp_brightness, 0); |
990 |
REG_GET_N("Deblock_Y", pp_dy, 0) |
REG_GET_N("Deblock_Y", pp_dy, 0) |
991 |
REG_GET_N("Deblock_UV", pp_duv, 0) |
REG_GET_N("Deblock_UV", pp_duv, 0) |
992 |
REG_GET_N("Dering", pp_dr, 0) |
REG_GET_N("Dering_Y", pp_dry, 0) |
993 |
|
REG_GET_N("Dering_UV", pp_druv, 0) |
994 |
REG_GET_N("FilmEffect", pp_fe, 0) |
REG_GET_N("FilmEffect", pp_fe, 0) |
995 |
|
|
996 |
RegCloseKey(hKey); |
RegCloseKey(hKey); |
1001 |
|
|
1002 |
LRESULT decompress_end(CODEC * codec) |
LRESULT decompress_end(CODEC * codec) |
1003 |
{ |
{ |
1004 |
if (m_hdll != NULL) { |
if (codec->m_hdll != NULL) { |
1005 |
if (codec->dhandle != NULL) { |
if (codec->dhandle != NULL) { |
1006 |
xvid_decore_func(codec->dhandle, XVID_DEC_DESTROY, NULL, NULL); |
codec->xvid_decore_func(codec->dhandle, XVID_DEC_DESTROY, NULL, NULL); |
1007 |
codec->dhandle = NULL; |
codec->dhandle = NULL; |
1008 |
} |
} |
|
FreeLibrary(m_hdll); |
|
|
m_hdll = NULL; |
|
1009 |
} |
} |
1010 |
|
|
1011 |
return ICERR_OK; |
return ICERR_OK; |
1038 |
|
|
1039 |
convert.input.csp = get_colorspace(icd->lpbiInput); |
convert.input.csp = get_colorspace(icd->lpbiInput); |
1040 |
convert.input.plane[0] = icd->lpInput; |
convert.input.plane[0] = icd->lpInput; |
1041 |
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); |
1042 |
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) |
1043 |
convert.input.stride[0] = (convert.input.stride[0]*2)/3; |
convert.input.stride[0] = (convert.input.stride[0]*2)/3; |
1044 |
|
|
1045 |
convert.output.csp = get_colorspace(icd->lpbiOutput); |
convert.output.csp = get_colorspace(icd->lpbiOutput); |
1046 |
convert.output.plane[0] = icd->lpOutput; |
convert.output.plane[0] = icd->lpOutput; |
1047 |
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); |
1048 |
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) |
1049 |
convert.output.stride[0] = (convert.output.stride[0]*2)/3; |
convert.output.stride[0] = (convert.output.stride[0]*2)/3; |
1050 |
|
|
1053 |
convert.interlacing = 0; |
convert.interlacing = 0; |
1054 |
if (convert.input.csp == XVID_CSP_NULL || |
if (convert.input.csp == XVID_CSP_NULL || |
1055 |
convert.output.csp == XVID_CSP_NULL || |
convert.output.csp == XVID_CSP_NULL || |
1056 |
xvid_global_func(0, XVID_GBL_CONVERT, &convert, NULL) < 0) |
codec->xvid_global_func(0, XVID_GBL_CONVERT, &convert, NULL) < 0) |
1057 |
{ |
{ |
1058 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
1059 |
} |
} |
1074 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
1075 |
} |
} |
1076 |
frame.output.plane[0] = icd->lpOutput; |
frame.output.plane[0] = icd->lpOutput; |
1077 |
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); |
1078 |
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) |
1079 |
frame.output.stride[0] = (frame.output.stride[0]*2)/3; |
frame.output.stride[0] = (frame.output.stride[0]*2)/3; |
1080 |
} |
} |
1085 |
|
|
1086 |
if (pp_dy)frame.general |= XVID_DEBLOCKY; |
if (pp_dy)frame.general |= XVID_DEBLOCKY; |
1087 |
if (pp_duv) frame.general |= XVID_DEBLOCKUV; |
if (pp_duv) frame.general |= XVID_DEBLOCKUV; |
1088 |
/* if (pp_dr) frame.general |= XVID_DERING; */ |
if (pp_dry) frame.general |= XVID_DERINGY; |
1089 |
|
if (pp_druv) frame.general |= XVID_DERINGUV; |
1090 |
if (pp_fe) frame.general |= XVID_FILMEFFECT; |
if (pp_fe) frame.general |= XVID_FILMEFFECT; |
1091 |
|
|
1092 |
frame.brightness = pp_brightness; |
frame.brightness = pp_brightness; |
1093 |
|
|
1094 |
switch (xvid_decore_func(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
switch (codec->xvid_decore_func(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
1095 |
{ |
{ |
1096 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
1097 |
return ICERR_ERROR; |
return ICERR_ERROR; |