--- trunk/vfw/src/config.c 2002/03/08 02:46:11 3 +++ trunk/vfw/src/config.c 2002/07/27 21:38:19 343 @@ -23,29 +23,137 @@ * * History: * - * ... ??? - * 05.03.2002 Version 0.01; Min Chen - * Add Core version display to about box - * + * 15.06.2002 added bframes options + * 21.04.2002 fixed custom matrix support, tried to get dll size down + * 17.04.2002 re-enabled lumi masking in 1st pass + * 15.04.2002 updated cbr support + * 07.04.2002 min keyframe interval checkbox + * 2-pass max bitrate and overflow customization + * 04.04.2002 interlacing support + * hinted ME support + * 24.03.2002 daniel smith + * added Foxer's new CBR engine + * - cbr_buffer is being used as reaction delay (quick hack) + * 23.03.2002 daniel smith + * added load defaults button + * merged foxer's alternative 2-pass code (2-pass alt tab) + * added proper tooltips + * moved registry data into reg_ints/reg_strs arrays + * added DEBUGERR output on errors instead of returning + * 16.03.2002 daniel smith + * rewrote/restructured most of file + * added tooltips (kind of - dirty message hook method) + * split tabs into a main dialog / advanced prop sheet + * advanced controls are now enabled/disabled by mode + * added modulated quantization, DX50 fourcc + * 11.03.2002 Min Chen + * now get Core Version use xvid_init() + * 05.03.2002 Min Chen + * Add Core version display to about box * 01.12.2001 inital version; (c)2001 peter ross * *************************************************************************/ #include +#include #include #include +#ifdef _SMP +#include +#endif #include "codec.h" #include "config.h" -#include "resource.h" #include "xvid.h" // cpu masks -#include // sprintf() +#include "resource.h" + + + +/* registry info structs */ + +CONFIG reg; + +REG_INT const reg_ints[] = { + {"mode", ®.mode, DLG_MODE_CBR}, + {"quality", ®.quality, 85}, + {"quant", ®.quant, 5}, + {"rc_bitrate", ®.rc_bitrate, 900000}, + {"rc_reaction_delay_factor",®.rc_reaction_delay_factor, 16}, + {"rc_averaging_period", ®.rc_averaging_period, 100}, + {"rc_buffer", ®.rc_buffer, 100}, + + {"motion_search", ®.motion_search, 5}, + {"quant_type", ®.quant_type, 0}, + {"fourcc_used", ®.fourcc_used, 0}, + {"max_key_interval", ®.max_key_interval, 300}, + {"min_key_interval", ®.min_key_interval, 1}, + {"lum_masking", ®.lum_masking, 0}, + {"interlacing", ®.interlacing, 0}, +#ifdef BFRAMES + {"max_bframes", ®.max_bframes, -1}, + {"bquant_ratio", ®.bquant_ratio, 200}, + {"packed", ®.packed, 0}, + {"dx50bvop", ®.dx50bvop, 0}, + {"debug", ®.debug, 0}, + {"frame_drop_ratio", ®.frame_drop_ratio, 0}, +#endif + + {"min_iquant", ®.min_iquant, 1}, + {"max_iquant", ®.max_iquant, 31}, + {"min_pquant", ®.min_pquant, 1}, + {"max_pquant", ®.max_pquant, 31}, + + {"desired_size", ®.desired_size, 570000}, + {"keyframe_boost", ®.keyframe_boost, 20}, + {"discard1pass", ®.discard1pass, 1}, + {"dummy2pass", ®.dummy2pass, 0}, +// added by koepi for new two-pass curve treatment + {"kftreshold", ®.kftreshold, 10}, + {"kfreduction", ®.kfreduction, 30}, +// end of koepi's additions + {"curve_compression_high", ®.curve_compression_high, 25}, + {"curve_compression_low", ®.curve_compression_low, 10}, + {"use_alt_curve", ®.use_alt_curve, 0}, + {"alt_curve_use_auto", ®.alt_curve_use_auto, 1}, + {"alt_curve_auto_str", ®.alt_curve_auto_str, 50}, + {"alt_curve_use_auto_bonus_bias", ®.alt_curve_use_auto_bonus_bias, 1}, + {"alt_curve_bonus_bias", ®.alt_curve_bonus_bias, 50}, + {"alt_curve_type", ®.alt_curve_type, 1}, + {"alt_curve_high_dist", ®.alt_curve_high_dist, 300}, + {"alt_curve_low_dist", ®.alt_curve_low_dist, 300}, + {"alt_curve_min_rel_qual", ®.alt_curve_min_rel_qual, 50}, + {"bitrate_payback_delay", ®.bitrate_payback_delay, 240}, + {"bitrate_payback_method", ®.bitrate_payback_method, 0}, + {"twopass_max_bitrate", ®.twopass_max_bitrate, 10000 * CONFIG_KBPS}, + {"twopass_max_overflow_improvement", ®.twopass_max_overflow_improvement, 60}, + {"twopass_max_overflow_degradation", ®.twopass_max_overflow_degradation, 60}, + {"hinted_me", ®.hinted_me, 0}, + + {"credits_start", ®.credits_start, 0}, + {"credits_start_begin", ®.credits_start_begin, 0}, + {"credits_start_end", ®.credits_start_end, 0}, + {"credits_end", ®.credits_end, 0}, + {"credits_end_begin", ®.credits_end_begin, 0}, + {"credits_end_end", ®.credits_end_end, 0}, + + {"credits_mode", ®.credits_mode, 0}, + {"credits_rate", ®.credits_rate, 20}, + {"credits_quant_i", ®.credits_quant_i, 20}, + {"credits_quant_p", ®.credits_quant_p, 20}, + {"credits_start_size", ®.credits_start_size, 10000}, + {"credits_end_size", ®.credits_end_size, 10000} +}; + +REG_STR const reg_strs[] = { + {"hintfile", reg.hintfile, CONFIG_HINTFILE}, + {"stats1", reg.stats1, CONFIG_2PASS_1_FILE}, + {"stats2", reg.stats2, CONFIG_2PASS_2_FILE} +// {"build", reg.build, XVID_BUILD} +}; /* get config settings from registry */ -#define REG_GET_N(X, Y, Z) size=sizeof(int);if(RegQueryValueEx(hKey, X, 0, 0, (LPBYTE)&Y, &size) != ERROR_SUCCESS) {Y=Z;} -#define REG_GET_S(X, Y, Z) size=MAX_PATH;if(RegQueryValueEx(hKey, X, 0, 0, Y, &size) != ERROR_SUCCESS) {lstrcpy(Y, Z);} #define REG_GET_B(X, Y, Z) size=sizeof((Z));if(RegQueryValueEx(hKey, X, 0, 0, Y, &size) != ERROR_SUCCESS) {memcpy(Y, Z, sizeof((Z)));} void config_reg_get(CONFIG * config) @@ -53,59 +161,37 @@ HKEY hKey; DWORD size; XVID_INIT_PARAM init_param; + int i; - init_param.cpu_flags = 0; + init_param.cpu_flags = XVID_CPU_CHKONLY; xvid_init(0, 0, &init_param, NULL); - config->cpu = init_param.cpu_flags; + reg.cpu = init_param.cpu_flags; - RegOpenKeyEx(XVID_REG_KEY, XVID_REG_SUBKEY, 0, KEY_READ, &hKey); +#ifdef _SMP + reg.num_threads = pthread_num_processors_np(); +#endif - REG_GET_N("mode", config->mode, DLG_MODE_CBR) - REG_GET_N("bitrate", config->bitrate, 900000) - REG_GET_N("quality", config->quality, 85) - REG_GET_N("quant", config->quant, 5) - - REG_GET_S("stats1", config->stats1, CONFIG_2PASS_1_FILE) - REG_GET_S("stats2", config->stats2, CONFIG_2PASS_2_FILE) - REG_GET_N("discard1pass", config->discard1pass, 1) - REG_GET_N("dummy2pass", config->dummy2pass, 0) - REG_GET_N("desired_size", config->desired_size, 570000) - - REG_GET_N("min_iquant", config->min_iquant, 1) - REG_GET_N("max_iquant", config->max_iquant, 31) - - REG_GET_N("keyframe_boost", config->keyframe_boost, 20) - REG_GET_N("min_key_interval", config->min_key_interval, 6) - REG_GET_N("bitrate_payback_delay", config->bitrate_payback_delay, 240) - REG_GET_N("bitrate_payback_method", config->bitrate_payback_method, 0) - REG_GET_N("curve_compression_high", config->curve_compression_high, 25) - REG_GET_N("curve_compression_low", config->curve_compression_low, 15) - - REG_GET_N("credits_start", config->credits_start, 0) - REG_GET_N("credits_start_begin", config->credits_start_begin, 0) - REG_GET_N("credits_start_end", config->credits_start_end, 0) - REG_GET_N("credits_end", config->credits_end, 0) - REG_GET_N("credits_end_begin", config->credits_end_begin, 0) - REG_GET_N("credits_end_end", config->credits_end_end, 0) - - REG_GET_N("credits_mode", config->credits_mode, 0) - REG_GET_N("credits_rate", config->credits_rate, 10) - REG_GET_N("credits_quant_i", config->credits_quant_i, 20) - REG_GET_N("credits_quant_p", config->credits_quant_p, 20) - REG_GET_N("credits_start_size", config->credits_start_size, 10000) - REG_GET_N("credits_end_size", config->credits_end_size, 10000) - - REG_GET_N("motion_search", config->motion_search, 5) - REG_GET_N("quant_type", config->quant_type, 0) - REG_GET_N("max_key_interval", config->max_key_interval, 300) - - REG_GET_N("rc_buffersize", config->rc_buffersize, 2048000) - - REG_GET_N("max_quant", config->max_quant, 31) - REG_GET_N("min_quant", config->min_quant, 1) - REG_GET_N("lum_masking", config->lum_masking, 0) + RegOpenKeyEx(XVID_REG_KEY, XVID_REG_PARENT "\\" XVID_REG_CHILD, 0, KEY_READ, &hKey); + + for (i=0 ; ifourcc_used, 0) + if (RegQueryValueEx(hKey, reg_strs[i].reg_value, 0, 0, (LPBYTE)reg_strs[i].config_str, &size) != ERROR_SUCCESS) + { + memcpy(reg_strs[i].config_str, reg_strs[i].def, MAX_PATH); + } + } { BYTE default_qmatrix_intra[] = { @@ -130,28 +216,29 @@ 23,24,25,27,28,30,31,33 }; - REG_GET_B("qmatrix_intra", config->qmatrix_intra, default_qmatrix_intra) - REG_GET_B("qmatrix_inter", config->qmatrix_inter, default_qmatrix_inter) + REG_GET_B("qmatrix_intra", reg.qmatrix_intra, default_qmatrix_intra); + REG_GET_B("qmatrix_inter", reg.qmatrix_inter, default_qmatrix_inter); } + memcpy(config, ®, sizeof(CONFIG)); + RegCloseKey(hKey); } /* put config settings in registry */ -#define REG_SET_N(X, Y) RegSetValueEx(hKey, X, 0, REG_DWORD, (LPBYTE)&Y, sizeof(int)) -#define REG_SET_S(X, Y) RegSetValueEx(hKey, X, 0, REG_SZ, Y, lstrlen(Y)+1) #define REG_SET_B(X, Y) RegSetValueEx(hKey, X, 0, REG_BINARY, Y, sizeof((Y))) void config_reg_set(CONFIG * config) { HKEY hKey; DWORD dispo; + int i; if (RegCreateKeyEx( XVID_REG_KEY, - XVID_REG_SUBKEY, + XVID_REG_PARENT "\\" XVID_REG_CHILD, 0, XVID_REG_CLASS, REG_OPTION_NON_VOLATILE, @@ -164,327 +251,159 @@ return; } - REG_SET_N("mode", config->mode); - REG_SET_N("bitrate", config->bitrate); - REG_SET_N("quality", config->quality); - REG_SET_N("quant", config->quant); - - REG_SET_S("stats1", config->stats1); - REG_SET_S("stats2", config->stats2); - REG_SET_N("discard1pass", config->discard1pass); - REG_SET_N("dummy2pass", config->dummy2pass); - REG_SET_N("desired_size", config->desired_size); - - REG_SET_N("min_iquant", config->min_iquant); - REG_SET_N("max_iquant", config->max_iquant); - - REG_SET_N("keyframe_boost", config->keyframe_boost); - REG_SET_N("min_key_interval", config->min_key_interval); - REG_SET_N("bitrate_payback_delay", config->bitrate_payback_delay); - REG_SET_N("bitrate_payback_method", config->bitrate_payback_method); - REG_SET_N("curve_compression_high", config->curve_compression_high); - REG_SET_N("curve_compression_low", config->curve_compression_low); - - REG_SET_N("credits_start", config->credits_start); - REG_SET_N("credits_start_begin", config->credits_start_begin); - REG_SET_N("credits_start_end", config->credits_start_end); - REG_SET_N("credits_end", config->credits_end); - REG_SET_N("credits_end_begin", config->credits_end_begin); - REG_SET_N("credits_end_end", config->credits_end_end); - - REG_SET_N("credits_mode", config->credits_mode); - REG_SET_N("credits_rate", config->credits_rate); - REG_SET_N("credits_quant_i", config->credits_quant_i); - REG_SET_N("credits_quant_p", config->credits_quant_p); - REG_SET_N("credits_start_size", config->credits_start_size); - REG_SET_N("credits_end_size", config->credits_end_size); - - REG_SET_N("motion_search", config->motion_search); - REG_SET_N("quant_type", config->quant_type); - REG_SET_N("max_key_interval", config->max_key_interval); - - REG_SET_N("rc_buffersize", config->rc_buffersize); - - REG_SET_N("max_quant", config->max_quant); - REG_SET_N("min_quant", config->min_quant); - REG_SET_N("lum_masking", config->lum_masking); + memcpy(®, config, sizeof(CONFIG)); + + for (i=0 ; ifourcc_used); + for (i=0 ; iqmatrix_intra); - REG_SET_B("qmatrix_inter", config->qmatrix_inter); + REG_SET_B("qmatrix_intra", reg.qmatrix_intra); + REG_SET_B("qmatrix_inter", reg.qmatrix_inter); RegCloseKey(hKey); } -/* enable/disable dialog controls based on encoder mode */ - -#define ENABLE(X) EnableWindow(GetDlgItem(hDlg, (X)), TRUE); -#define DISABLE(X) EnableWindow(GetDlgItem(hDlg, (X)), FALSE); -#define ISDLGSET(X) (IsDlgButtonChecked(hDlg, (X)) == BST_CHECKED) +/* clear XviD registry key, load defaults */ -void config_mode(HWND hDlg) +void config_reg_default(CONFIG * config) { - XVID_INIT_PARAM init_param; - LONG mode; - - mode = SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0); + HKEY hKey; - if (mode == DLG_MODE_VBR_QUAL || mode == DLG_MODE_VBR_QUANT || - mode == DLG_MODE_2PASS_1 || mode == DLG_MODE_2PASS_2_INT) - { - ENABLE(IDC_CREDITS); - } - else + if (RegOpenKeyEx(XVID_REG_KEY, XVID_REG_PARENT, 0, KEY_ALL_ACCESS, &hKey)) { - DISABLE(IDC_CREDITS); + DEBUG1("Couldn't open registry key for deletion - ", GetLastError()); + return; } - if (mode == DLG_MODE_VBR_QUAL || mode == DLG_MODE_VBR_QUANT || mode == DLG_MODE_CBR) - { - ENABLE(IDC_VALUE_STATIC); - ENABLE(IDC_VALUE); - ENABLE(IDC_SLIDER_STATIC); - ENABLE(IDC_SLIDER); - } - else + if (RegDeleteKey(hKey, XVID_REG_CHILD)) { - DISABLE(IDC_VALUE_STATIC); - DISABLE(IDC_VALUE); - DISABLE(IDC_SLIDER_STATIC); - DISABLE(IDC_SLIDER); + DEBUG1("Couldn't delete registry key - ", GetLastError()); + return; } - if (mode == DLG_MODE_2PASS_1 || mode == DLG_MODE_2PASS_2_EXT || mode == DLG_MODE_2PASS_2_INT) - { - ENABLE(IDC_2PASS_STATS1_STATIC); - ENABLE(IDC_2PASS_STATS1); - ENABLE(IDC_2PASS_STATS1_BROWSE); - ENABLE(IDC_2PASS_INT); - } - else - { - DISABLE(IDC_2PASS_STATS1_STATIC); - DISABLE(IDC_2PASS_STATS1); - DISABLE(IDC_2PASS_STATS1_BROWSE); - DISABLE(IDC_2PASS_INT); - } + RegCloseKey(hKey); + config_reg_get(config); + config_reg_set(config); +} - if (mode == DLG_MODE_2PASS_1) - { - ENABLE(IDC_DISCARD1PASS); - } - else - { - DISABLE(IDC_DISCARD1PASS); - } - if (mode == DLG_MODE_2PASS_2_EXT) - { - ENABLE(IDC_2PASS_STATS1_STATIC); - ENABLE(IDC_2PASS_STATS2); - ENABLE(IDC_2PASS_STATS2_BROWSE); - } - else - { - DISABLE(IDC_2PASS_STATS1_STATIC); - DISABLE(IDC_2PASS_STATS2); - DISABLE(IDC_2PASS_STATS2_BROWSE); - } +/* leaves current config value if dialog item is empty */ - if (ISDLGSET(IDC_CPU_FORCE)) { - ENABLE(IDC_CPU_MMX); - ENABLE(IDC_CPU_MMXEXT); - ENABLE(IDC_CPU_SSE); - ENABLE(IDC_CPU_SSE2); - ENABLE(IDC_CPU_3DNOW); - ENABLE(IDC_CPU_3DNOWEXT); - } else { - xvid_init(0, 0, &init_param, NULL); +int config_get_int(HWND hDlg, INT item, int config) +{ + BOOL success = FALSE; - CheckDlgButton(hDlg, IDC_CPU_MMX, init_param.cpu_flags & XVID_CPU_MMX ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_MMXEXT, init_param.cpu_flags & XVID_CPU_MMXEXT ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_SSE, init_param.cpu_flags & XVID_CPU_SSE ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_SSE2, init_param.cpu_flags & XVID_CPU_SSE2 ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_3DNOW, init_param.cpu_flags & XVID_CPU_3DNOW ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_3DNOWEXT, init_param.cpu_flags & XVID_CPU_3DNOWEXT ? BST_CHECKED : BST_UNCHECKED); + int tmp = GetDlgItemInt(hDlg, item, &success, TRUE); - DISABLE(IDC_CPU_MMX); - DISABLE(IDC_CPU_MMXEXT); - DISABLE(IDC_CPU_SSE); - DISABLE(IDC_CPU_SSE2); - DISABLE(IDC_CPU_3DNOW); - DISABLE(IDC_CPU_3DNOWEXT); - } + return (success) ? tmp : config; } -/* upload config data into dialog */ - -void config_upload(HWND hDlg, int page, CONFIG * config) +int config_get_uint(HWND hDlg, UINT item, int config) { - switch (page) - { - case DLG_MAIN : - SendDlgItemMessage(hDlg, IDC_MODE, CB_SETCURSEL, config->mode, 0); - config_mode(hDlg); + BOOL success = FALSE; - config_slider(hDlg, config); - config_value(hDlg, config); + int tmp = GetDlgItemInt(hDlg, item, &success, FALSE); - SetDlgItemText(hDlg, IDC_2PASS_STATS1, config->stats1); - SetDlgItemText(hDlg, IDC_2PASS_STATS2, config->stats2); - CheckDlgButton(hDlg, IDC_DISCARD1PASS, config->discard1pass ? BST_CHECKED : BST_UNCHECKED); - break; + return (success) ? tmp : config; +} - case DLG_ADV : - SendDlgItemMessage(hDlg, IDC_MOTION, CB_SETCURSEL, config->motion_search, 0); - SendDlgItemMessage(hDlg, IDC_QTYPE, CB_SETCURSEL, config->quant_type, 0); - SetDlgItemInt(hDlg, IDC_MAXKEY, config->max_key_interval, FALSE); - SetDlgItemInt(hDlg, IDC_MINQ, config->min_quant, FALSE); - SetDlgItemInt(hDlg, IDC_MAXQ, config->max_quant, FALSE); - CheckDlgButton(hDlg, IDC_LUMMASK, config->lum_masking ? BST_CHECKED : BST_UNCHECKED); +/* downloads data from main dialog */ - SendDlgItemMessage(hDlg, IDC_FOURCC, CB_SETCURSEL, config->fourcc_used, 0); +void main_download(HWND hDlg, CONFIG * config) +{ + switch(config->mode) + { + default : + case DLG_MODE_CBR : + config->rc_bitrate = config_get_uint(hDlg, IDC_VALUE, config->rc_bitrate) * CONFIG_KBPS; break; - case DLG_DEBUG : - SetDlgItemInt(hDlg, IDC_RC_BUFFERSIZE, config->rc_buffersize, FALSE); - - SetDlgItemInt(hDlg, IDC_IMINQ, config->min_iquant, FALSE); - SetDlgItemInt(hDlg, IDC_IMAXQ, config->max_iquant, FALSE); - CheckDlgButton(hDlg, IDC_DUMMY2PASS, config->dummy2pass ? BST_CHECKED : BST_UNCHECKED); + case DLG_MODE_VBR_QUAL : + config->quality = config_get_uint(hDlg, IDC_VALUE, config->quality); break; - case DLG_CPU : - CheckDlgButton(hDlg, IDC_CPU_MMX, config->cpu & XVID_CPU_MMX ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_MMXEXT, config->cpu & XVID_CPU_MMXEXT ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_SSE, config->cpu & XVID_CPU_SSE ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_SSE2, config->cpu & XVID_CPU_SSE2 ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_3DNOW, config->cpu & XVID_CPU_3DNOW ? BST_CHECKED : BST_UNCHECKED); - CheckDlgButton(hDlg, IDC_CPU_3DNOWEXT, config->cpu & XVID_CPU_3DNOWEXT ? BST_CHECKED : BST_UNCHECKED); + case DLG_MODE_VBR_QUANT : + config->quant = config_get_uint(hDlg, IDC_VALUE, config->quant); + break; - CheckRadioButton(hDlg, IDC_CPU_AUTO, IDC_CPU_FORCE, - config->cpu & XVID_CPU_FORCE ? IDC_CPU_FORCE : IDC_CPU_AUTO ); + case DLG_MODE_2PASS_2_INT : + config->desired_size = config_get_uint(hDlg, IDC_VALUE, config->desired_size); break; } -} + config->mode = SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0); +} -/* download config data from dialog - replaces invalid values instead of alerting user for now -*/ -#define CONSTRAINVAL(X,Y,Z) if((X)<(Y)) X=Y; if((X)>(Z)) X=Z; +/* updates the edit box */ -void config_download(HWND hDlg, int page, CONFIG * config) +void main_value(HWND hDlg, CONFIG* config) { + char* text; int value; + int enabled = TRUE; - switch (page) + switch (config->mode) { - case DLG_MAIN : - config->mode = SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0); - - value = config_get_int(hDlg, IDC_VALUE, 2); - - switch (SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_GETRANGEMAX, 0, 0)) - { - case 10000 : - CONSTRAINVAL(value, 1, 10000) - config->bitrate = value * CONFIG_KBPS; - break; - - case 100 : - CONSTRAINVAL(value, 0, 100) - config->quality = value; - break; - - case 31 : - CONSTRAINVAL(value, 1, 31) - config->quant = value; - break; - } - - GetDlgItemText(hDlg, IDC_2PASS_STATS1, config->stats1, MAX_PATH); - if (config->stats1[0] == '\0') - { - lstrcpy(config->stats1, CONFIG_2PASS_1_FILE); - } - GetDlgItemText(hDlg, IDC_2PASS_STATS2, config->stats2, MAX_PATH); - if (config->stats2[0] == '\0') - { - lstrcpy(config->stats2, CONFIG_2PASS_2_FILE); - } + default : + enabled = FALSE; - config->discard1pass = ISDLGSET(IDC_DISCARD1PASS); + case DLG_MODE_CBR : + text = "Bitrate (Kbps):"; + value = config->rc_bitrate / CONFIG_KBPS; break; - case DLG_ADV : - config->motion_search = SendDlgItemMessage(hDlg, IDC_MOTION, CB_GETCURSEL, 0, 0); - config->quant_type = SendDlgItemMessage(hDlg, IDC_QTYPE, CB_GETCURSEL, 0, 0); - config->max_key_interval = config_get_int(hDlg, IDC_MAXKEY, config->max_key_interval); - - config->min_quant = config_get_int(hDlg, IDC_MINQ, config->min_quant); - config->max_quant = config_get_int(hDlg, IDC_MAXQ, config->max_quant); - config->lum_masking = ISDLGSET(IDC_LUMMASK); - - CONSTRAINVAL(config->min_quant, 1, 31) - CONSTRAINVAL(config->max_quant, 1, 31) - if(config->max_quant < config->min_quant) - { - config->max_quant = config->min_quant; - } - - config->fourcc_used = SendDlgItemMessage(hDlg, IDC_FOURCC, CB_GETCURSEL, 0, 0); + case DLG_MODE_VBR_QUAL : + text = "Quality:"; + value = config->quality; break; - case DLG_DEBUG: - config->rc_buffersize = config_get_int(hDlg, IDC_RC_BUFFERSIZE, config->rc_buffersize); - - config->min_iquant = config_get_int(hDlg, IDC_IMINQ, config->min_iquant); - config->max_iquant = config_get_int(hDlg, IDC_IMAXQ, config->max_iquant); - config->dummy2pass = ISDLGSET(IDC_DUMMY2PASS); - - CONSTRAINVAL(config->min_iquant, 1, 31) - CONSTRAINVAL(config->min_iquant, 1, 31) - if(config->max_iquant < config->min_iquant) - { - config->max_iquant = config->min_iquant; - } + case DLG_MODE_VBR_QUANT : + text = "Quantizer:"; + value = config->quant; break; - case DLG_CPU : - config->cpu = 0; - config->cpu |= ISDLGSET(IDC_CPU_MMX) ? XVID_CPU_MMX : 0; - config->cpu |= ISDLGSET(IDC_CPU_MMXEXT) ? XVID_CPU_MMXEXT: 0; - config->cpu |= ISDLGSET(IDC_CPU_SSE) ? XVID_CPU_SSE: 0; - config->cpu |= ISDLGSET(IDC_CPU_SSE2) ? XVID_CPU_SSE2: 0; - config->cpu |= ISDLGSET(IDC_CPU_3DNOW) ? XVID_CPU_3DNOW: 0; - config->cpu |= ISDLGSET(IDC_CPU_3DNOWEXT) ? XVID_CPU_3DNOWEXT: 0; - config->cpu |= ISDLGSET(IDC_CPU_FORCE) ? XVID_CPU_FORCE : 0; + case DLG_MODE_2PASS_2_INT : + text = "Desired size (Kbtyes):"; + value = config->desired_size; break; } + + SetDlgItemText(hDlg, IDC_VALUE_STATIC, text); + SetDlgItemInt(hDlg, IDC_VALUE, value, FALSE); + + EnableWindow(GetDlgItem(hDlg, IDC_VALUE_STATIC), enabled); + EnableWindow(GetDlgItem(hDlg, IDC_VALUE), enabled); } /* updates the slider */ -void config_slider(HWND hDlg, CONFIG* config) +void main_slider(HWND hDlg, CONFIG * config) { char* text; long range; int pos; + int enabled = TRUE; switch (config->mode) { default : + enabled = FALSE; + case DLG_MODE_CBR : text = "Bitrate (Kbps):"; range = MAKELONG(0,10000); - pos = config->bitrate / CONFIG_KBPS; + pos = config->rc_bitrate / CONFIG_KBPS; break; case DLG_MODE_VBR_QUAL : @@ -503,329 +422,537 @@ SetDlgItemText(hDlg, IDC_SLIDER_STATIC, text); SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETRANGE, TRUE, range); SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETPOS, TRUE, pos); + + EnableWindow(GetDlgItem(hDlg, IDC_SLIDER_STATIC), enabled); + EnableWindow(GetDlgItem(hDlg, IDC_SLIDER), enabled); } -/* updates the edit box */ +/* load advanced options property sheet */ -void config_value(HWND hDlg, CONFIG* config) +void adv_dialog(HWND hParent, CONFIG * config) { - char* text; - int value; + PROPSHEETINFO psi[DLG_COUNT]; + PROPSHEETPAGE psp[DLG_COUNT]; + PROPSHEETHEADER psh; + CONFIG temp; + int i; - switch (config->mode) + config->save = FALSE; + memcpy(&temp, config, sizeof(CONFIG)); + + for (i=0 ; ibitrate / CONFIG_KBPS; - break; + psp[i].dwSize = sizeof(PROPSHEETPAGE); + psp[i].dwFlags = 0; + psp[i].hInstance = hInst; + psp[i].pfnDlgProc = adv_proc; + psp[i].lParam = (LPARAM)&psi[i]; + psp[i].pfnCallback = NULL; + + psi[i].page = i; + psi[i].config = &temp; + } + + psp[DLG_GLOBAL].pszTemplate = MAKEINTRESOURCE(IDD_GLOBAL); + psp[DLG_QUANT].pszTemplate = MAKEINTRESOURCE(IDD_QUANT); + psp[DLG_2PASS].pszTemplate = MAKEINTRESOURCE(IDD_2PASS); + psp[DLG_2PASSALT].pszTemplate = MAKEINTRESOURCE(IDD_2PASSALT); + psp[DLG_CREDITS].pszTemplate = MAKEINTRESOURCE(IDD_CREDITS); + psp[DLG_CPU].pszTemplate = MAKEINTRESOURCE(IDD_CPU); + + psh.dwSize = sizeof(PROPSHEETHEADER); + psh.dwFlags = PSH_PROPSHEETPAGE | PSH_NOAPPLYNOW; + psh.hwndParent = hParent; + psh.hInstance = hInst; + psh.pszCaption = (LPSTR) "XviD Configuration"; + psh.nPages = DLG_COUNT; + psh.nStartPage = DLG_GLOBAL; + psh.ppsp = (LPCPROPSHEETPAGE)&psp; + psh.pfnCallback = NULL; - case DLG_MODE_VBR_QUAL : - text = "Quality:"; - value = config->quality; - break; + PropertySheet(&psh); - case DLG_MODE_VBR_QUANT : - text = "Quantizer:"; - value = config->quant; - break; + if (temp.save) + { + memcpy(config, &temp, sizeof(CONFIG)); } - - SetDlgItemText(hDlg, IDC_VALUE_STATIC, text); - SetDlgItemInt(hDlg, IDC_VALUE, value, FALSE); } -/* leaves current config value if dialog item is empty */ - -int config_get_int(HWND hDlg, UINT item, int config) -{ - BOOL success = FALSE; - - int tmp = GetDlgItemInt(hDlg, item, &success, FALSE); - - if(success) { - return tmp; - } else { - return config; - } -} +/* enable/disable advanced controls based on encoder mode */ +#define CONTROLDLG(X,Y) EnableWindow(GetDlgItem(hDlg, (X)), (Y)) +#define ISDLGSET(X) (IsDlgButtonChecked(hDlg, (X)) == BST_CHECKED) -/* configure credits dialog controls */ +#define MOD_CBR -void credits_controls(HWND hDlg) +void adv_mode(HWND hDlg, int mode) { - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_START_BEGIN), ISDLGSET(IDC_CREDITS_START)); - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_START_END), ISDLGSET(IDC_CREDITS_START)); - - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_END_BEGIN), ISDLGSET(IDC_CREDITS_END)); - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_END_END), ISDLGSET(IDC_CREDITS_END)); - - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_RATE), ISDLGSET(IDC_CREDITS_RATE_RADIO)); - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_QUANTI), ISDLGSET(IDC_CREDITS_QUANT_RADIO)); - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_QUANTP), ISDLGSET(IDC_CREDITS_QUANT_RADIO)); - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_START_SIZE), ISDLGSET(IDC_CREDITS_SIZE_RADIO)); - EnableWindow(GetDlgItem(hDlg, IDC_CREDITS_END_SIZE), ISDLGSET(IDC_CREDITS_SIZE_RADIO)); -} + // create arrays of controls to be disabled for each mode + const short twopass_disable[] = { + IDC_KFBOOST, IDC_DUMMY2PASS, IDC_USEALT, +// added by koepi for new curve treatment + IDC_KFTRESHOLD, IDC_KFREDUCTION, +//end of koepi's additions + IDC_CURVECOMPH, IDC_CURVECOMPL, IDC_PAYBACK, IDC_PAYBACKBIAS, IDC_PAYBACKPROP, + IDC_STATS2, IDC_STATS2_BROWSE, + }; + + const short cbr_disable[] = { + IDC_STATS1, IDC_STATS1_BROWSE, IDC_DISCARD1PASS, IDC_HINTEDME, + IDC_CREDITS_START, IDC_CREDITS_END, IDC_CREDITS_START_BEGIN, IDC_CREDITS_START_END, + IDC_CREDITS_END_BEGIN, IDC_CREDITS_END_END, IDC_CREDITS_RATE_RADIO, + IDC_CREDITS_QUANT_RADIO, IDC_CREDITS_QUANT_STATIC, IDC_CREDITS_SIZE_RADIO, + IDC_CREDITS_END_STATIC, IDC_CREDITS_RATE, IDC_CREDITS_QUANTI, IDC_CREDITS_QUANTP, + IDC_CREDITS_START_SIZE, IDC_CREDITS_END_SIZE, + }; + + const short qual_disable[] = { + IDC_STATS1, IDC_STATS1_BROWSE, IDC_DISCARD1PASS, IDC_HINTEDME, + IDC_CBR_REACTIONDELAY, IDC_CBR_AVERAGINGPERIOD, IDC_CBR_BUFFER, + IDC_CREDITS_SIZE_RADIO, IDC_CREDITS_END_STATIC, IDC_CREDITS_START_SIZE, IDC_CREDITS_END_SIZE + }; + + const short quant_disable[] = { + IDC_STATS1, IDC_STATS1_BROWSE, IDC_DISCARD1PASS, IDC_HINTEDME, + IDC_CBR_REACTIONDELAY, IDC_CBR_AVERAGINGPERIOD, IDC_CBR_BUFFER, + IDC_MINIQUANT, IDC_MAXIQUANT, IDC_MINPQUANT, IDC_MAXPQUANT, + IDC_CREDITS_SIZE_RADIO, IDC_CREDITS_END_STATIC, IDC_CREDITS_START_SIZE, IDC_CREDITS_END_SIZE + }; + + const short twopass1_disable[] = { + IDC_CBR_REACTIONDELAY, IDC_CBR_AVERAGINGPERIOD, IDC_CBR_BUFFER, + IDC_MINIQUANT, IDC_MAXIQUANT, IDC_MINPQUANT, IDC_MAXPQUANT, + IDC_CREDITS_RATE_RADIO, IDC_CREDITS_RATE, IDC_CREDITS_SIZE_RADIO, IDC_CREDITS_END_STATIC, + IDC_CREDITS_START_SIZE, IDC_CREDITS_END_SIZE + }; + + const short twopass2_ext_disable[] = { + IDC_CBR_REACTIONDELAY, IDC_CBR_AVERAGINGPERIOD, IDC_CBR_BUFFER, + IDC_CREDITS_RATE_RADIO, IDC_CREDITS_QUANT_RADIO, IDC_CREDITS_QUANT_STATIC, + IDC_CREDITS_SIZE_RADIO, IDC_CREDITS_END_STATIC, IDC_CREDITS_RATE, + IDC_CREDITS_QUANTI, IDC_CREDITS_QUANTP, IDC_CREDITS_START_SIZE, IDC_CREDITS_END_SIZE + }; + + const short twopass2_int_disable[] = { + IDC_CBR_REACTIONDELAY, IDC_CBR_AVERAGINGPERIOD, IDC_CBR_BUFFER, + IDC_STATS2, IDC_STATS2_BROWSE + }; + + // store pointers in order so we can lookup using config->mode + const short* modes[] = { + cbr_disable, qual_disable, quant_disable, + twopass1_disable, twopass2_ext_disable, twopass2_int_disable + }; + + // ditto modes[] + const int lengths[] = { + sizeof(cbr_disable)/sizeof(short), sizeof(qual_disable)/sizeof(short), + sizeof(quant_disable)/sizeof(short), sizeof(twopass1_disable)/sizeof(short), + sizeof(twopass2_ext_disable)/sizeof(short), sizeof(twopass2_int_disable)/sizeof(short), 0 + }; - -void quant_upload(HWND hDlg, CONFIG* config) -{ int i; - - for (i=0 ; i<64 ; ++i) + int hinted_me, use_alt, use_alt_auto, use_alt_auto_bonus; + int credits_start, credits_end, credits_rate, credits_quant, credits_size; + int cpu_force; + + // first perform checkbox-based enable/disable + hinted_me = ISDLGSET(IDC_HINTEDME); + CONTROLDLG(IDC_HINTFILE, hinted_me); + CONTROLDLG(IDC_HINT_BROWSE, hinted_me); + + use_alt = ISDLGSET(IDC_USEALT) && (mode == DLG_MODE_2PASS_2_EXT || mode == DLG_MODE_2PASS_2_INT); + use_alt_auto = ISDLGSET(IDC_USEAUTO); + use_alt_auto_bonus = ISDLGSET(IDC_USEAUTOBONUS); + CONTROLDLG(IDC_USEAUTO, use_alt); + CONTROLDLG(IDC_AUTOSTR, use_alt && use_alt_auto); + CONTROLDLG(IDC_USEAUTOBONUS, use_alt); + CONTROLDLG(IDC_BONUSBIAS, use_alt && !use_alt_auto_bonus); + CONTROLDLG(IDC_CURVETYPE, use_alt); + CONTROLDLG(IDC_ALTCURVEHIGH, use_alt); + CONTROLDLG(IDC_ALTCURVELOW, use_alt); + CONTROLDLG(IDC_MINQUAL, use_alt && !use_alt_auto); + + credits_start = ISDLGSET(IDC_CREDITS_START); + CONTROLDLG(IDC_CREDITS_START_BEGIN, credits_start); + CONTROLDLG(IDC_CREDITS_START_END, credits_start); + + credits_end = ISDLGSET(IDC_CREDITS_END); + CONTROLDLG(IDC_CREDITS_END_BEGIN, credits_end); + CONTROLDLG(IDC_CREDITS_END_END, credits_end); + + credits_rate = ISDLGSET(IDC_CREDITS_RATE_RADIO); + credits_quant = ISDLGSET(IDC_CREDITS_QUANT_RADIO); + credits_size = ISDLGSET(IDC_CREDITS_SIZE_RADIO); + CONTROLDLG(IDC_CREDITS_RATE, credits_rate); + CONTROLDLG(IDC_CREDITS_QUANTI, credits_quant); + CONTROLDLG(IDC_CREDITS_QUANTP, credits_quant); + CONTROLDLG(IDC_CREDITS_START_SIZE, credits_size); + CONTROLDLG(IDC_CREDITS_END_SIZE, credits_size); + + cpu_force = ISDLGSET(IDC_CPU_FORCE); + CONTROLDLG(IDC_CPU_MMX, cpu_force); + CONTROLDLG(IDC_CPU_MMXEXT, cpu_force); + CONTROLDLG(IDC_CPU_SSE, cpu_force); + CONTROLDLG(IDC_CPU_SSE2, cpu_force); + CONTROLDLG(IDC_CPU_3DNOW, cpu_force); + CONTROLDLG(IDC_CPU_3DNOWEXT, cpu_force); + + // now perform codec mode enable/disable + for (i=0 ; iqmatrix_intra[i], FALSE); - SetDlgItemInt(hDlg, IDC_QINTER00 + i, config->qmatrix_inter[i], FALSE); + EnableWindow(GetDlgItem(hDlg, modes[mode][i]), FALSE); } -} - - -void quant_download(HWND hDlg, CONFIG* config) -{ - int i; - for (i=0 ; i<64 ; ++i) + if (mode != DLG_MODE_2PASS_2_EXT && mode != DLG_MODE_2PASS_2_INT) { - config->qmatrix_intra[i] = config_get_int(hDlg, i + IDC_QINTRA00, config->qmatrix_intra[i]); - CONSTRAINVAL(config->qmatrix_intra[i], 1, 255) - - config->qmatrix_inter[i] = config_get_int(hDlg, i + IDC_QINTER00, config->qmatrix_inter[i]); - CONSTRAINVAL(config->qmatrix_inter[i], 1, 255) + for (i=0 ; ilParam; - - SetWindowLong(hDlg, GWL_USERDATA, (LPARAM)psi); + case DLG_GLOBAL : + SendDlgItemMessage(hDlg, IDC_MOTION, CB_SETCURSEL, config->motion_search, 0); + SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_SETCURSEL, config->quant_type, 0); + SendDlgItemMessage(hDlg, IDC_FOURCC, CB_SETCURSEL, config->fourcc_used, 0); + SetDlgItemInt(hDlg, IDC_MAXKEY, config->max_key_interval, FALSE); + SetDlgItemInt(hDlg, IDC_MINKEY, config->min_key_interval, FALSE); + CheckDlgButton(hDlg, IDC_LUMMASK, config->lum_masking ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_INTERLACING, config->interlacing ? BST_CHECKED : BST_UNCHECKED); +#ifdef BFRAMES + SetDlgItemInt(hDlg, IDC_MAXBFRAMES, config->max_bframes, TRUE); + SetDlgItemInt(hDlg, IDC_BQUANTRATIO, config->bquant_ratio, FALSE); + CheckDlgButton(hDlg, IDC_PACKED, config->packed ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_DX50BVOP, config->dx50bvop ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_DEBUG, config->debug ? BST_CHECKED : BST_UNCHECKED); +#endif + break; + + case DLG_QUANT : + SetDlgItemInt(hDlg, IDC_MINIQUANT, config->min_iquant, FALSE); + SetDlgItemInt(hDlg, IDC_MAXIQUANT, config->max_iquant, FALSE); + SetDlgItemInt(hDlg, IDC_MINPQUANT, config->min_pquant, FALSE); + SetDlgItemInt(hDlg, IDC_MAXPQUANT, config->max_pquant, FALSE); + break; - switch (psi->page) - { - case DLG_MAIN : - SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"1 Pass - CBR"); - SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"1 Pass - quality"); - SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"1 Pass - quantizer"); - SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"2 Pass - 1st pass"); - SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"2 Pass - 2nd pass Ext."); - SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"2 Pass - 2nd pass Int."); - SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"Null - test speed"); - break; + case DLG_2PASS : + SetDlgItemInt(hDlg, IDC_KFBOOST, config->keyframe_boost, FALSE); + CheckDlgButton(hDlg, IDC_DISCARD1PASS, config->discard1pass ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_DUMMY2PASS, config->dummy2pass ? BST_CHECKED : BST_UNCHECKED); +// added by koepi for new 2pass curve treatment + SetDlgItemInt(hDlg, IDC_KFTRESHOLD, config->kftreshold, FALSE); + SetDlgItemInt(hDlg, IDC_KFREDUCTION, config->kfreduction, FALSE); +// end of koepi's additions + SetDlgItemInt(hDlg, IDC_CURVECOMPH, config->curve_compression_high, FALSE); + SetDlgItemInt(hDlg, IDC_CURVECOMPL, config->curve_compression_low, FALSE); + SetDlgItemInt(hDlg, IDC_PAYBACK, config->bitrate_payback_delay, FALSE); + CheckDlgButton(hDlg, IDC_PAYBACKBIAS, (config->bitrate_payback_method == 0)); + CheckDlgButton(hDlg, IDC_PAYBACKPROP, (config->bitrate_payback_method == 1)); - case DLG_ADV : - SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"0 - None"); - SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"1 - Very Low"); - SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"2 - Low"); - SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"3 - Medium"); - SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"4 - High"); - SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"5 - Very High"); - SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"6 - Ultra High"); + CheckDlgButton(hDlg, IDC_HINTEDME, config->hinted_me ? BST_CHECKED : BST_UNCHECKED); + SetDlgItemText(hDlg, IDC_HINTFILE, config->hintfile); + SetDlgItemText(hDlg, IDC_STATS1, config->stats1); + SetDlgItemText(hDlg, IDC_STATS2, config->stats2); + break; - SendDlgItemMessage(hDlg, IDC_QTYPE, CB_ADDSTRING, 0, (LPARAM)"H.263"); - SendDlgItemMessage(hDlg, IDC_QTYPE, CB_ADDSTRING, 0, (LPARAM)"MPEG"); - SendDlgItemMessage(hDlg, IDC_QTYPE, CB_ADDSTRING, 0, (LPARAM)"MPEG-Custom"); + case DLG_2PASSALT : + CheckDlgButton(hDlg, IDC_USEALT, config->use_alt_curve ? BST_CHECKED : BST_UNCHECKED); - SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"XVID"); - SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"DIVX"); - break; + SendDlgItemMessage(hDlg, IDC_CURVETYPE, CB_SETCURSEL, config->alt_curve_type, 0); + SetDlgItemInt(hDlg, IDC_ALTCURVEHIGH, config->alt_curve_high_dist, FALSE); + SetDlgItemInt(hDlg, IDC_ALTCURVELOW, config->alt_curve_low_dist, FALSE); + SetDlgItemInt(hDlg, IDC_MINQUAL, config->alt_curve_min_rel_qual, FALSE); - case DLG_ABOUT : - { - HFONT hFont; - LOGFONT lfData; + CheckDlgButton(hDlg, IDC_USEAUTO, config->alt_curve_use_auto ? BST_CHECKED : BST_UNCHECKED); + SetDlgItemInt(hDlg, IDC_AUTOSTR, config->alt_curve_auto_str, FALSE); - SetDlgItemText(hDlg, IDC_BUILD, __TIME__ ", " __DATE__); - - // - { - char chTemp[64]; - sprintf(chTemp,"Core Version %d.%d",(API_VERSION>>16),(API_VERSION&0xFFFFU)); - SetDlgItemText(hDlg, IDC_CORE_VERSION, chTemp); - } + CheckDlgButton(hDlg, IDC_USEAUTOBONUS, config->alt_curve_use_auto_bonus_bias ? BST_CHECKED : BST_UNCHECKED); + SetDlgItemInt(hDlg, IDC_BONUSBIAS, config->alt_curve_bonus_bias, FALSE); - hFont = (HFONT)SendDlgItemMessage(hDlg, IDC_WEBSITE, WM_GETFONT, 0, 0L); + SetDlgItemInt(hDlg, IDC_MAXBITRATE, config->twopass_max_bitrate / CONFIG_KBPS, FALSE); + SetDlgItemInt(hDlg, IDC_OVERIMP, config->twopass_max_overflow_improvement, FALSE); + SetDlgItemInt(hDlg, IDC_OVERDEG, config->twopass_max_overflow_degradation, FALSE); + break; - if (GetObject(hFont, sizeof(LOGFONT), &lfData)) - { - lfData.lfUnderline = 1; + case DLG_CREDITS : + CheckDlgButton(hDlg, IDC_CREDITS_START, config->credits_start ? BST_CHECKED : BST_UNCHECKED); + SetDlgItemInt(hDlg, IDC_CREDITS_START_BEGIN, config->credits_start_begin, FALSE); + SetDlgItemInt(hDlg, IDC_CREDITS_START_END, config->credits_start_end, FALSE); + CheckDlgButton(hDlg, IDC_CREDITS_END, config->credits_end ? BST_CHECKED : BST_UNCHECKED); + SetDlgItemInt(hDlg, IDC_CREDITS_END_BEGIN, config->credits_end_begin, FALSE); + SetDlgItemInt(hDlg, IDC_CREDITS_END_END, config->credits_end_end, FALSE); - hFont = CreateFontIndirect(&lfData); - if (hFont) - { - SendDlgItemMessage(hDlg, IDC_WEBSITE, WM_SETFONT, (WPARAM)hFont, 1L); - } - } + SetDlgItemInt(hDlg, IDC_CREDITS_RATE, config->credits_rate, FALSE); + SetDlgItemInt(hDlg, IDC_CREDITS_QUANTI, config->credits_quant_i, FALSE); + SetDlgItemInt(hDlg, IDC_CREDITS_QUANTP, config->credits_quant_p, FALSE); + SetDlgItemInt(hDlg, IDC_CREDITS_START_SIZE, config->credits_start_size, FALSE); + SetDlgItemInt(hDlg, IDC_CREDITS_END_SIZE, config->credits_end_size, FALSE); - SetClassLong(GetDlgItem(hDlg, IDC_WEBSITE), GCL_HCURSOR, (LONG)LoadCursor(NULL, IDC_HAND)); - SetDlgItemText(hDlg, IDC_WEBSITE, XVID_WEBSITE); - } + if (config->credits_mode == CREDITS_MODE_RATE) + { + CheckDlgButton(hDlg, IDC_CREDITS_RATE_RADIO, BST_CHECKED); } - - config_upload(hDlg, psi->page, psi->config); - config_mode(hDlg); - break; - - case WM_CTLCOLORSTATIC : - if ((HWND)lParam == GetDlgItem(hDlg, IDC_WEBSITE)) - { - SetBkMode((HDC)wParam, TRANSPARENT) ; - SetTextColor((HDC)wParam, RGB(0x00,0x00,0xc0)); - return (BOOL)GetStockObject(NULL_BRUSH); - } - return FALSE; - - case WM_COMMAND : - if (LOWORD(wParam) == IDC_MODE && HIWORD(wParam) == LBN_SELCHANGE) + else if (config->credits_mode == CREDITS_MODE_QUANT) { - config_mode(hDlg); - config_download(hDlg, psi->page, psi->config); - config_value(hDlg, psi->config); - config_slider(hDlg, psi->config); + CheckDlgButton(hDlg, IDC_CREDITS_QUANT_RADIO, BST_CHECKED); } - else if ((LOWORD(wParam) == IDC_CPU_AUTO || LOWORD(wParam) == IDC_CPU_FORCE) && HIWORD(wParam) == BN_CLICKED) + else // CREDITS_MODE_SIZE { - config_mode(hDlg); + CheckDlgButton(hDlg, IDC_CREDITS_SIZE_RADIO, BST_CHECKED); } - else if (HIWORD(wParam) == EN_UPDATE && LOWORD(wParam) == IDC_VALUE) - { - int value = config_get_int(hDlg, IDC_VALUE, 1); - int max = 1; - - switch (SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0)) - { - default : - case DLG_MODE_CBR : - max = 10000; - break; + break; - case DLG_MODE_VBR_QUAL : - max = 100; - break; + case DLG_CPU : + CheckDlgButton(hDlg, IDC_CPU_MMX, (config->cpu & XVID_CPU_MMX) ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_CPU_MMXEXT, (config->cpu & XVID_CPU_MMXEXT) ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_CPU_SSE, (config->cpu & XVID_CPU_SSE) ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_CPU_SSE2, (config->cpu & XVID_CPU_SSE2) ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_CPU_3DNOW, (config->cpu & XVID_CPU_3DNOW) ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_CPU_3DNOWEXT, (config->cpu & XVID_CPU_3DNOWEXT) ? BST_CHECKED : BST_UNCHECKED); - case DLG_MODE_VBR_QUANT : - max = 31; - break; - } + CheckRadioButton(hDlg, IDC_CPU_AUTO, IDC_CPU_FORCE, + config->cpu & XVID_CPU_FORCE ? IDC_CPU_FORCE : IDC_CPU_AUTO ); - if (value < 1) - { - value = 1; - } - if (value > max) - { - value = max; - SetDlgItemInt(hDlg, IDC_VALUE, value, FALSE); - } +#ifdef _SMP + SetDlgItemInt(hDlg, IDC_NUMTHREADS, config->num_threads, FALSE); +#endif + +#ifdef BFRAMES + SetDlgItemInt(hDlg, IDC_FRAMEDROP, config->frame_drop_ratio, FALSE); +#endif + + SetDlgItemInt(hDlg, IDC_CBR_REACTIONDELAY, config->rc_reaction_delay_factor, FALSE); + SetDlgItemInt(hDlg, IDC_CBR_AVERAGINGPERIOD, config->rc_averaging_period, FALSE); + SetDlgItemInt(hDlg, IDC_CBR_BUFFER, config->rc_buffer, FALSE); + break; + } +} - SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETPOS, TRUE, value); - } - else if ((LOWORD(wParam) == IDC_2PASS_STATS1_BROWSE || LOWORD(wParam) == IDC_2PASS_STATS2_BROWSE) && HIWORD(wParam) == BN_CLICKED) - { - OPENFILENAME ofn; - char tmp[MAX_PATH]; - int hComponent = (LOWORD(wParam) == IDC_2PASS_STATS1_BROWSE ? IDC_2PASS_STATS1 : IDC_2PASS_STATS2 ); - GetDlgItemText(hDlg, hComponent, tmp, MAX_PATH); +/* download config data from dialog + replaces invalid values instead of alerting user for now +*/ - memset(&ofn, 0, sizeof(OPENFILENAME)); - ofn.lStructSize = sizeof(OPENFILENAME); +#define CONSTRAINVAL(X,Y,Z) if((X)<(Y)) X=Y; if((X)>(Z)) X=Z; - ofn.hwndOwner = hDlg; - ofn.lpstrFilter = "bitrate curve (*.stats)\0*.stats\0All files (*.*)\0*.*\0\0"; - ofn.lpstrFile = tmp; - ofn.nMaxFile = MAX_PATH; - ofn.Flags = OFN_PATHMUSTEXIST; +void adv_download(HWND hDlg, int page, CONFIG * config) +{ + switch (page) + { + case DLG_GLOBAL : + config->motion_search = SendDlgItemMessage(hDlg, IDC_MOTION, CB_GETCURSEL, 0, 0); + config->quant_type = SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_GETCURSEL, 0, 0); + config->fourcc_used = SendDlgItemMessage(hDlg, IDC_FOURCC, CB_GETCURSEL, 0, 0); + config->max_key_interval = config_get_uint(hDlg, IDC_MAXKEY, config->max_key_interval); + config->min_key_interval = config_get_uint(hDlg, IDC_MINKEY, config->min_key_interval); + config->lum_masking = ISDLGSET(IDC_LUMMASK); + config->interlacing = ISDLGSET(IDC_INTERLACING); +#ifdef BFRAMES + config->max_bframes = config_get_int(hDlg, IDC_MAXBFRAMES, config->max_bframes); + config->bquant_ratio = config_get_uint(hDlg, IDC_BQUANTRATIO, config->bquant_ratio); + config->packed = ISDLGSET(IDC_PACKED); + config->dx50bvop = ISDLGSET(IDC_DX50BVOP); + config->debug = ISDLGSET(IDC_DEBUG); +#endif + break; + + case DLG_QUANT : + config->min_iquant = config_get_uint(hDlg, IDC_MINIQUANT, config->min_iquant); + config->max_iquant = config_get_uint(hDlg, IDC_MAXIQUANT, config->max_iquant); + config->min_pquant = config_get_uint(hDlg, IDC_MINPQUANT, config->min_pquant); + config->max_pquant = config_get_uint(hDlg, IDC_MAXPQUANT, config->max_pquant); + + CONSTRAINVAL(config->min_iquant, 1, 31); + CONSTRAINVAL(config->max_iquant, config->min_iquant, 31); + CONSTRAINVAL(config->min_pquant, 1, 31); + CONSTRAINVAL(config->max_pquant, config->min_pquant, 31); + break; + + case DLG_2PASS : + config->keyframe_boost = GetDlgItemInt(hDlg, IDC_KFBOOST, NULL, FALSE); +// added by koepi for the new 2pass curve treatment + config->kftreshold = GetDlgItemInt(hDlg, IDC_KFTRESHOLD, NULL, FALSE); + config->kfreduction = GetDlgItemInt(hDlg, IDC_KFREDUCTION, NULL, FALSE); +//end of koepi's additions + config->discard1pass = ISDLGSET(IDC_DISCARD1PASS); + config->dummy2pass = ISDLGSET(IDC_DUMMY2PASS); + config->curve_compression_high = GetDlgItemInt(hDlg, IDC_CURVECOMPH, NULL, FALSE); + config->curve_compression_low = GetDlgItemInt(hDlg, IDC_CURVECOMPL, NULL, FALSE); + config->bitrate_payback_delay = config_get_uint(hDlg, IDC_PAYBACK, config->bitrate_payback_delay); + config->bitrate_payback_method = ISDLGSET(IDC_PAYBACKPROP); + config->hinted_me = ISDLGSET(IDC_HINTEDME); - // display save box for stats1 using 1st-pass - if (LOWORD(wParam) == IDC_2PASS_STATS1_BROWSE && - SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0) == DLG_MODE_2PASS_1) - { - ofn.Flags |= OFN_OVERWRITEPROMPT; - if (GetSaveFileName(&ofn)) - { - SetDlgItemText(hDlg, hComponent, tmp); - } - } - else - { - ofn.Flags |= OFN_FILEMUSTEXIST; - if (GetOpenFileName(&ofn)) { - SetDlgItemText(hDlg, hComponent, tmp); - } - } - } - else if (LOWORD(wParam) == IDC_CREDITS && HIWORD(wParam) == BN_CLICKED) + if (GetDlgItemText(hDlg, IDC_HINTFILE, config->hintfile, MAX_PATH) == 0) { - DialogBoxParam(hInst, MAKEINTRESOURCE(IDD_CREDITS), hDlg, credits_proc, (LPARAM)psi->config); + lstrcpy(config->hintfile, CONFIG_HINTFILE); } - else if (LOWORD(wParam) == IDC_2PASS_INT && HIWORD(wParam) == BN_CLICKED) + if (GetDlgItemText(hDlg, IDC_STATS1, config->stats1, MAX_PATH) == 0) { - DialogBoxParam(hInst, MAKEINTRESOURCE(IDD_2PASS), hDlg, twopass_proc, (LPARAM)psi->config); - } - else if (LOWORD(wParam) == IDC_QUANTMATRIX && HIWORD(wParam) == BN_CLICKED) - { - DialogBoxParam(hInst, MAKEINTRESOURCE(IDD_QUANTMATRIX), hDlg, quantmatrix_proc, (LPARAM)psi->config); + lstrcpy(config->stats1, CONFIG_2PASS_1_FILE); } - else if (LOWORD(wParam) == IDC_WEBSITE && HIWORD(wParam) == STN_CLICKED) + if (GetDlgItemText(hDlg, IDC_STATS2, config->stats2, MAX_PATH) == 0) { - ShellExecute(hDlg, "open", XVID_WEBSITE, NULL, NULL, SW_SHOWNORMAL); + lstrcpy(config->stats2, CONFIG_2PASS_2_FILE); } + + CONSTRAINVAL(config->bitrate_payback_delay, 1, 10000); + CONSTRAINVAL(config->keyframe_boost, 0, 1000); + CONSTRAINVAL(config->curve_compression_high, 0, 100); + CONSTRAINVAL(config->curve_compression_low, 0, 100); break; - case WM_HSCROLL: - if((HWND)lParam == GetDlgItem(hDlg, IDC_SLIDER)) + case DLG_2PASSALT : + config->use_alt_curve = ISDLGSET(IDC_USEALT); + + config->alt_curve_use_auto = ISDLGSET(IDC_USEAUTO); + config->alt_curve_auto_str = config_get_uint(hDlg, IDC_AUTOSTR, config->alt_curve_auto_str); + + config->alt_curve_use_auto_bonus_bias = ISDLGSET(IDC_USEAUTOBONUS); + config->alt_curve_bonus_bias = config_get_uint(hDlg, IDC_BONUSBIAS, config->alt_curve_bonus_bias); + + config->alt_curve_type = SendDlgItemMessage(hDlg, IDC_CURVETYPE, CB_GETCURSEL, 0, 0); + config->alt_curve_high_dist = config_get_uint(hDlg, IDC_ALTCURVEHIGH, config->alt_curve_high_dist); + config->alt_curve_low_dist = config_get_uint(hDlg, IDC_ALTCURVELOW, config->alt_curve_low_dist); + config->alt_curve_min_rel_qual = config_get_uint(hDlg, IDC_MINQUAL, config->alt_curve_min_rel_qual); + + config->twopass_max_bitrate /= CONFIG_KBPS; + config->twopass_max_bitrate = config_get_uint(hDlg, IDC_MAXBITRATE, config->twopass_max_bitrate); + config->twopass_max_bitrate *= CONFIG_KBPS; + config->twopass_max_overflow_improvement = config_get_uint(hDlg, IDC_OVERIMP, config->twopass_max_overflow_improvement); + config->twopass_max_overflow_degradation = config_get_uint(hDlg, IDC_OVERDEG, config->twopass_max_overflow_degradation); + + CONSTRAINVAL(config->twopass_max_overflow_improvement, 1, 80); + CONSTRAINVAL(config->twopass_max_overflow_degradation, 1, 80); + break; + + case DLG_CREDITS : + config->credits_start = ISDLGSET(IDC_CREDITS_START); + config->credits_start_begin = GetDlgItemInt(hDlg, IDC_CREDITS_START_BEGIN, NULL, FALSE); + config->credits_start_end = config_get_uint(hDlg, IDC_CREDITS_START_END, config->credits_start_end); + config->credits_end = ISDLGSET(IDC_CREDITS_END); + config->credits_end_begin = config_get_uint(hDlg, IDC_CREDITS_END_BEGIN, config->credits_end_begin); + config->credits_end_end = config_get_uint(hDlg, IDC_CREDITS_END_END, config->credits_end_end); + + config->credits_rate = config_get_uint(hDlg, IDC_CREDITS_RATE, config->credits_rate); + config->credits_quant_i = config_get_uint(hDlg, IDC_CREDITS_QUANTI, config->credits_quant_i); + config->credits_quant_p = config_get_uint(hDlg, IDC_CREDITS_QUANTP, config->credits_quant_p); + config->credits_start_size = config_get_uint(hDlg, IDC_CREDITS_START_SIZE, config->credits_start_size); + config->credits_end_size = config_get_uint(hDlg, IDC_CREDITS_END_SIZE, config->credits_end_size); + + config->credits_mode = 0; + config->credits_mode = ISDLGSET(IDC_CREDITS_RATE_RADIO) ? CREDITS_MODE_RATE : config->credits_mode; + config->credits_mode = ISDLGSET(IDC_CREDITS_QUANT_RADIO) ? CREDITS_MODE_QUANT : config->credits_mode; + config->credits_mode = ISDLGSET(IDC_CREDITS_SIZE_RADIO) ? CREDITS_MODE_SIZE : config->credits_mode; + + CONSTRAINVAL(config->credits_rate, 1, 100); + CONSTRAINVAL(config->credits_quant_i, 1, 31); + CONSTRAINVAL(config->credits_quant_p, 1, 31); + + if (config->credits_start_begin > config->credits_start_end) { - SetDlgItemInt(hDlg, IDC_VALUE, SendMessage((HWND)lParam, TBM_GETPOS, 0, 0), FALSE); + config->credits_start_begin = config->credits_start_end; + config->credits_start = 0; } - else + if (config->credits_end_begin > config->credits_end_end) { - return 0; + config->credits_end_begin = config->credits_end_end; + config->credits_end = 0; } break; - case WM_NOTIFY : - switch (((NMHDR *)lParam)->code) - { - case PSN_KILLACTIVE : - /* validate */ - config_download(hDlg, psi->page, psi->config); - SetWindowLong(hDlg, DWL_MSGRESULT, FALSE); - break; + case DLG_CPU : + config->cpu = 0; + config->cpu |= ISDLGSET(IDC_CPU_MMX) ? XVID_CPU_MMX : 0; + config->cpu |= ISDLGSET(IDC_CPU_MMXEXT) ? XVID_CPU_MMXEXT: 0; + config->cpu |= ISDLGSET(IDC_CPU_SSE) ? XVID_CPU_SSE: 0; + config->cpu |= ISDLGSET(IDC_CPU_SSE2) ? XVID_CPU_SSE2: 0; + config->cpu |= ISDLGSET(IDC_CPU_3DNOW) ? XVID_CPU_3DNOW: 0; + config->cpu |= ISDLGSET(IDC_CPU_3DNOWEXT) ? XVID_CPU_3DNOWEXT: 0; + config->cpu |= ISDLGSET(IDC_CPU_FORCE) ? XVID_CPU_FORCE : 0; - case PSN_APPLY : - /* apply */ - config_download(hDlg, psi->page, psi->config); - SetWindowLong(hDlg, DWL_MSGRESULT, FALSE); - config_reg_set(psi->config); - psi->config->save = TRUE; - break; - } +#ifdef _SMP + config->num_threads = config_get_uint(hDlg, IDC_NUMTHREADS, config->num_threads); +#endif +#ifdef BFRAMES + config->frame_drop_ratio = config_get_uint(hDlg, IDC_FRAMEDROP, config->frame_drop_ratio); +#endif + + config->rc_reaction_delay_factor = config_get_uint(hDlg, IDC_CBR_REACTIONDELAY, config->rc_reaction_delay_factor); + config->rc_averaging_period = config_get_uint(hDlg, IDC_CBR_AVERAGINGPERIOD, config->rc_averaging_period); + config->rc_buffer = config_get_uint(hDlg, IDC_CBR_BUFFER, config->rc_buffer); break; + } +} - default : - return 0; + +void quant_upload(HWND hDlg, CONFIG* config) +{ + int i; + + for (i=0 ; i<64 ; ++i) + { + SetDlgItemInt(hDlg, IDC_QINTRA00 + i, config->qmatrix_intra[i], FALSE); + SetDlgItemInt(hDlg, IDC_QINTER00 + i, config->qmatrix_inter[i], FALSE); } +} - return 1; + +void quant_download(HWND hDlg, CONFIG* config) +{ + int i; + + for (i=0 ; i<64 ; ++i) + { + int temp; + + temp = config_get_uint(hDlg, i + IDC_QINTRA00, config->qmatrix_intra[i]); + CONSTRAINVAL(temp, 1, 255); + config->qmatrix_intra[i] = temp; + + temp = config_get_uint(hDlg, i + IDC_QINTER00, config->qmatrix_inter[i]); + CONSTRAINVAL(temp, 1, 255); + config->qmatrix_inter[i] = temp; + } +} + + +/* enumerates child windows, assigns tooltips */ + +BOOL CALLBACK enum_tooltips(HWND hWnd, LPARAM lParam) +{ + char help[500]; + + if (LoadString(hInst, GetDlgCtrlID(hWnd), help, 500)) + { + TOOLINFO ti; + + ti.cbSize = sizeof(TOOLINFO); + ti.uFlags = TTF_SUBCLASS | TTF_IDISHWND; + ti.hwnd = GetParent(hWnd); + ti.uId = (LPARAM)hWnd; + ti.lpszText = help; + + SendMessage(hTooltip, TTM_ADDTOOL, 0, (LPARAM)&ti); + } + + return TRUE; } -/* credits dialog proc */ +/* main dialog proc */ -BOOL CALLBACK credits_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) +BOOL CALLBACK main_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) { CONFIG* config = (CONFIG*)GetWindowLong(hDlg, GWL_USERDATA); @@ -836,101 +963,104 @@ config = (CONFIG*)lParam; - CheckDlgButton(hDlg, IDC_CREDITS_START, config->credits_start ? BST_CHECKED : BST_UNCHECKED); - SetDlgItemInt(hDlg, IDC_CREDITS_START_BEGIN, config->credits_start_begin, FALSE); - SetDlgItemInt(hDlg, IDC_CREDITS_START_END, config->credits_start_end, FALSE); - CheckDlgButton(hDlg, IDC_CREDITS_END, config->credits_end ? BST_CHECKED : BST_UNCHECKED); - SetDlgItemInt(hDlg, IDC_CREDITS_END_BEGIN, config->credits_end_begin, FALSE); - SetDlgItemInt(hDlg, IDC_CREDITS_END_END, config->credits_end_end, FALSE); + SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"1 Pass - CBR"); + SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"1 Pass - quality"); + SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"1 Pass - quantizer"); + SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"2 Pass - 1st pass"); + SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"2 Pass - 2nd pass Ext."); + SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"2 Pass - 2nd pass Int."); + SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"Null - test speed"); - SetDlgItemInt(hDlg, IDC_CREDITS_RATE, config->credits_rate, FALSE); - SetDlgItemInt(hDlg, IDC_CREDITS_QUANTI, config->credits_quant_i, FALSE); - SetDlgItemInt(hDlg, IDC_CREDITS_QUANTP, config->credits_quant_p, FALSE); - SetDlgItemInt(hDlg, IDC_CREDITS_START_SIZE, config->credits_start_size, FALSE); - SetDlgItemInt(hDlg, IDC_CREDITS_END_SIZE, config->credits_end_size, FALSE); + SendDlgItemMessage(hDlg, IDC_MODE, CB_SETCURSEL, config->mode, 0); - switch (config->credits_mode) - { - case CREDITS_MODE_RATE : - CheckDlgButton(hDlg, IDC_CREDITS_RATE_RADIO, BST_CHECKED); - break; + InitCommonControls(); - case CREDITS_MODE_QUANT : - CheckDlgButton(hDlg, IDC_CREDITS_QUANT_RADIO, BST_CHECKED); - break; + if (hTooltip = CreateWindow(TOOLTIPS_CLASS, NULL, TTS_ALWAYSTIP, + CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, + NULL, NULL, hInst, NULL)) + { + SetWindowPos(hTooltip, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOMOVE|SWP_NOSIZE|SWP_NOACTIVATE); + SendMessage(hTooltip, TTM_SETDELAYTIME, TTDT_AUTOMATIC, MAKELONG(1500, 0)); + SendMessage(hTooltip, TTM_SETMAXTIPWIDTH, 0, 400); - case CREDITS_MODE_SIZE : - CheckDlgButton(hDlg, IDC_CREDITS_SIZE_RADIO, BST_CHECKED); - break; + EnumChildWindows(hDlg, enum_tooltips, 0); } - credits_controls(hDlg); + main_slider(hDlg, config); + main_value(hDlg, config); + break; + case WM_HSCROLL : + if((HWND)lParam == GetDlgItem(hDlg, IDC_SLIDER)) + { + SetDlgItemInt(hDlg, IDC_VALUE, SendMessage((HWND)lParam, TBM_GETPOS, 0, 0), FALSE); + } + else + { + return 0; + } break; case WM_COMMAND : - if (LOWORD(wParam) == IDCANCEL) + if (LOWORD(wParam) == IDC_MODE && HIWORD(wParam) == LBN_SELCHANGE) { - EndDialog(hDlg, IDCANCEL); + main_download(hDlg, config); + main_slider(hDlg, config); + main_value(hDlg, config); } - else if (HIWORD(wParam) == BN_CLICKED) + else if (LOWORD(wParam) == IDC_ADVANCED && HIWORD(wParam) == BN_CLICKED) { - switch (LOWORD(wParam)) + adv_dialog(hDlg, config); + + if (config->save) { - case IDC_CREDITS_START : - case IDC_CREDITS_END : - case IDC_CREDITS_RATE_RADIO : - case IDC_CREDITS_QUANT_RADIO : - case IDC_CREDITS_SIZE_RADIO : - credits_controls(hDlg); - break; + config_reg_set(config); + } + } + else if (LOWORD(wParam) == IDC_DEFAULTS && HIWORD(wParam) == BN_CLICKED) + { + config_reg_default(config); - case IDOK : - config->credits_start = ISDLGSET(IDC_CREDITS_START); - config->credits_start_begin = config_get_int(hDlg, IDC_CREDITS_START_BEGIN, config->credits_start_begin); - config->credits_start_end = config_get_int(hDlg, IDC_CREDITS_START_END, config->credits_start_end); - config->credits_end = ISDLGSET(IDC_CREDITS_END); - config->credits_end_begin = config_get_int(hDlg, IDC_CREDITS_END_BEGIN, config->credits_end_begin); - config->credits_end_end = config_get_int(hDlg, IDC_CREDITS_END_END, config->credits_end_end); - - config->credits_rate = config_get_int(hDlg, IDC_CREDITS_RATE, config->credits_rate); - config->credits_quant_i = config_get_int(hDlg, IDC_CREDITS_QUANTI, config->credits_quant_i); - config->credits_quant_p = config_get_int(hDlg, IDC_CREDITS_QUANTP, config->credits_quant_p); - config->credits_start_size = config_get_int(hDlg, IDC_CREDITS_START_SIZE, config->credits_start_size); - config->credits_end_size = config_get_int(hDlg, IDC_CREDITS_END_SIZE, config->credits_end_size); + SendDlgItemMessage(hDlg, IDC_MODE, CB_SETCURSEL, config->mode, 0); - if (ISDLGSET(IDC_CREDITS_RATE_RADIO)) - { - config->credits_mode = CREDITS_MODE_RATE; - } - if (ISDLGSET(IDC_CREDITS_QUANT_RADIO)) - { - config->credits_mode = CREDITS_MODE_QUANT; - } - if (ISDLGSET(IDC_CREDITS_SIZE_RADIO)) - { - config->credits_mode = CREDITS_MODE_SIZE; - } + main_slider(hDlg, config); + main_value(hDlg, config); + } + else if (HIWORD(wParam) == EN_UPDATE && LOWORD(wParam) == IDC_VALUE) + { + int value = config_get_uint(hDlg, IDC_VALUE, 1); + int max = 1; - CONSTRAINVAL(config->credits_rate, 1, 100) - CONSTRAINVAL(config->credits_quant_i, 1, 31) - CONSTRAINVAL(config->credits_quant_p, 1, 31) + max = (config->mode == DLG_MODE_CBR) ? 10000 : + ((config->mode == DLG_MODE_VBR_QUAL) ? 100 : + ((config->mode == DLG_MODE_VBR_QUANT) ? 31 : 1<<30)); - if (config->credits_start_begin > config->credits_start_end) - { - config->credits_start_begin = config->credits_start_end; - config->credits_start = 0; - } - if (config->credits_end_begin > config->credits_end_end) - { - config->credits_end_begin = config->credits_end_end; - config->credits_end = 0; - } + if (value < 1) + { + value = 1; + } + if (value > max) + { + value = max; + SetDlgItemInt(hDlg, IDC_VALUE, value, FALSE); + } - EndDialog(hDlg, IDOK); - break; + if (config->mode != DLG_MODE_2PASS_2_INT) + { + SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETPOS, TRUE, value); } } + else if (LOWORD(wParam) == IDOK && HIWORD(wParam) == BN_CLICKED) + { + main_download(hDlg, config); + config->save = TRUE; + EndDialog(hDlg, IDOK); + } + else if (LOWORD(wParam) == IDCANCEL) + { + config->save = FALSE; + EndDialog(hDlg, IDCANCEL); + } break; default : @@ -941,50 +1071,162 @@ } -/* 2-pass dialog proc */ +/* advanced dialog proc */ -BOOL CALLBACK twopass_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) +BOOL CALLBACK adv_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) { - CONFIG* config = (CONFIG*)GetWindowLong(hDlg, GWL_USERDATA); + PROPSHEETINFO *psi; + + psi = (PROPSHEETINFO*)GetWindowLong(hDlg, GWL_USERDATA); switch (uMsg) { case WM_INITDIALOG : - SetWindowLong(hDlg, GWL_USERDATA, lParam); + psi = (PROPSHEETINFO*) ((LPPROPSHEETPAGE)lParam)->lParam; - config = (CONFIG*)lParam; + SetWindowLong(hDlg, GWL_USERDATA, (LPARAM)psi); - SetDlgItemInt(hDlg, IDC_DESIRED, config->desired_size, FALSE); - SetDlgItemInt(hDlg, IDC_KFBOOST, config->keyframe_boost, FALSE); - SetDlgItemInt(hDlg, IDC_MINKEY, config->min_key_interval, FALSE); - SetDlgItemInt(hDlg, IDC_CURVECOMPH, config->curve_compression_high, FALSE); - SetDlgItemInt(hDlg, IDC_CURVECOMPL, config->curve_compression_low, FALSE); - SetDlgItemInt(hDlg, IDC_PAYBACK, config->bitrate_payback_delay, FALSE); - CheckDlgButton(hDlg, IDC_PAYBACKBIAS, (config->bitrate_payback_method == 0)); - CheckDlgButton(hDlg, IDC_PAYBACKPROP, (config->bitrate_payback_method == 1)); + if (psi->page == DLG_GLOBAL) + { + SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"0 - None"); + SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"1 - Very Low"); + SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"2 - Low"); + SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"3 - Medium"); + SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"4 - High"); + SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"5 - Very High"); + SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"6 - Ultra High"); + + SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_ADDSTRING, 0, (LPARAM)"H.263"); + SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_ADDSTRING, 0, (LPARAM)"MPEG"); + SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_ADDSTRING, 0, (LPARAM)"MPEG-Custom"); + SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_ADDSTRING, 0, (LPARAM)"Modulated"); + + SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"XVID"); + SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"DIVX"); + SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"DX50"); + +#ifndef BFRAMES + EnableWindow(GetDlgItem(hDlg, IDC_BSTATIC1), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_BSTATIC2), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_BSTATIC3), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_MAXBFRAMES), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_BQUANTRATIO), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_PACKED), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_DX50BVOP), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_DEBUG), FALSE); +#endif + } + else if (psi->page == DLG_2PASSALT) + { + SendDlgItemMessage(hDlg, IDC_CURVETYPE, CB_ADDSTRING, 0, (LPARAM)"Low"); + SendDlgItemMessage(hDlg, IDC_CURVETYPE, CB_ADDSTRING, 0, (LPARAM)"Medium"); + SendDlgItemMessage(hDlg, IDC_CURVETYPE, CB_ADDSTRING, 0, (LPARAM)"High"); + } + else if (psi->page == DLG_CPU) + { +#ifndef _SMP + + EnableWindow(GetDlgItem(hDlg, IDC_NUMTHREADS_STATIC), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_NUMTHREADS), FALSE); +#endif +#ifndef BFRAMES + EnableWindow(GetDlgItem(hDlg, IDC_FRAMEDROP_STATIC), FALSE); + EnableWindow(GetDlgItem(hDlg, IDC_FRAMEDROP), FALSE); +#endif + } + + if (hTooltip) + { + EnumChildWindows(hDlg, enum_tooltips, 0); + } + + adv_upload(hDlg, psi->page, psi->config); + adv_mode(hDlg, psi->config->mode); break; case WM_COMMAND : - if (LOWORD(wParam) == IDOK && HIWORD(wParam) == BN_CLICKED) + if (HIWORD(wParam) == BN_CLICKED) + { + switch (LOWORD(wParam)) + { + case IDC_HINTEDME : + case IDC_USEALT : + case IDC_USEAUTO : + case IDC_USEAUTOBONUS : + case IDC_CREDITS_START : + case IDC_CREDITS_END : + case IDC_CREDITS_RATE_RADIO : + case IDC_CREDITS_QUANT_RADIO : + case IDC_CREDITS_SIZE_RADIO : + case IDC_CPU_AUTO : + case IDC_CPU_FORCE : + adv_mode(hDlg, psi->config->mode); + break; + } + } + if ((LOWORD(wParam) == IDC_HINT_BROWSE || LOWORD(wParam) == IDC_STATS1_BROWSE || LOWORD(wParam) == IDC_STATS2_BROWSE) && HIWORD(wParam) == BN_CLICKED) { - config->desired_size = config_get_int(hDlg, IDC_DESIRED, config->desired_size); - config->keyframe_boost = GetDlgItemInt(hDlg, IDC_KFBOOST, NULL, FALSE); - config->min_key_interval = config_get_int(hDlg, IDC_MINKEY, config->max_key_interval); - config->curve_compression_high = GetDlgItemInt(hDlg, IDC_CURVECOMPH, NULL, FALSE); - config->curve_compression_low = GetDlgItemInt(hDlg, IDC_CURVECOMPL, NULL, FALSE); - config->bitrate_payback_delay = config_get_int(hDlg, IDC_PAYBACK, config->bitrate_payback_delay); - config->bitrate_payback_method = ISDLGSET(IDC_PAYBACKPROP); - - CONSTRAINVAL(config->bitrate_payback_delay, 1, 10000) - CONSTRAINVAL(config->keyframe_boost, 0, 1000) - CONSTRAINVAL(config->curve_compression_high, 0, 100) - CONSTRAINVAL(config->curve_compression_low, 0, 100) + OPENFILENAME ofn; + char tmp[MAX_PATH]; + int hComponent = (LOWORD(wParam) == IDC_STATS1_BROWSE ? IDC_STATS1 : IDC_STATS2); - EndDialog(hDlg, IDOK); + GetDlgItemText(hDlg, hComponent, tmp, MAX_PATH); + + memset(&ofn, 0, sizeof(OPENFILENAME)); + ofn.lStructSize = sizeof(OPENFILENAME); + + ofn.hwndOwner = hDlg; + ofn.lpstrFilter = "bitrate curve (*.stats)\0*.stats\0All files (*.*)\0*.*\0\0"; + ofn.lpstrFile = tmp; + ofn.nMaxFile = MAX_PATH; + ofn.Flags = OFN_PATHMUSTEXIST; + + if (LOWORD(wParam) == IDC_HINT_BROWSE) + { + ofn.lpstrFilter = "motion hints (*.mvh)\0*.mvh\0All files (*.*)\0*.*\0\0"; + if (GetOpenFileName(&ofn)) + { + SetDlgItemText(hDlg, IDC_HINTFILE, tmp); + } + } + else if (LOWORD(wParam) == IDC_STATS1_BROWSE && + psi->config->mode == DLG_MODE_2PASS_1) + { + ofn.Flags |= OFN_OVERWRITEPROMPT; + if (GetSaveFileName(&ofn)) + { + SetDlgItemText(hDlg, hComponent, tmp); + } + } + else + { + ofn.Flags |= OFN_FILEMUSTEXIST; + if (GetOpenFileName(&ofn)) { + SetDlgItemText(hDlg, hComponent, tmp); + } + } } - else if (LOWORD(wParam) == IDCANCEL) + else if (LOWORD(wParam) == IDC_QUANTMATRIX && HIWORD(wParam) == BN_CLICKED) { - EndDialog(hDlg, IDCANCEL); + DialogBoxParam(hInst, MAKEINTRESOURCE(IDD_QUANTMATRIX), hDlg, quantmatrix_proc, (LPARAM)psi->config); + } + break; + + case WM_NOTIFY : + switch (((NMHDR *)lParam)->code) + { + case PSN_KILLACTIVE : + /* validate */ + adv_download(hDlg, psi->page, psi->config); + SetWindowLong(hDlg, DWL_MSGRESULT, FALSE); + break; + + case PSN_APPLY : + /* apply */ + adv_download(hDlg, psi->page, psi->config); + SetWindowLong(hDlg, DWL_MSGRESULT, FALSE); + psi->config->save = TRUE; + break; } break; @@ -1006,17 +1248,19 @@ { case WM_INITDIALOG : SetWindowLong(hDlg, GWL_USERDATA, lParam); - config = (CONFIG*)lParam; - quant_upload(hDlg, config); + + if (hTooltip) + { + EnumChildWindows(hDlg, enum_tooltips, 0); + } break; case WM_COMMAND : if (LOWORD(wParam) == IDOK && HIWORD(wParam) == BN_CLICKED) { quant_download(hDlg, config); - EndDialog(hDlg, IDOK); } else if (LOWORD(wParam) == IDCANCEL) @@ -1055,13 +1299,13 @@ if (hFile == INVALID_HANDLE_VALUE) { - DEBUG("Couldn't save quant matrix"); + DEBUGERR("Couldn't save quant matrix"); } else { if (!WriteFile(hFile, quant_data, 128, &wrote, 0)) { - DEBUG("Couldnt write quant matrix"); + DEBUGERR("Couldnt write quant matrix"); } } @@ -1077,13 +1321,13 @@ if (hFile == INVALID_HANDLE_VALUE) { - DEBUG("Couldn't load quant matrix"); + DEBUGERR("Couldn't load quant matrix"); } else { if (!ReadFile(hFile, quant_data, 128, &read, 0)) { - DEBUG("Couldnt read quant matrix"); + DEBUGERR("Couldnt read quant matrix"); } else { @@ -1105,3 +1349,69 @@ return 1; } + + +/* about dialog proc */ + +BOOL CALLBACK about_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) +{ + switch (uMsg) + { + case WM_INITDIALOG : + { + XVID_INIT_PARAM init_param; + char core[100]; + HFONT hFont; + LOGFONT lfData; + + SetDlgItemText(hDlg, IDC_BUILD, XVID_BUILD); + + init_param.cpu_flags = XVID_CPU_CHKONLY; + xvid_init(NULL, 0, &init_param, 0); + wsprintf(core, "Core Version %d.%d", (init_param.api_version>>16),(init_param.api_version&0xFFFFU)); + SetDlgItemText(hDlg, IDC_CORE, core); + + hFont = (HFONT)SendDlgItemMessage(hDlg, IDC_WEBSITE, WM_GETFONT, 0, 0L); + + if (GetObject(hFont, sizeof(LOGFONT), &lfData)) + { + lfData.lfUnderline = 1; + + hFont = CreateFontIndirect(&lfData); + if (hFont) + { + SendDlgItemMessage(hDlg, IDC_WEBSITE, WM_SETFONT, (WPARAM)hFont, 1L); + } + } + + SetClassLong(GetDlgItem(hDlg, IDC_WEBSITE), GCL_HCURSOR, (LONG)LoadCursor(NULL, IDC_HAND)); + SetDlgItemText(hDlg, IDC_WEBSITE, XVID_WEBSITE); + } + break; + + case WM_CTLCOLORSTATIC : + if ((HWND)lParam == GetDlgItem(hDlg, IDC_WEBSITE)) + { + SetBkMode((HDC)wParam, TRANSPARENT) ; + SetTextColor((HDC)wParam, RGB(0x00,0x00,0xc0)); + return (BOOL)GetStockObject(NULL_BRUSH); + } + return 0; + + case WM_COMMAND : + if (LOWORD(wParam) == IDC_WEBSITE && HIWORD(wParam) == STN_CLICKED) + { + ShellExecute(hDlg, "open", XVID_WEBSITE, NULL, NULL, SW_SHOWNORMAL); + } + else if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL) + { + EndDialog(hDlg, LOWORD(wParam)); + } + break; + + default : + return 0; + } + + return 1; +}