58 |
#include "status.h" |
#include "status.h" |
59 |
|
|
60 |
|
|
61 |
|
|
62 |
static const int pmvfast_presets[7] = { |
static const int pmvfast_presets[7] = { |
63 |
0, 0, 0, 0, |
0, 0, 0, 0, |
64 |
0 | XVID_ME_HALFPELREFINE16 | 0, |
0 | XVID_ME_HALFPELREFINE16 | 0, |
73 |
or XVID_CSP_NULL if failure |
or XVID_CSP_NULL if failure |
74 |
*/ |
*/ |
75 |
|
|
76 |
int get_colorspace(BITMAPINFOHEADER * hdr) |
static int get_colorspace(BITMAPINFOHEADER * hdr) |
77 |
{ |
{ |
78 |
/* rgb only: negative height specifies top down image */ |
/* rgb only: negative height specifies top down image */ |
79 |
int rgb_flip = (hdr->biHeight < 0 ? 0 : XVID_CSP_VFLIP); |
int rgb_flip = (hdr->biHeight < 0 ? 0 : XVID_CSP_VFLIP); |
255 |
} |
} |
256 |
|
|
257 |
|
|
258 |
const char type2char(int type) |
static char type2char(int type) |
259 |
{ |
{ |
260 |
if (type==XVID_TYPE_IVOP) |
if (type==XVID_TYPE_IVOP) |
261 |
return 'I'; |
return 'I'; |
266 |
return 'S'; |
return 'S'; |
267 |
} |
} |
268 |
|
|
269 |
int vfw_debug(void *handle, |
static int vfw_debug(void *handle, |
270 |
int opt, |
int opt, |
271 |
void *param1, |
void *param1, |
272 |
void *param2) |
void *param2) |
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 |
} |
} |
350 |
|
|
351 |
void |
/* constant-quant zones for fixed quant encoding */ |
|
sort_zones(zone_t * zones, int zone_num, int * sel); |
|
|
|
|
352 |
static void |
static void |
353 |
prepare_cquant_zones(CONFIG * config) { |
prepare_cquant_zones(CONFIG * config) { |
354 |
|
|
380 |
} |
} |
381 |
} |
} |
382 |
|
|
383 |
|
/* full first pass zones */ |
384 |
|
static void |
385 |
|
prepare_full1pass_zones(CONFIG * config) { |
386 |
|
|
387 |
|
int i = 0; |
388 |
|
if (config->num_zones == 0 || config->zones[0].frame != 0) { |
389 |
|
/* first zone does not start at frame 0 or doesn't exist */ |
390 |
|
|
391 |
|
if (config->num_zones >= MAX_ZONES) config->num_zones--; /* we scrifice last zone */ |
392 |
|
|
393 |
|
config->zones[config->num_zones].frame = 0; |
394 |
|
config->zones[config->num_zones].mode = RC_ZONE_QUANT; |
395 |
|
config->zones[config->num_zones].weight = 100; |
396 |
|
config->zones[config->num_zones].quant = 200; |
397 |
|
config->zones[config->num_zones].type = XVID_TYPE_AUTO; |
398 |
|
config->zones[config->num_zones].greyscale = 0; |
399 |
|
config->zones[config->num_zones].chroma_opt = 0; |
400 |
|
config->zones[config->num_zones].bvop_threshold = 0; |
401 |
|
config->num_zones++; |
402 |
|
|
403 |
|
sort_zones(config->zones, config->num_zones, &i); |
404 |
|
} |
405 |
|
|
406 |
|
/* step 2: let's change all weight zones into quant zones */ |
407 |
|
|
408 |
|
for(i = 0; i < config->num_zones; i++) |
409 |
|
if (config->zones[i].mode == RC_ZONE_WEIGHT) { |
410 |
|
config->zones[i].mode = RC_ZONE_QUANT; |
411 |
|
config->zones[i].quant = 200; |
412 |
|
} |
413 |
|
} |
414 |
|
|
415 |
|
|
416 |
LRESULT compress_begin(CODEC * codec, BITMAPINFO * lpbiInput, BITMAPINFO * lpbiOutput) |
LRESULT compress_begin(CODEC * codec, BITMAPINFO * lpbiInput, BITMAPINFO * lpbiOutput) |
417 |
{ |
{ |
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 */ |
465 |
memset(&pass1, 0, sizeof(pass1)); |
memset(&pass1, 0, sizeof(pass1)); |
466 |
pass1.version = XVID_VERSION; |
pass1.version = XVID_VERSION; |
467 |
pass1.filename = codec->config.stats; |
pass1.filename = codec->config.stats; |
468 |
|
if (codec->config.full1pass) |
469 |
plugins[create.num_plugins].func = xvid_plugin_2pass1_func; |
prepare_full1pass_zones(&tmpCfg); |
470 |
|
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; |
603 |
|
|
604 |
LRESULT compress_end(CODEC * codec) |
LRESULT compress_end(CODEC * codec) |
605 |
{ |
{ |
606 |
if (m_hdll != NULL) { |
if (codec->m_hdll != NULL) { |
607 |
if (codec->ehandle != NULL) { |
if (codec->ehandle != NULL) { |
608 |
xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
codec->xvid_encore_func(codec->ehandle, XVID_ENC_DESTROY, NULL, NULL); |
609 |
codec->ehandle = NULL; |
codec->ehandle = NULL; |
610 |
} |
} |
|
FreeLibrary(m_hdll); |
|
|
m_hdll = NULL; |
|
611 |
} |
} |
612 |
|
|
613 |
if (codec->config.display_status) |
if (codec->config.display_status) |
776 |
if ((frame.input.csp = get_colorspace(inhdr)) == XVID_CSP_NULL) |
if ((frame.input.csp = get_colorspace(inhdr)) == XVID_CSP_NULL) |
777 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
778 |
|
|
779 |
if (frame.input.csp == XVID_CSP_I420 || frame.input.csp == XVID_CSP_YV12) |
if (frame.input.csp == XVID_CSP_I420 || frame.input.csp == XVID_CSP_YV12) { |
780 |
frame.input.stride[0] = (frame.input.stride[0]*2)/3; |
frame.input.stride[0] = (4 * icc->lpbiInput->biWidth + 3) / 4; |
781 |
|
frame.input.stride[1] = frame.input.stride[2] = frame.input.stride[0] / 2 ; |
782 |
|
} |
783 |
|
|
784 |
frame.bitstream = icc->lpOutput; |
frame.bitstream = icc->lpOutput; |
785 |
frame.length = icc->lpbiOutput->biSizeImage; |
frame.length = icc->lpbiOutput->biSizeImage; |
804 |
memset(&stats, 0, sizeof(stats)); |
memset(&stats, 0, sizeof(stats)); |
805 |
stats.version = XVID_VERSION; |
stats.version = XVID_VERSION; |
806 |
|
|
807 |
length = xvid_encore_func(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats); |
length = codec->xvid_encore_func(codec->ehandle, XVID_ENC_ENCODE, &frame, &stats); |
808 |
switch (length) |
switch (length) |
809 |
{ |
{ |
810 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
924 |
outhdr->biPlanes = 1; |
outhdr->biPlanes = 1; |
925 |
outhdr->biBitCount = 24; |
outhdr->biBitCount = 24; |
926 |
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 */ |
927 |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount; |
outhdr->biSizeImage = outhdr->biWidth * outhdr->biHeight * outhdr->biBitCount / 8; |
928 |
outhdr->biXPelsPerMeter = 0; |
outhdr->biXPelsPerMeter = 0; |
929 |
outhdr->biYPelsPerMeter = 0; |
outhdr->biYPelsPerMeter = 0; |
930 |
outhdr->biClrUsed = 0; |
outhdr->biClrUsed = 0; |
947 |
xvid_dec_create_t create; |
xvid_dec_create_t create; |
948 |
HKEY hKey; |
HKEY hKey; |
949 |
|
|
950 |
if (init_dll() != 0) return ICERR_ERROR; |
if (init_dll(codec) != 0) return ICERR_ERROR; |
951 |
|
|
952 |
memset(&init, 0, sizeof(init)); |
memset(&init, 0, sizeof(init)); |
953 |
init.version = XVID_VERSION; |
init.version = XVID_VERSION; |
954 |
init.cpu_flags = codec->config.cpu; |
init.cpu_flags = codec->config.cpu; |
955 |
xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
codec->xvid_global_func(0, XVID_GBL_INIT, &init, NULL); |
956 |
|
|
957 |
memset(&create, 0, sizeof(create)); |
memset(&create, 0, sizeof(create)); |
958 |
create.version = XVID_VERSION; |
create.version = XVID_VERSION; |
959 |
create.width = lpbiInput->bmiHeader.biWidth; |
create.width = lpbiInput->bmiHeader.biWidth; |
960 |
create.height = lpbiInput->bmiHeader.biHeight; |
create.height = lpbiInput->bmiHeader.biHeight; |
961 |
|
|
962 |
switch(xvid_decore_func(0, XVID_DEC_CREATE, &create, NULL)) |
switch(codec->xvid_decore_func(0, XVID_DEC_CREATE, &create, NULL)) |
963 |
{ |
{ |
964 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
965 |
return ICERR_ERROR; |
return ICERR_ERROR; |
991 |
|
|
992 |
LRESULT decompress_end(CODEC * codec) |
LRESULT decompress_end(CODEC * codec) |
993 |
{ |
{ |
994 |
if (m_hdll != NULL) { |
if (codec->m_hdll != NULL) { |
995 |
if (codec->dhandle != NULL) { |
if (codec->dhandle != NULL) { |
996 |
xvid_decore_func(codec->dhandle, XVID_DEC_DESTROY, NULL, NULL); |
codec->xvid_decore_func(codec->dhandle, XVID_DEC_DESTROY, NULL, NULL); |
997 |
codec->dhandle = NULL; |
codec->dhandle = NULL; |
998 |
} |
} |
|
FreeLibrary(m_hdll); |
|
|
m_hdll = NULL; |
|
999 |
} |
} |
1000 |
|
|
1001 |
return ICERR_OK; |
return ICERR_OK; |
1043 |
convert.interlacing = 0; |
convert.interlacing = 0; |
1044 |
if (convert.input.csp == XVID_CSP_NULL || |
if (convert.input.csp == XVID_CSP_NULL || |
1045 |
convert.output.csp == XVID_CSP_NULL || |
convert.output.csp == XVID_CSP_NULL || |
1046 |
xvid_global_func(0, XVID_GBL_CONVERT, &convert, NULL) < 0) |
codec->xvid_global_func(0, XVID_GBL_CONVERT, &convert, NULL) < 0) |
1047 |
{ |
{ |
1048 |
return ICERR_BADFORMAT; |
return ICERR_BADFORMAT; |
1049 |
} |
} |
1078 |
/* if (pp_dr) frame.general |= XVID_DERING; */ |
/* if (pp_dr) frame.general |= XVID_DERING; */ |
1079 |
if (pp_fe) frame.general |= XVID_FILMEFFECT; |
if (pp_fe) frame.general |= XVID_FILMEFFECT; |
1080 |
|
|
1081 |
switch (xvid_decore_func(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
switch (codec->xvid_decore_func(codec->dhandle, XVID_DEC_DECODE, &frame, NULL)) |
1082 |
{ |
{ |
1083 |
case XVID_ERR_FAIL : |
case XVID_ERR_FAIL : |
1084 |
return ICERR_ERROR; |
return ICERR_ERROR; |