--- branches/dev-api-3/vfw/src/config.c 2002/12/14 06:07:03 715 +++ branches/dev-api-3/vfw/src/config.c 2002/12/14 06:09:33 716 @@ -103,6 +103,7 @@ {"packed", ®.packed, 0}, {"dx50bvop", ®.dx50bvop, 1}, {"debug", ®.debug, 0}, + {"reduced_resolution", ®.reduced_resolution, 0}, {"frame_drop_ratio", ®.frame_drop_ratio, 0}, {"min_iquant", ®.min_iquant, 2}, @@ -151,7 +152,11 @@ {"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} + {"credits_end_size", ®.credits_end_size, 10000}, + + /* decoder */ + {"deblock_y", ®.deblock_y, 0}, + {"deblock_uv", ®.deblock_uv, 0} }; REG_STR const reg_strs[] = { @@ -654,6 +659,8 @@ 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); + + CheckDlgButton(hDlg, IDC_REDUCED, config->reduced_resolution ? BST_CHECKED : BST_UNCHECKED); break; case DLG_QUANT : @@ -787,6 +794,7 @@ config->packed = ISDLGSET(IDC_PACKED); config->dx50bvop = ISDLGSET(IDC_DX50BVOP); config->debug = ISDLGSET(IDC_DEBUG); + config->reduced_resolution = ISDLGSET(IDC_REDUCED); break; case DLG_QUANT : @@ -972,6 +980,134 @@ } + +/* --- decoder options dialog --- */ + +#define DEC_DLG_COUNT 1 +#define DEC_DLG_POSTPROC 0 + +/* decoder dialog: upload config data */ + +void dec_upload(HWND hDlg, int page, CONFIG * config) +{ + switch (page) + { + case DEC_DLG_POSTPROC : + CheckDlgButton(hDlg, IDC_DEBLOCK_Y, config->deblock_y ? BST_CHECKED : BST_UNCHECKED); + CheckDlgButton(hDlg, IDC_DEBLOCK_UV, config->deblock_uv ? BST_CHECKED : BST_UNCHECKED); + break; + } +} + + +/* dec dialog: download config data */ + +void dec_download(HWND hDlg, int page, CONFIG * config) +{ + switch (page) + { + case DEC_DLG_POSTPROC : + config->deblock_y = ISDLGSET(IDC_DEBLOCK_Y); + config->deblock_uv = ISDLGSET(IDC_DEBLOCK_UV); + break; + } +} + +/* decoder dialog proc */ + +BOOL CALLBACK dec_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam) +{ + PROPSHEETINFO *psi; + + psi = (PROPSHEETINFO*)GetWindowLong(hDlg, GWL_USERDATA); + + switch (uMsg) + { + case WM_INITDIALOG : + psi = (PROPSHEETINFO*) ((LPPROPSHEETPAGE)lParam)->lParam; + + SetWindowLong(hDlg, GWL_USERDATA, (LPARAM)psi); + + if (hTooltip) + { + EnumChildWindows(hDlg, enum_tooltips, 0); + } + + dec_upload(hDlg, psi->page, psi->config); + break; + + case WM_NOTIFY : + switch (((NMHDR *)lParam)->code) + { + case PSN_KILLACTIVE : + /* validate */ + dec_download(hDlg, psi->page, psi->config); + SetWindowLong(hDlg, DWL_MSGRESULT, FALSE); + break; + + case PSN_APPLY : + /* apply */ + dec_download(hDlg, psi->page, psi->config); + SetWindowLong(hDlg, DWL_MSGRESULT, FALSE); + psi->config->save = TRUE; + break; + } + break; + + default : + return 0; + } + + return 1; +} + + +void dec_dialog(HWND hParent, CONFIG * config) +{ + PROPSHEETINFO psi[DEC_DLG_COUNT]; + PROPSHEETPAGE psp[DEC_DLG_COUNT]; + PROPSHEETHEADER psh; + CONFIG temp; + int i; + + config->save = FALSE; + memcpy(&temp, config, sizeof(CONFIG)); + + for (i=0 ; isave) + { + config_reg_set(config); + } + } else if (LOWORD(wParam) == IDC_DEFAULTS && HIWORD(wParam) == BN_CLICKED) { config_reg_default(config); @@ -1127,6 +1272,9 @@ 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"); + + /* XXX: reduced resolution is not ready for prime-time */ + ShowWindow(GetDlgItem(hDlg, IDC_REDUCED), SW_HIDE); } else if (psi->page == DLG_2PASSALT) {