[svn] / trunk / xvidcore / vfw / src / config.c Repository:
ViewVC logotype

Annotation of /trunk/xvidcore/vfw/src/config.c

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1440 - (view) (download)

1 : edgomez 1382 /**************************************************************************
2 :     *
3 :     * XVID VFW FRONTEND
4 :     * config
5 :     *
6 :     * This program is free software; you can redistribute it and/or modify
7 :     * it under the terms of the GNU General Public License as published by
8 :     * the Free Software Foundation; either version 2 of the License, or
9 :     * (at your option) any later version.
10 :     *
11 :     * This program is distributed in the hope that it will be useful,
12 :     * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 :     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 :     * GNU General Public License for more details.
15 :     *
16 :     * You should have received a copy of the GNU General Public License
17 :     * along with this program; if not, write to the Free Software
18 :     * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19 :     *
20 :     *************************************************************************/
21 :    
22 :     /**************************************************************************
23 :     *
24 :     * History:
25 :     *
26 :     * 15.06.2002 added bframes options
27 :     * 21.04.2002 fixed custom matrix support, tried to get dll size down
28 :     * 17.04.2002 re-enabled lumi masking in 1st pass
29 :     * 15.04.2002 updated cbr support
30 :     * 07.04.2002 min keyframe interval checkbox
31 :     * 2-pass max bitrate and overflow customization
32 :     * 04.04.2002 interlacing support
33 :     * hinted ME support
34 :     * 24.03.2002 daniel smith <danielsmith@astroboymail.com>
35 :     * added Foxer's new CBR engine
36 :     * - cbr_buffer is being used as reaction delay (quick hack)
37 :     * 23.03.2002 daniel smith <danielsmith@astroboymail.com>
38 :     * added load defaults button
39 :     * merged foxer's alternative 2-pass code (2-pass alt tab)
40 :     * added proper tooltips
41 :     * moved registry data into reg_ints/reg_strs arrays
42 :     * added DEBUGERR output on errors instead of returning
43 :     * 16.03.2002 daniel smith <danielsmith@astroboymail.com>
44 :     * rewrote/restructured most of file
45 :     * added tooltips (kind of - dirty message hook method)
46 :     * split tabs into a main dialog / advanced prop sheet
47 :     * advanced controls are now enabled/disabled by mode
48 :     * added modulated quantization, DX50 fourcc
49 :     * 11.03.2002 Min Chen <chenm001@163.com>
50 :     * now get Core Version use xvid_init()
51 :     * 05.03.2002 Min Chen <chenm001@163.com>
52 :     * Add Core version display to about box
53 :     * 01.12.2001 inital version; (c)2001 peter ross <pross@xvid.org>
54 :     *
55 :     *************************************************************************/
56 :    
57 :    
58 :     #include <windows.h>
59 :     #include <commctrl.h>
60 :     #include <stdio.h> /* sprintf */
61 :     #include <xvid.h> /* XviD API */
62 :    
63 :     #include "debug.h"
64 :     #include "config.h"
65 :     #include "resource.h"
66 :    
67 :    
68 :     #define CONSTRAINVAL(X,Y,Z) if((X)<(Y)) X=Y; if((X)>(Z)) X=Z;
69 :     #define IsDlgChecked(hwnd,idc) (IsDlgButtonChecked(hwnd,idc) == BST_CHECKED)
70 :     #define CheckDlg(hwnd,idc,value) CheckDlgButton(hwnd,idc, value?BST_CHECKED:BST_UNCHECKED)
71 :     #define EnableDlgWindow(hwnd,idc,state) EnableWindow(GetDlgItem(hwnd,idc),state)
72 :    
73 :     static void zones_update(HWND hDlg, CONFIG * config);
74 :    
75 :     HINSTANCE g_hInst;
76 :     HWND g_hTooltip;
77 :    
78 :     static int g_use_bitrate = 1;
79 :    
80 :    
81 : syskin 1437 int pp_brightness, pp_dy, pp_duv, pp_fe, pp_dry, pp_druv; /* decoder options */
82 : edgomez 1382
83 :     /* enumerates child windows, assigns tooltips */
84 :     BOOL CALLBACK enum_tooltips(HWND hWnd, LPARAM lParam)
85 :     {
86 :     char help[500];
87 :    
88 :     if (LoadString(g_hInst, GetDlgCtrlID(hWnd), help, 500))
89 :     {
90 :     TOOLINFO ti;
91 :     ti.cbSize = sizeof(TOOLINFO);
92 :     ti.uFlags = TTF_SUBCLASS | TTF_IDISHWND;
93 :     ti.hwnd = GetParent(hWnd);
94 :     ti.uId = (LPARAM)hWnd;
95 :     ti.lpszText = help;
96 :     SendMessage(g_hTooltip, TTM_ADDTOOL, 0, (LPARAM)&ti);
97 :     }
98 :    
99 :     return TRUE;
100 :     }
101 :    
102 :    
103 :     /* ===================================================================================== */
104 :     /* MPEG-4 PROFILES/LEVELS ============================================================== */
105 :     /* ===================================================================================== */
106 :    
107 :    
108 :    
109 :     /* default vbv_occupancy is (64/170)*vbv_buffer_size */
110 :    
111 :     const profile_t profiles[] =
112 :     {
113 :     /* name p@l, w h fps obj Tvmv vmv vcv ac% vbv pkt kbps flags */
114 :     { "Simple @ L0", 0x08, 176, 144, 15, 1, 198, 99, 1485, 100, 10*16368, 2048, 64, 0 },
115 :     /* simple@l0: max f_code=1, intra_dc_vlc_threshold=0 */
116 :     /* if ac preidition is used, adaptive quantization must not be used */
117 :     /* <=qcif must be used */
118 :     { "Simple @ L1", 0x01, 176, 144, 15, 4, 198, 99, 1485, 100, 10*16368, 2048, 64, PROFILE_ADAPTQUANT },
119 :     { "Simple @ L2", 0x02, 352, 288, 15, 4, 792, 396, 5940, 100, 40*16368, 4096, 128, PROFILE_ADAPTQUANT },
120 :     { "Simple @ L3", 0x03, 352, 288, 15, 4, 792, 396, 11880, 100, 40*16368, 8192, 384, PROFILE_ADAPTQUANT },
121 :    
122 :     { "ARTS @ L1", 0x91, 176, 144, 15, 4, 198, 99, 1485, 100, 10*16368, 8192, 64, PROFILE_ARTS },
123 :     { "ARTS @ L2", 0x92, 352, 288, 15, 4, 792, 396, 5940, 100, 40*16368, 16384, 128, PROFILE_ARTS },
124 :     { "ARTS @ L3", 0x93, 352, 288, 30, 4, 792, 396, 11880, 100, 40*16368, 16384, 384, PROFILE_ARTS },
125 :     { "ARTS @ L4", 0x94, 352, 288, 30, 16, 792, 396, 11880, 100, 80*16368, 16384, 2000, PROFILE_ARTS },
126 :    
127 :     { "AS @ L0", 0xf0, 176, 144, 30, 1, 297, 99, 2970, 100, 10*16368, 2048, 128, PROFILE_AS },
128 :     { "AS @ L1", 0xf1, 176, 144, 30, 4, 297, 99, 2970, 100, 10*16368, 2048, 128, PROFILE_AS },
129 :     { "AS @ L2", 0xf2, 352, 288, 15, 4, 1188, 396, 5940, 100, 40*16368, 4096, 384, PROFILE_AS },
130 :     { "AS @ L3", 0xf3, 352, 288, 30, 4, 1188, 396, 11880, 100, 40*16368, 4096, 768, PROFILE_AS },
131 :     /* ISMA Profile 1, (ASP) @ L3b (CIF, 1.5 Mb/s) CIF(352x288), 30fps, 1.5Mbps max ??? */
132 :     { "AS @ L4", 0xf4, 352, 576, 30, 4, 2376, 792, 23760, 50, 80*16368, 8192, 3000, PROFILE_AS },
133 :     { "AS @ L5", 0xf5, 720, 576, 30, 4, 4860, 1620, 48600, 25, 112*16368, 16384, 8000, PROFILE_AS },
134 :    
135 :     #ifdef DXN_PROFILES
136 :     { "DXN Handheld", 0x00, 176, 144, 15, -1, 198, 99, 1485, 100, 16*16368, -1, 128, PROFILE_ADAPTQUANT },
137 :     { "DXN Portable NTSC", 0x00, 352, 240, 30, -1, 990, 330, 9900, 100, 64*16368, -1, 768, PROFILE_ADAPTQUANT|PROFILE_BVOP },
138 :     { "DXN Portable PAL", 0x00, 352, 288, 25, -1, 1188, 396, 9900, 100, 64*16368, -1, 768, PROFILE_ADAPTQUANT|PROFILE_BVOP },
139 :     { "DXN HT NTSC", 0x00, 720, 480, 30, -1, 4050, 1350, 40500, 100, 192*16368, -1, 4000, PROFILE_ADAPTQUANT|PROFILE_BVOP|PROFILE_INTERLACE },
140 :     { "DXN HT PAL", 0x00, 720, 576, 25, -1, 4860, 1620, 40500, 100, 192*16368, -1, 4000, PROFILE_ADAPTQUANT|PROFILE_BVOP|PROFILE_INTERLACE },
141 :     { "DXN HDTV", 0x00, 1280, 720, 30, -1,10800, 3600, 108000, 100, 384*16368, -1, 8000, PROFILE_ADAPTQUANT|PROFILE_BVOP|PROFILE_INTERLACE },
142 :     #endif
143 :    
144 :     { "(unrestricted)", 0x00, 0, 0, 0, 0, 0, 0, 0, 100, 0*16368, 0, 0, 0xffffffff },
145 :     };
146 :    
147 :    
148 :     typedef struct {
149 :     char * name;
150 :     float value;
151 :     } named_float_t;
152 :    
153 :     static const named_float_t video_fps_list[] = {
154 :     { "15.0", 15.0F },
155 :     { "23.976 (FILM)", 23.976F },
156 :     { "25.0 (PAL)", 25.0F },
157 :     { "29.97 (NTSC)", 29.970F },
158 :     { "30.0", 30.0F },
159 :     { "50.0 (HD PAL)", 50.0F },
160 :     { "59.94 (HD NTSC)", 59.940F },
161 :     { "60.0", 60.0F },
162 :     };
163 :    
164 :    
165 :     typedef struct {
166 :     char * name;
167 :     int avi_interval; /* audio overhead intervals (milliseconds) */
168 :     float mkv_multiplier; /* mkv multiplier */
169 :     } named_int_t;
170 :    
171 :    
172 :     #define NO_AUDIO 5
173 :     static const named_int_t audio_type_list[] = {
174 :     { "MP3-CBR", 1000, 48000/1152/6 },
175 :     { "MP3-VBR", 24, 48000/1152/6 },
176 :     { "OGG", /*?*/1000, 48000*(0.7F/1024 + 0.3F/180) },
177 :     { "AC3", 64, 48000/1536/6 },
178 :     { "DTS", 21, /*?*/48000/1152/6 },
179 :     { "(None)", 0, 0 },
180 :     };
181 :    
182 :    
183 :     /* ===================================================================================== */
184 :     /* REGISTRY ============================================================================ */
185 :     /* ===================================================================================== */
186 :    
187 :     /* registry info structs */
188 :     CONFIG reg;
189 :    
190 :     static const REG_INT reg_ints[] = {
191 :     {"mode", &reg.mode, RC_MODE_1PASS},
192 :     {"bitrate", &reg.bitrate, 700},
193 :     {"desired_size", &reg.desired_size, 570000},
194 :     {"use_2pass_bitrate", &reg.use_2pass_bitrate, 0},
195 :     {"desired_quant", &reg.desired_quant, DEFAULT_QUANT}, /* 100-base float */
196 :    
197 :     /* profile */
198 :     {"quant_type", &reg.quant_type, 0},
199 :     {"lum_masking", &reg.lum_masking, 0},
200 :     {"interlacing", &reg.interlacing, 0},
201 :     {"qpel", &reg.qpel, 0},
202 :     {"gmc", &reg.gmc, 0},
203 :     {"reduced_resolution", &reg.reduced_resolution, 0},
204 :     {"use_bvop", &reg.use_bvop, 1},
205 :     {"max_bframes", &reg.max_bframes, 2},
206 :     {"bquant_ratio", &reg.bquant_ratio, 150}, /* 100-base float */
207 :     {"bquant_offset", &reg.bquant_offset, 100}, /* 100-base float */
208 :     {"packed", &reg.packed, 1},
209 :     {"closed_gov", &reg.closed_gov, 1},
210 :    
211 :     /* aspect ratio */
212 :     {"ar_mode", &reg.ar_mode, 0},
213 :     {"aspect_ratio", &reg.display_aspect_ratio, 0},
214 :     {"par_x", &reg.par_x, 1},
215 :     {"par_y", &reg.par_y, 1},
216 :     {"ar_x", &reg.ar_x, 4},
217 :     {"ar_y", &reg.ar_y, 3},
218 :    
219 :     /* zones */
220 :     {"num_zones", &reg.num_zones, 1},
221 :    
222 :     /* single pass */
223 :     {"rc_reaction_delay_factor",&reg.rc_reaction_delay_factor, 16},
224 :     {"rc_averaging_period", &reg.rc_averaging_period, 100},
225 :     {"rc_buffer", &reg.rc_buffer, 100},
226 :    
227 :     /* 2pass1 */
228 :     {"discard1pass", &reg.discard1pass, 1},
229 :     {"full1pass", &reg.full1pass, 0},
230 :    
231 :     /* 2pass2 */
232 :     {"keyframe_boost", &reg.keyframe_boost, 10},
233 :     {"kfreduction", &reg.kfreduction, 20},
234 :     {"kfthreshold", &reg.kfthreshold, 1},
235 :     {"curve_compression_high", &reg.curve_compression_high, 0},
236 :     {"curve_compression_low", &reg.curve_compression_low, 0},
237 :     {"overflow_control_strength", &reg.overflow_control_strength, 5},
238 :     {"twopass_max_overflow_improvement", &reg.twopass_max_overflow_improvement, 5},
239 :     {"twopass_max_overflow_degradation", &reg.twopass_max_overflow_degradation, 5},
240 :    
241 :     /* bitrate calculator */
242 :     {"container_type", &reg.container_type, 1},
243 :     {"target_size", &reg.target_size, 650 * 1024},
244 :     {"subtitle_size", &reg.subtitle_size, 0},
245 :     {"hours", &reg.hours, 1},
246 :     {"minutes", &reg.minutes, 30},
247 :     {"seconds", &reg.seconds, 0},
248 :     {"fps", &reg.fps, 2},
249 :     {"audio_mode", &reg.audio_mode, 0},
250 :     {"audio_type", &reg.audio_type, 0},
251 :     {"audio_rate", &reg.audio_rate, 128},
252 :     {"audio_size", &reg.audio_size, 0},
253 :    
254 :     /* motion */
255 :     {"motion_search", &reg.motion_search, 6},
256 :     {"vhq_mode", &reg.vhq_mode, 1},
257 :     {"chromame", &reg.chromame, 1},
258 :     {"cartoon_mode", &reg.cartoon_mode, 0},
259 :     {"turbo", &reg.turbo, 0},
260 :     {"max_key_interval", &reg.max_key_interval, 300},
261 :     {"frame_drop_ratio", &reg.frame_drop_ratio, 0},
262 :    
263 :     /* quant */
264 :     {"min_iquant", &reg.min_iquant, 1},
265 :     {"max_iquant", &reg.max_iquant, 31},
266 :     {"min_pquant", &reg.min_pquant, 1},
267 :     {"max_pquant", &reg.max_pquant, 31},
268 :     {"min_bquant", &reg.min_bquant, 1},
269 :     {"max_bquant", &reg.max_bquant, 31},
270 :     {"trellis_quant", &reg.trellis_quant, 0},
271 :    
272 :     /* debug */
273 :     {"fourcc_used", &reg.fourcc_used, 0},
274 :     {"debug", &reg.debug, 0x0},
275 :     {"vop_debug", &reg.vop_debug, 0},
276 :     {"display_status", &reg.display_status, 1},
277 :    
278 :     /* decoder, shared with dshow */
279 : suxen_drol 1397 {"Brightness", &pp_brightness, 0},
280 : edgomez 1382 {"Deblock_Y", &pp_dy, 0},
281 :     {"Deblock_UV", &pp_duv, 0},
282 : syskin 1437 {"Dering_Y", &pp_dry, 0},
283 :     {"Dering_UV", &pp_druv, 0},
284 : edgomez 1382 {"FilmEffect", &pp_fe, 0},
285 :    
286 :     };
287 :    
288 :     static const REG_STR reg_strs[] = {
289 :     {"profile", reg.profile_name, "AS @ L5"},
290 :     {"stats", reg.stats, CONFIG_2PASS_FILE},
291 :     };
292 :    
293 :    
294 :     zone_t stmp;
295 :     static const REG_INT reg_zone[] = {
296 :     {"zone%i_frame", &stmp.frame, 0},
297 :     {"zone%i_mode", &stmp.mode, RC_ZONE_WEIGHT},
298 :     {"zone%i_weight", &stmp.weight, 100}, /* 100-base float */
299 :     {"zone%i_quant", &stmp.quant, 500}, /* 100-base float */
300 :     {"zone%i_type", &stmp.type, XVID_TYPE_AUTO},
301 :     {"zone%i_greyscale", &stmp.greyscale, 0},
302 :     {"zone%i_chroma_opt", &stmp.chroma_opt, 0},
303 :     {"zone%i_bvop_threshold", &stmp.bvop_threshold, 0},
304 :     };
305 :    
306 :     static const BYTE default_qmatrix_intra[] = {
307 :     8, 17,18,19,21,23,25,27,
308 :     17,18,19,21,23,25,27,28,
309 :     20,21,22,23,24,26,28,30,
310 :     21,22,23,24,26,28,30,32,
311 :     22,23,24,26,28,30,32,35,
312 :     23,24,26,28,30,32,35,38,
313 :     25,26,28,30,32,35,38,41,
314 :     27,28,30,32,35,38,41,45
315 :     };
316 :    
317 :     static const BYTE default_qmatrix_inter[] = {
318 :     16,17,18,19,20,21,22,23,
319 :     17,18,19,20,21,22,23,24,
320 :     18,19,20,21,22,23,24,25,
321 :     19,20,21,22,23,24,26,27,
322 :     20,21,22,23,25,26,27,28,
323 :     21,22,23,24,26,27,28,30,
324 :     22,23,24,26,27,28,30,31,
325 :     23,24,25,27,28,30,31,33
326 :     };
327 :    
328 :    
329 :    
330 :     #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)));}
331 :    
332 :     #define XVID_DLL_NAME "xvidcore.dll"
333 :    
334 :     void config_reg_get(CONFIG * config)
335 :     {
336 :     char tmp[32];
337 :     HKEY hKey;
338 :     DWORD size;
339 :     int i,j;
340 :     xvid_gbl_info_t info;
341 :     HINSTANCE m_hdll;
342 :    
343 :     memset(&info, 0, sizeof(info));
344 :     info.version = XVID_VERSION;
345 :    
346 :     m_hdll = LoadLibrary(XVID_DLL_NAME);
347 :     if (m_hdll != NULL) {
348 :    
349 :     ((int (__cdecl *)(void *, int, void *, void *))GetProcAddress(m_hdll, "xvid_global"))
350 :     (0, XVID_GBL_INFO, &info, NULL);
351 :    
352 :     FreeLibrary(m_hdll);
353 :     }
354 :    
355 :     reg.cpu = info.cpu_flags;
356 :     reg.num_threads = info.num_threads;
357 :    
358 :     RegOpenKeyEx(XVID_REG_KEY, XVID_REG_PARENT "\\" XVID_REG_CHILD, 0, KEY_READ, &hKey);
359 :    
360 :     /* read integer values */
361 :     for (i=0 ; i<sizeof(reg_ints)/sizeof(REG_INT); i++) {
362 :     size = sizeof(int);
363 :     if (RegQueryValueEx(hKey, reg_ints[i].reg_value, 0, 0, (LPBYTE)reg_ints[i].config_int, &size) != ERROR_SUCCESS) {
364 :     *reg_ints[i].config_int = reg_ints[i].def;
365 :     }
366 :     }
367 :    
368 :     /* read string values */
369 :     for (i=0 ; i<sizeof(reg_strs)/sizeof(REG_STR); i++) {
370 :     size = MAX_PATH;
371 :     if (RegQueryValueEx(hKey, reg_strs[i].reg_value, 0, 0, (LPBYTE)reg_strs[i].config_str, &size) != ERROR_SUCCESS) {
372 :     memcpy(reg_strs[i].config_str, reg_strs[i].def, MAX_PATH);
373 :     }
374 :     }
375 :    
376 :     reg.profile = 0;
377 :     for (i=0; i<sizeof(profiles)/sizeof(profile_t); i++) {
378 :     if (lstrcmpi(profiles[i].name, reg.profile_name) == 0) {
379 :     reg.profile = i;
380 :     }
381 :     }
382 :    
383 :     memcpy(config, &reg, sizeof(CONFIG));
384 :    
385 :    
386 :     /* read quant matrices */
387 :     REG_GET_B("qmatrix_intra", config->qmatrix_intra, default_qmatrix_intra);
388 :     REG_GET_B("qmatrix_inter", config->qmatrix_inter, default_qmatrix_inter);
389 :    
390 :    
391 :     /* read zones */
392 :     if (config->num_zones>MAX_ZONES) {
393 :     config->num_zones=MAX_ZONES;
394 :     }else if (config->num_zones<=0) {
395 :     config->num_zones = 1;
396 :     }
397 :    
398 :     for (i=0; i<config->num_zones; i++) {
399 :     for (j=0; j<sizeof(reg_zone)/sizeof(REG_INT); j++) {
400 :     size = sizeof(int);
401 :    
402 :     wsprintf(tmp, reg_zone[j].reg_value, i);
403 :     if (RegQueryValueEx(hKey, tmp, 0, 0, (LPBYTE)reg_zone[j].config_int, &size) != ERROR_SUCCESS)
404 :     *reg_zone[j].config_int = reg_zone[j].def;
405 :     }
406 :    
407 :     memcpy(&config->zones[i], &stmp, sizeof(zone_t));
408 :     }
409 :    
410 :     RegCloseKey(hKey);
411 :     }
412 :    
413 :    
414 :     /* put config settings in registry */
415 :    
416 :     #define REG_SET_B(X, Y) RegSetValueEx(hKey, X, 0, REG_BINARY, Y, sizeof((Y)))
417 :    
418 :     void config_reg_set(CONFIG * config)
419 :     {
420 :     char tmp[64];
421 :     HKEY hKey;
422 :     DWORD dispo;
423 :     int i,j;
424 :    
425 :     if (RegCreateKeyEx(
426 :     XVID_REG_KEY,
427 :     XVID_REG_PARENT "\\" XVID_REG_CHILD,
428 :     0,
429 :     XVID_REG_CLASS,
430 :     REG_OPTION_NON_VOLATILE,
431 :     KEY_WRITE,
432 :     0,
433 :     &hKey,
434 :     &dispo) != ERROR_SUCCESS)
435 :     {
436 :     DPRINTF("Couldn't create XVID_REG_SUBKEY - GetLastError=%i", GetLastError());
437 :     return;
438 :     }
439 :    
440 :     memcpy(&reg, config, sizeof(CONFIG));
441 :    
442 :     /* set integer values */
443 :     for (i=0 ; i<sizeof(reg_ints)/sizeof(REG_INT); i++) {
444 :     RegSetValueEx(hKey, reg_ints[i].reg_value, 0, REG_DWORD, (LPBYTE)reg_ints[i].config_int, sizeof(int));
445 :     }
446 :    
447 :     /* set string values */
448 :     strcpy(reg.profile_name, profiles[reg.profile].name);
449 :     for (i=0 ; i<sizeof(reg_strs)/sizeof(REG_STR); i++) {
450 :     RegSetValueEx(hKey, reg_strs[i].reg_value, 0, REG_SZ, reg_strs[i].config_str, lstrlen(reg_strs[i].config_str)+1);
451 :     }
452 :    
453 :     /* set quant matrices */
454 :     REG_SET_B("qmatrix_intra", config->qmatrix_intra);
455 :     REG_SET_B("qmatrix_inter", config->qmatrix_inter);
456 :    
457 :     /* set seections */
458 :     for (i=0; i<config->num_zones; i++) {
459 :     memcpy(&stmp, &config->zones[i], sizeof(zone_t));
460 :     for (j=0; j<sizeof(reg_zone)/sizeof(REG_INT); j++) {
461 :     wsprintf(tmp, reg_zone[j].reg_value, i);
462 :     RegSetValueEx(hKey, tmp, 0, REG_DWORD, (LPBYTE)reg_zone[j].config_int, sizeof(int));
463 :     }
464 :     }
465 :    
466 :     RegCloseKey(hKey);
467 :     }
468 :    
469 :    
470 :     /* clear XviD registry key, load defaults */
471 :    
472 :     static void config_reg_default(CONFIG * config)
473 :     {
474 :     HKEY hKey;
475 :    
476 :     if (RegOpenKeyEx(XVID_REG_KEY, XVID_REG_PARENT, 0, KEY_ALL_ACCESS, &hKey)) {
477 :     DPRINTF("Couldn't open registry key for deletion - GetLastError=%i", GetLastError());
478 :     return;
479 :     }
480 :    
481 :     if (RegDeleteKey(hKey, XVID_REG_CHILD)) {
482 :     DPRINTF("Couldn't delete registry key - GetLastError=%i", GetLastError());
483 :     return;
484 :     }
485 :    
486 :     RegCloseKey(hKey);
487 :     config_reg_get(config);
488 :     config_reg_set(config);
489 :     }
490 :    
491 :    
492 :     /* leaves current config value if dialog item is empty */
493 :     static int config_get_int(HWND hDlg, INT item, int config)
494 :     {
495 :     BOOL success = FALSE;
496 :     int tmp = GetDlgItemInt(hDlg, item, &success, TRUE);
497 :     return (success) ? tmp : config;
498 :     }
499 :    
500 :    
501 :     static int config_get_uint(HWND hDlg, UINT item, int config)
502 :     {
503 :     BOOL success = FALSE;
504 :     int tmp = GetDlgItemInt(hDlg, item, &success, FALSE);
505 :     return (success) ? tmp : config;
506 :     }
507 :    
508 :     /* get uint from combobox
509 :     GetDlgItemInt doesnt work properly for cb list items */
510 :     #define UINT_BUF_SZ 20
511 :     static int config_get_cbuint(HWND hDlg, UINT item, int def)
512 :     {
513 :     int sel = SendMessage(GetDlgItem(hDlg, item), CB_GETCURSEL, 0, 0);
514 :     char buf[UINT_BUF_SZ];
515 :    
516 :     if (sel<0) {
517 :     return config_get_uint(hDlg, item, def);
518 :     }
519 :    
520 :     if (SendMessage(GetDlgItem(hDlg, item), CB_GETLBTEXT, sel, (LPARAM)buf) == CB_ERR) {
521 :     return def;
522 :     }
523 :    
524 :     return atoi(buf);
525 :     }
526 :    
527 :    
528 :     /* we use "100 base" floats */
529 :    
530 :     #define FLOAT_BUF_SZ 20
531 :     static int get_dlgitem_float(HWND hDlg, UINT item, int def)
532 :     {
533 :     char buf[FLOAT_BUF_SZ];
534 :    
535 :     if (GetDlgItemText(hDlg, item, buf, FLOAT_BUF_SZ) == 0)
536 :     return def;
537 :    
538 :     return (int)(atof(buf)*100);
539 :     }
540 :    
541 :     static void set_dlgitem_float(HWND hDlg, UINT item, int value)
542 :     {
543 :     char buf[FLOAT_BUF_SZ];
544 :     sprintf(buf, "%.2f", (float)value/100);
545 :     SetDlgItemText(hDlg, item, buf);
546 :     }
547 :    
548 :    
549 :     #define HEX_BUF_SZ 16
550 :     static unsigned int get_dlgitem_hex(HWND hDlg, UINT item, unsigned int def)
551 :     {
552 :     char buf[HEX_BUF_SZ];
553 :     unsigned int value;
554 :    
555 :     if (GetDlgItemText(hDlg, item, buf, HEX_BUF_SZ) == 0)
556 :     return def;
557 :    
558 :     if (sscanf(buf,"0x%x", &value)==1 || sscanf(buf,"%x", &value)==1) {
559 :     return value;
560 :     }
561 :    
562 :     return def;
563 :     }
564 :    
565 :     static void set_dlgitem_hex(HWND hDlg, UINT item, int value)
566 :     {
567 :     char buf[HEX_BUF_SZ];
568 :     wsprintf(buf, "0x%x", value);
569 :     SetDlgItemText(hDlg, item, buf);
570 :     }
571 :    
572 :     /* ===================================================================================== */
573 :     /* QUANT MATRIX DIALOG ================================================================= */
574 :     /* ===================================================================================== */
575 :    
576 :     static void quant_upload(HWND hDlg, CONFIG* config)
577 :     {
578 :     int i;
579 :    
580 :     for (i=0 ; i<64; i++) {
581 :     SetDlgItemInt(hDlg, IDC_QINTRA00 + i, config->qmatrix_intra[i], FALSE);
582 :     SetDlgItemInt(hDlg, IDC_QINTER00 + i, config->qmatrix_inter[i], FALSE);
583 :     }
584 :     }
585 :    
586 :    
587 :     static void quant_download(HWND hDlg, CONFIG* config)
588 :     {
589 :     int i;
590 :    
591 :     for (i=0; i<64; i++) {
592 :     int temp;
593 :    
594 :     temp = config_get_uint(hDlg, i + IDC_QINTRA00, config->qmatrix_intra[i]);
595 :     CONSTRAINVAL(temp, 1, 255);
596 :     config->qmatrix_intra[i] = temp;
597 :    
598 :     temp = config_get_uint(hDlg, i + IDC_QINTER00, config->qmatrix_inter[i]);
599 :     CONSTRAINVAL(temp, 1, 255);
600 :     config->qmatrix_inter[i] = temp;
601 :     }
602 :     }
603 :    
604 :    
605 :     static void quant_loadsave(HWND hDlg, CONFIG * config, int save)
606 :     {
607 :     char file[MAX_PATH];
608 :     OPENFILENAME ofn;
609 :     HANDLE hFile;
610 :     DWORD read=128, wrote=0;
611 :     BYTE quant_data[128];
612 :    
613 :     strcpy(file, "\\matrix");
614 :     memset(&ofn, 0, sizeof(OPENFILENAME));
615 :     ofn.lStructSize = sizeof(OPENFILENAME);
616 :    
617 :     ofn.hwndOwner = hDlg;
618 :     ofn.lpstrFilter = "All files (*.*)\0*.*\0\0";
619 :     ofn.lpstrFile = file;
620 :     ofn.nMaxFile = MAX_PATH;
621 :     ofn.Flags = OFN_PATHMUSTEXIST;
622 :    
623 :     if (save) {
624 :     ofn.Flags |= OFN_OVERWRITEPROMPT;
625 :     if (GetSaveFileName(&ofn)) {
626 :     hFile = CreateFile(file, GENERIC_WRITE, 0, 0, CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, 0);
627 :    
628 :     quant_download(hDlg, config);
629 :     memcpy(quant_data, config->qmatrix_intra, 64);
630 :     memcpy(quant_data+64, config->qmatrix_inter, 64);
631 :    
632 :     if (hFile == INVALID_HANDLE_VALUE) {
633 :     DPRINTF("Couldn't save quant matrix");
634 :     }else{
635 :     if (!WriteFile(hFile, quant_data, 128, &wrote, 0)) {
636 :     DPRINTF("Couldnt write quant matrix");
637 :     }
638 :     }
639 :     CloseHandle(hFile);
640 :     }
641 :     }else{
642 :     ofn.Flags |= OFN_FILEMUSTEXIST;
643 :     if (GetOpenFileName(&ofn)) {
644 :     hFile = CreateFile(file, GENERIC_READ, 0, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0);
645 :    
646 :     if (hFile == INVALID_HANDLE_VALUE) {
647 :     DPRINTF("Couldn't load quant matrix");
648 :     } else {
649 :     if (!ReadFile(hFile, quant_data, 128, &read, 0)) {
650 :     DPRINTF("Couldnt read quant matrix");
651 :     }else{
652 :     memcpy(config->qmatrix_intra, quant_data, 64);
653 :     memcpy(config->qmatrix_inter, quant_data+64, 64);
654 :     quant_upload(hDlg, config);
655 :     }
656 :     }
657 :     CloseHandle(hFile);
658 :     }
659 :     }
660 :     }
661 :    
662 :     /* quantization matrix dialog proc */
663 :    
664 :     static BOOL CALLBACK quantmatrix_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
665 :     {
666 :     CONFIG* config = (CONFIG*)GetWindowLong(hDlg, GWL_USERDATA);
667 :    
668 :     switch (uMsg)
669 :     {
670 :     case WM_INITDIALOG :
671 :     SetWindowLong(hDlg, GWL_USERDATA, lParam);
672 :     config = (CONFIG*)lParam;
673 :     quant_upload(hDlg, config);
674 :    
675 :     if (g_hTooltip)
676 :     {
677 :     EnumChildWindows(hDlg, enum_tooltips, 0);
678 :     }
679 :     break;
680 :    
681 :     case WM_COMMAND :
682 :    
683 :     if (HIWORD(wParam) == BN_CLICKED) {
684 :     switch(LOWORD(wParam)) {
685 :     case IDOK :
686 :     quant_download(hDlg, config);
687 :     EndDialog(hDlg, IDOK);
688 :     break;
689 :    
690 :     case IDCANCEL :
691 :     EndDialog(hDlg, IDCANCEL);
692 :     break;
693 :    
694 :     case IDC_SAVE :
695 :     quant_loadsave(hDlg, config, 1);
696 :     break;
697 :    
698 :     case IDC_LOAD :
699 :     quant_loadsave(hDlg, config, 0);
700 :     break;
701 :    
702 :     default :
703 :     return FALSE;
704 :     }
705 :     break;
706 :     }
707 :     return FALSE;
708 :    
709 :     default :
710 :     return FALSE;
711 :     }
712 :    
713 :     return TRUE;
714 :     }
715 :    
716 :    
717 :     /* ===================================================================================== */
718 :     /* ADVANCED DIALOG PAGES ================================================================ */
719 :     /* ===================================================================================== */
720 :    
721 :     /* initialise pages */
722 :     static void adv_init(HWND hDlg, int idd, CONFIG * config)
723 :     {
724 :     unsigned int i;
725 :    
726 :     switch(idd) {
727 :     case IDD_PROFILE :
728 :     for (i=0; i<sizeof(profiles)/sizeof(profile_t); i++)
729 :     SendDlgItemMessage(hDlg, IDC_PROFILE_PROFILE, CB_ADDSTRING, 0, (LPARAM)profiles[i].name);
730 :     SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_ADDSTRING, 0, (LPARAM)"H.263");
731 :     SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_ADDSTRING, 0, (LPARAM)"MPEG");
732 :     SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_ADDSTRING, 0, (LPARAM)"MPEG-Custom");
733 :     break;
734 :    
735 :     case IDD_AR:
736 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_ADDSTRING, 0, (LPARAM)"Square (default)");
737 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_ADDSTRING, 0, (LPARAM)"4:3 PAL");
738 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_ADDSTRING, 0, (LPARAM)"4:3 NTSC");
739 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_ADDSTRING, 0, (LPARAM)"16:9 PAL");
740 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_ADDSTRING, 0, (LPARAM)"16:9 NTSC");
741 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_ADDSTRING, 0, (LPARAM)"Custom...");
742 :     break;
743 :    
744 :     case IDD_LEVEL :
745 :     for (i=0; i<sizeof(profiles)/sizeof(profile_t); i++)
746 :     SendDlgItemMessage(hDlg, IDC_LEVEL_PROFILE, CB_ADDSTRING, 0, (LPARAM)profiles[i].name);
747 :     break;
748 :    
749 :     case IDD_BITRATE :
750 :     SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_ADDSTRING, 0, (LPARAM)"AVI-Legacy");
751 :     SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_ADDSTRING, 0, (LPARAM)"AVI-OpenDML");
752 :     SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_ADDSTRING, 0, (LPARAM)"Matroska");
753 :     SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_ADDSTRING, 0, (LPARAM)"OGM");
754 :     SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_ADDSTRING, 0, (LPARAM)"(None)");
755 :    
756 :     SendDlgItemMessage(hDlg, IDC_BITRATE_TSIZE, CB_ADDSTRING, 0, (LPARAM)"665600");
757 :     SendDlgItemMessage(hDlg, IDC_BITRATE_TSIZE, CB_ADDSTRING, 0, (LPARAM)"716800");
758 :     SendDlgItemMessage(hDlg, IDC_BITRATE_TSIZE, CB_ADDSTRING, 0, (LPARAM)"1331200");
759 :     SendDlgItemMessage(hDlg, IDC_BITRATE_TSIZE, CB_ADDSTRING, 0, (LPARAM)"1433600");
760 :    
761 :     for (i=0; i<sizeof(video_fps_list)/sizeof(named_float_t); i++)
762 :     SendDlgItemMessage(hDlg, IDC_BITRATE_FPS, CB_ADDSTRING, 0, (LPARAM)video_fps_list[i].name);
763 :    
764 :     for (i=0; i<sizeof(audio_type_list)/sizeof(named_int_t); i++)
765 :     SendDlgItemMessage(hDlg, IDC_BITRATE_AFORMAT, CB_ADDSTRING, 0, (LPARAM)audio_type_list[i].name);
766 :    
767 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"32");
768 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"56");
769 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"64");
770 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"96");
771 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"112");
772 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"128");
773 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"160");
774 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"192");
775 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"224");
776 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"256");
777 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"384");
778 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"448");
779 :     SendDlgItemMessage(hDlg, IDC_BITRATE_ARATE, CB_ADDSTRING, 0, (LPARAM)"512");
780 :     break;
781 :    
782 :     case IDD_ZONE :
783 :     EnableDlgWindow(hDlg, IDC_ZONE_FETCH, config->ci_valid);
784 :     break;
785 :    
786 :     case IDD_MOTION :
787 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"0 - None");
788 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"1 - Very Low");
789 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"2 - Low");
790 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"3 - Medium");
791 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"4 - High");
792 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"5 - Very High");
793 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_ADDSTRING, 0, (LPARAM)"6 - Ultra High");
794 :    
795 :     SendDlgItemMessage(hDlg, IDC_VHQ, CB_ADDSTRING, 0, (LPARAM)"0 - Off");
796 :     SendDlgItemMessage(hDlg, IDC_VHQ, CB_ADDSTRING, 0, (LPARAM)"1 - Mode Decision");
797 :     SendDlgItemMessage(hDlg, IDC_VHQ, CB_ADDSTRING, 0, (LPARAM)"2 - Limited Search");
798 :     SendDlgItemMessage(hDlg, IDC_VHQ, CB_ADDSTRING, 0, (LPARAM)"3 - Medium Search");
799 :     SendDlgItemMessage(hDlg, IDC_VHQ, CB_ADDSTRING, 0, (LPARAM)"4 - Wide Search");
800 :     break;
801 :    
802 :     case IDD_DEBUG :
803 :     /* force threads disabled */
804 :     EnableWindow(GetDlgItem(hDlg, IDC_NUMTHREADS_STATIC), FALSE);
805 :     EnableWindow(GetDlgItem(hDlg, IDC_NUMTHREADS), FALSE);
806 :    
807 :     SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"XVID");
808 :     SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"DIVX");
809 :     SendDlgItemMessage(hDlg, IDC_FOURCC, CB_ADDSTRING, 0, (LPARAM)"DX50");
810 :     break;
811 : suxen_drol 1397
812 :     case IDD_DEC :
813 :     SendDlgItemMessage(hDlg, IDC_DEC_BRIGHTNESS, TBM_SETRANGE, (WPARAM)TRUE, (LPARAM)MAKELONG(-96, 96));
814 :     SendDlgItemMessage(hDlg, IDC_DEC_BRIGHTNESS, TBM_SETTICFREQ, (WPARAM)16, (LPARAM)0);
815 :     break;
816 : edgomez 1382 }
817 :     }
818 :    
819 :    
820 :     /* enable/disable controls based on encoder-mode or user selection */
821 :    
822 :     static void adv_mode(HWND hDlg, int idd, CONFIG * config)
823 :     {
824 :     int profile;
825 :     int weight_en, quant_en;
826 :     int cpu_force;
827 :     int custom_quant, bvops;
828 :     int ar_mode, ar_par;
829 :    
830 :     switch(idd) {
831 :     case IDD_PROFILE :
832 :     profile = SendDlgItemMessage(hDlg, IDC_PROFILE_PROFILE, CB_GETCURSEL, 0, 0);
833 :     EnableDlgWindow(hDlg, IDC_BVOP, profiles[profile].flags&PROFILE_BVOP);
834 :    
835 :     EnableDlgWindow(hDlg, IDC_QUANTTYPE_S, profiles[profile].flags&PROFILE_MPEGQUANT);
836 :     EnableDlgWindow(hDlg, IDC_QUANTTYPE_S, profiles[profile].flags&PROFILE_MPEGQUANT);
837 :     EnableDlgWindow(hDlg, IDC_QUANTTYPE, profiles[profile].flags&PROFILE_MPEGQUANT);
838 :     custom_quant = (profiles[profile].flags&PROFILE_MPEGQUANT) && SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_GETCURSEL, 0, 0)==QUANT_MODE_CUSTOM;
839 :     EnableDlgWindow(hDlg, IDC_QUANTMATRIX, custom_quant);
840 :     EnableDlgWindow(hDlg, IDC_LUMMASK, profiles[profile].flags&PROFILE_ADAPTQUANT);
841 :     EnableDlgWindow(hDlg, IDC_INTERLACING, profiles[profile].flags&PROFILE_INTERLACE);
842 :     EnableDlgWindow(hDlg, IDC_QPEL, profiles[profile].flags&PROFILE_QPEL);
843 :     EnableDlgWindow(hDlg, IDC_GMC, profiles[profile].flags&PROFILE_GMC);
844 :     EnableDlgWindow(hDlg, IDC_REDUCED, profiles[profile].flags&PROFILE_REDUCED);
845 :    
846 :     bvops = (profiles[profile].flags&PROFILE_BVOP) && IsDlgChecked(hDlg, IDC_BVOP);
847 :     EnableDlgWindow(hDlg, IDC_MAXBFRAMES, bvops);
848 :     EnableDlgWindow(hDlg, IDC_BQUANTRATIO, bvops);
849 :     EnableDlgWindow(hDlg, IDC_BQUANTOFFSET, bvops);
850 :     EnableDlgWindow(hDlg, IDC_MAXBFRAMES_S, bvops);
851 :     EnableDlgWindow(hDlg, IDC_BQUANTRATIO_S, bvops);
852 :     EnableDlgWindow(hDlg, IDC_BQUANTOFFSET_S, bvops);
853 :     EnableDlgWindow(hDlg, IDC_PACKED, bvops);
854 :     EnableDlgWindow(hDlg, IDC_CLOSEDGOV, bvops);
855 :     break;
856 :    
857 :     case IDD_AR:
858 :     ar_mode = IsDlgChecked(hDlg, IDC_PAR);
859 :     EnableDlgWindow(hDlg, IDC_ASPECT_RATIO, ar_mode);
860 :    
861 :     ar_par = SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_GETCURSEL, 0, 0);
862 :     if (ar_par == 5) { /* custom par */
863 :     SetDlgItemInt(hDlg, IDC_PARY, config->par_y, FALSE);
864 :     SetDlgItemInt(hDlg, IDC_PARX, config->par_x, FALSE);
865 :    
866 :     EnableDlgWindow(hDlg, IDC_PARX, ar_mode);
867 :     EnableDlgWindow(hDlg, IDC_PARY, ar_mode);
868 :     } else {
869 :     SetDlgItemInt(hDlg, IDC_PARX, PARS[ar_par][0], FALSE);
870 :     SetDlgItemInt(hDlg, IDC_PARY, PARS[ar_par][1], FALSE);
871 :     EnableDlgWindow(hDlg, IDC_PARX, FALSE);
872 :     EnableDlgWindow(hDlg, IDC_PARY, FALSE);
873 :     }
874 :    
875 :     ar_mode = IsDlgChecked(hDlg, IDC_AR);
876 :    
877 :     config->ar_x = config_get_uint(hDlg, IDC_ARX, config->ar_x);
878 :     config->ar_y = config_get_uint(hDlg, IDC_ARY, config->ar_y);
879 :    
880 :     EnableDlgWindow(hDlg, IDC_ARX, ar_mode);
881 :     EnableDlgWindow(hDlg, IDC_ARY, ar_mode);
882 :     break;
883 :    
884 :     case IDD_LEVEL :
885 :     profile = SendDlgItemMessage(hDlg, IDC_LEVEL_PROFILE, CB_GETCURSEL, 0, 0);
886 :     SetDlgItemInt(hDlg, IDC_LEVEL_WIDTH, profiles[profile].width, FALSE);
887 :     SetDlgItemInt(hDlg, IDC_LEVEL_HEIGHT, profiles[profile].height, FALSE);
888 :     SetDlgItemInt(hDlg, IDC_LEVEL_FPS, profiles[profile].fps, FALSE);
889 :     SetDlgItemInt(hDlg, IDC_LEVEL_VMV, profiles[profile].max_vmv_buffer_sz, FALSE);
890 :     SetDlgItemInt(hDlg, IDC_LEVEL_VCV, profiles[profile].vcv_decoder_rate, FALSE);
891 :     SetDlgItemInt(hDlg, IDC_LEVEL_VBV, profiles[profile].max_vbv_size, FALSE);
892 :     SetDlgItemInt(hDlg, IDC_LEVEL_BITRATE, profiles[profile].max_bitrate, FALSE);
893 :     break;
894 :    
895 :     case IDD_BITRATE :
896 :     {
897 :     int ctype = SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_GETCURSEL, 0, 0);
898 :     int target_size = config_get_cbuint(hDlg, IDC_BITRATE_TSIZE, 0);
899 :     int subtitle_size = config_get_uint(hDlg, IDC_BITRATE_SSIZE, 0);
900 :     int fps = SendDlgItemMessage(hDlg, IDC_BITRATE_FPS, CB_GETCURSEL, 0, 0);
901 :    
902 :     int duration =
903 :     3600 * config_get_uint(hDlg, IDC_BITRATE_HOURS, 0) +
904 :     60 * config_get_uint(hDlg, IDC_BITRATE_MINUTES, 0) +
905 :     config_get_uint(hDlg, IDC_BITRATE_SECONDS, 0);
906 :    
907 :     int audio_type = SendDlgItemMessage(hDlg, IDC_BITRATE_AFORMAT, CB_GETCURSEL, 0, 0);
908 :     int audio_mode = IsDlgChecked(hDlg, IDC_BITRATE_AMODE_SIZE);
909 :     int audio_rate = config_get_cbuint(hDlg, IDC_BITRATE_ARATE, 0);
910 :     int audio_size = config_get_uint(hDlg, IDC_BITRATE_ASIZE, 0);
911 :    
912 :     int frames;
913 :     int overhead;
914 :     int vsize;
915 :    
916 :     if (duration == 0)
917 :     break;
918 :    
919 :     if (fps < 0 || fps >= sizeof(video_fps_list)/sizeof(named_float_t)) {
920 :     fps = 0;
921 :     }
922 :     if (audio_type < 0 || audio_type >= sizeof(audio_type_list)/sizeof(named_int_t)) {
923 :     audio_type = 0;
924 :     }
925 :    
926 :     EnableDlgWindow(hDlg, IDC_BITRATE_AMODE_RATE, audio_type!=NO_AUDIO);
927 :     EnableDlgWindow(hDlg, IDC_BITRATE_AMODE_SIZE, audio_type!=NO_AUDIO);
928 :     EnableDlgWindow(hDlg, IDC_BITRATE_ARATE, audio_type!=NO_AUDIO && !audio_mode);
929 :     EnableDlgWindow(hDlg, IDC_BITRATE_ASIZE, audio_type!=NO_AUDIO && audio_mode);
930 :     EnableDlgWindow(hDlg, IDC_BITRATE_ASELECT, audio_type!=NO_AUDIO && audio_mode);
931 :    
932 :     /* step 1: calculate number of frames */
933 :     frames = (int)(duration * video_fps_list[fps].value);
934 :    
935 :     /* step 2: calculate audio_size (kbytes)*/
936 :     if (audio_type!=NO_AUDIO) {
937 :     if (audio_mode==0) {
938 :     audio_size = (duration * audio_rate) / 8;
939 :     }
940 :     }else{
941 :     audio_size = 0;
942 :     }
943 :    
944 :     /* step 3: calculate container overhead */
945 :    
946 :     switch(ctype) {
947 :     case 0 : /* AVI */
948 :     case 1 : /* AVI-OpenDML */
949 :    
950 :     overhead = frames;
951 :    
952 :     if (audio_type!=NO_AUDIO) {
953 :     overhead += (duration * 1000) / audio_type_list[audio_type].avi_interval;
954 :     }
955 :    
956 :     overhead *= (ctype==0) ? 24 : 16;
957 :    
958 :     overhead /= 1024;
959 :     break;
960 :    
961 :     case 2 : /* Matroska: gknot formula */
962 :    
963 :     /* common overhead */
964 :     overhead = 40 + 12 + 8+ 16*duration + 200 + 100*1/*one audio stream*/ + 11*duration;
965 :    
966 :     /* video overhead */
967 :     overhead += frames*8 + (int)(frames * 4 * 0.94);
968 :    
969 :     /* cue tables and menu seek entries (300k default) */
970 :     overhead += 300 * 1024;
971 :    
972 :     /* audio */
973 :     overhead += (int)(duration * audio_type_list[audio_type].mkv_multiplier);
974 :    
975 :     overhead /= 1024;
976 :     break;
977 :    
978 :     case 3 : /* OGM: inaccurate model */
979 :     overhead = (int)(0.0039F * (target_size - subtitle_size));
980 :     break;
981 :    
982 :     default : /* (none) */
983 :     overhead = 0;
984 :     break;
985 :     }
986 :    
987 :     SetDlgItemInt(hDlg, IDC_BITRATE_COVERHEAD, overhead, TRUE);
988 :    
989 :     /* final video bitstream size */
990 :     vsize = target_size - subtitle_size - audio_size - overhead;
991 :     if (vsize > 0) {
992 :     SetDlgItemInt(hDlg, IDC_BITRATE_VSIZE, vsize, TRUE);
993 :     /* convert from kbytes to kbits-per-second */
994 :     SetDlgItemInt(hDlg, IDC_BITRATE_VRATE, (vsize * 8 * 128) / (duration * 125), TRUE);
995 :     }else{
996 :     SetDlgItemText(hDlg, IDC_BITRATE_VSIZE, "Overflow");
997 :     SetDlgItemText(hDlg, IDC_BITRATE_VRATE, "Overflow");
998 :     }
999 :    
1000 :     }
1001 :     break;
1002 :    
1003 :     case IDD_ZONE :
1004 :     weight_en = IsDlgChecked(hDlg, IDC_ZONE_MODE_WEIGHT);
1005 :     quant_en = IsDlgChecked(hDlg, IDC_ZONE_MODE_QUANT);
1006 :     EnableDlgWindow(hDlg, IDC_ZONE_WEIGHT, weight_en);
1007 :     EnableDlgWindow(hDlg, IDC_ZONE_QUANT, quant_en);
1008 :     EnableDlgWindow(hDlg, IDC_ZONE_SLIDER, weight_en|quant_en);
1009 :    
1010 :     if (weight_en) {
1011 :     SendDlgItemMessage(hDlg, IDC_ZONE_SLIDER, TBM_SETRANGE, TRUE, MAKELONG(001,200));
1012 :     SendDlgItemMessage(hDlg, IDC_ZONE_SLIDER, TBM_SETPOS, TRUE, get_dlgitem_float(hDlg, IDC_ZONE_WEIGHT, 100));
1013 :     SetDlgItemText(hDlg, IDC_ZONE_MIN, "0.01");
1014 :     SetDlgItemText(hDlg, IDC_ZONE_MAX, "2.00");
1015 :     }else if (quant_en) {
1016 :     SendDlgItemMessage(hDlg, IDC_ZONE_SLIDER, TBM_SETRANGE, TRUE, MAKELONG(100,3100));
1017 :     SendDlgItemMessage(hDlg, IDC_ZONE_SLIDER, TBM_SETPOS, TRUE, get_dlgitem_float(hDlg, IDC_ZONE_QUANT, 100));
1018 :     SetDlgItemText(hDlg, IDC_ZONE_MIN, "1");
1019 :     SetDlgItemText(hDlg, IDC_ZONE_MAX, "31");
1020 :     }
1021 :    
1022 :     bvops = (profiles[config->profile].flags&PROFILE_BVOP) && config->use_bvop;
1023 :     EnableDlgWindow(hDlg, IDC_ZONE_BVOPTHRESHOLD_S, bvops);
1024 :     EnableDlgWindow(hDlg, IDC_ZONE_BVOPTHRESHOLD, bvops);
1025 :     break;
1026 :    
1027 :     case IDD_DEBUG :
1028 :     cpu_force = IsDlgChecked(hDlg, IDC_CPU_FORCE);
1029 :     EnableDlgWindow(hDlg, IDC_CPU_MMX, cpu_force);
1030 :     EnableDlgWindow(hDlg, IDC_CPU_MMXEXT, cpu_force);
1031 :     EnableDlgWindow(hDlg, IDC_CPU_SSE, cpu_force);
1032 :     EnableDlgWindow(hDlg, IDC_CPU_SSE2, cpu_force);
1033 :     EnableDlgWindow(hDlg, IDC_CPU_3DNOW, cpu_force);
1034 :     EnableDlgWindow(hDlg, IDC_CPU_3DNOWEXT, cpu_force);
1035 :     break;
1036 :     }
1037 :     }
1038 :    
1039 :    
1040 :     /* upload config data into dialog */
1041 :     static void adv_upload(HWND hDlg, int idd, CONFIG * config)
1042 :     {
1043 :     switch (idd)
1044 :     {
1045 :     case IDD_PROFILE :
1046 :     SendDlgItemMessage(hDlg, IDC_PROFILE_PROFILE, CB_SETCURSEL, config->profile, 0);
1047 :    
1048 :     SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_SETCURSEL, config->quant_type, 0);
1049 :     CheckDlg(hDlg, IDC_LUMMASK, config->lum_masking);
1050 :     CheckDlg(hDlg, IDC_INTERLACING, config->interlacing);
1051 :     CheckDlg(hDlg, IDC_QPEL, config->qpel);
1052 :     CheckDlg(hDlg, IDC_GMC, config->gmc);
1053 :     CheckDlg(hDlg, IDC_REDUCED, config->reduced_resolution);
1054 :     CheckDlg(hDlg, IDC_BVOP, config->use_bvop);
1055 :    
1056 :     SetDlgItemInt(hDlg, IDC_MAXBFRAMES, config->max_bframes, FALSE);
1057 :     set_dlgitem_float(hDlg, IDC_BQUANTRATIO, config->bquant_ratio);
1058 :     set_dlgitem_float(hDlg, IDC_BQUANTOFFSET, config->bquant_offset);
1059 :     CheckDlg(hDlg, IDC_PACKED, config->packed);
1060 :     CheckDlg(hDlg, IDC_CLOSEDGOV, config->closed_gov);
1061 :    
1062 :     break;
1063 :     case IDD_AR:
1064 :     CheckRadioButton(hDlg, IDC_AR, IDC_PAR, config->ar_mode == 0 ? IDC_PAR : IDC_AR);
1065 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_SETCURSEL, (config->display_aspect_ratio), 0);
1066 :     SetDlgItemInt(hDlg, IDC_ARX, config->ar_x, FALSE);
1067 :     SetDlgItemInt(hDlg, IDC_ARY, config->ar_y, FALSE);
1068 :     break;
1069 :    
1070 :     case IDD_LEVEL :
1071 :     SendDlgItemMessage(hDlg, IDC_LEVEL_PROFILE, CB_SETCURSEL, config->profile, 0);
1072 :     break;
1073 :    
1074 :     case IDD_RC_CBR :
1075 :     SetDlgItemInt(hDlg, IDC_CBR_REACTIONDELAY, config->rc_reaction_delay_factor, FALSE);
1076 :     SetDlgItemInt(hDlg, IDC_CBR_AVERAGINGPERIOD, config->rc_averaging_period, FALSE);
1077 :     SetDlgItemInt(hDlg, IDC_CBR_BUFFER, config->rc_buffer, FALSE);
1078 :     break;
1079 :    
1080 :     case IDD_RC_2PASS1 :
1081 :     SetDlgItemText(hDlg, IDC_STATS, config->stats);
1082 :     CheckDlg(hDlg, IDC_DISCARD1PASS, config->discard1pass);
1083 :     CheckDlg(hDlg, IDC_FULL1PASS, config->full1pass);
1084 :     break;
1085 :    
1086 :     case IDD_RC_2PASS2 :
1087 :     SetDlgItemText(hDlg, IDC_STATS, config->stats);
1088 :     SetDlgItemInt(hDlg, IDC_KFBOOST, config->keyframe_boost, FALSE);
1089 :     SetDlgItemInt(hDlg, IDC_KFREDUCTION, config->kfreduction, FALSE);
1090 :    
1091 :     SetDlgItemInt(hDlg, IDC_OVERFLOW_CONTROL_STRENGTH, config->overflow_control_strength, FALSE);
1092 :     SetDlgItemInt(hDlg, IDC_OVERIMP, config->twopass_max_overflow_improvement, FALSE);
1093 :     SetDlgItemInt(hDlg, IDC_OVERDEG, config->twopass_max_overflow_degradation, FALSE);
1094 :    
1095 :     SetDlgItemInt(hDlg, IDC_CURVECOMPH, config->curve_compression_high, FALSE);
1096 :     SetDlgItemInt(hDlg, IDC_CURVECOMPL, config->curve_compression_low, FALSE);
1097 :     SetDlgItemInt(hDlg, IDC_MINKEY, config->kfthreshold, FALSE);
1098 :     break;
1099 :    
1100 :     case IDD_BITRATE :
1101 :     SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_SETCURSEL, config->container_type, 0);
1102 :     SetDlgItemInt(hDlg, IDC_BITRATE_TSIZE, config->target_size, FALSE);
1103 :     SetDlgItemInt(hDlg, IDC_BITRATE_SSIZE, config->subtitle_size, FALSE);
1104 :    
1105 :     SetDlgItemInt(hDlg, IDC_BITRATE_HOURS, config->hours, FALSE);
1106 :     SetDlgItemInt(hDlg, IDC_BITRATE_MINUTES, config->minutes, FALSE);
1107 :     SetDlgItemInt(hDlg, IDC_BITRATE_SECONDS, config->seconds, FALSE);
1108 :     SendDlgItemMessage(hDlg, IDC_BITRATE_FPS, CB_SETCURSEL, config->fps, 0);
1109 :    
1110 :     SendDlgItemMessage(hDlg, IDC_BITRATE_AFORMAT, CB_SETCURSEL, config->audio_type, 0);
1111 :     CheckRadioButton(hDlg, IDC_BITRATE_AMODE_RATE, IDC_BITRATE_AMODE_SIZE, config->audio_mode == 0 ? IDC_BITRATE_AMODE_RATE : IDC_BITRATE_AMODE_SIZE);
1112 :     SetDlgItemInt(hDlg, IDC_BITRATE_ARATE, config->audio_rate, FALSE);
1113 :     SetDlgItemInt(hDlg, IDC_BITRATE_ASIZE, config->audio_size, FALSE);
1114 :     break;
1115 :    
1116 :     case IDD_ZONE :
1117 :     SetDlgItemInt(hDlg, IDC_ZONE_FRAME, config->zones[config->cur_zone].frame, FALSE);
1118 :    
1119 :     CheckDlgButton(hDlg, IDC_ZONE_MODE_WEIGHT, config->zones[config->cur_zone].mode == RC_ZONE_WEIGHT);
1120 :     CheckDlgButton(hDlg, IDC_ZONE_MODE_QUANT, config->zones[config->cur_zone].mode == RC_ZONE_QUANT);
1121 :    
1122 :     set_dlgitem_float(hDlg, IDC_ZONE_WEIGHT, config->zones[config->cur_zone].weight);
1123 :     set_dlgitem_float(hDlg, IDC_ZONE_QUANT, config->zones[config->cur_zone].quant);
1124 :    
1125 :     CheckDlgButton(hDlg, IDC_ZONE_FORCEIVOP, config->zones[config->cur_zone].type==XVID_TYPE_IVOP);
1126 :     CheckDlgButton(hDlg, IDC_ZONE_GREYSCALE, config->zones[config->cur_zone].greyscale);
1127 :     CheckDlgButton(hDlg, IDC_ZONE_CHROMAOPT, config->zones[config->cur_zone].chroma_opt);
1128 :    
1129 :     SetDlgItemInt(hDlg, IDC_ZONE_BVOPTHRESHOLD, config->zones[config->cur_zone].bvop_threshold, TRUE);
1130 :     break;
1131 :    
1132 :     case IDD_MOTION :
1133 :     SendDlgItemMessage(hDlg, IDC_MOTION, CB_SETCURSEL, config->motion_search, 0);
1134 :     SendDlgItemMessage(hDlg, IDC_VHQ, CB_SETCURSEL, config->vhq_mode, 0);
1135 :     CheckDlg(hDlg, IDC_CHROMAME, config->chromame);
1136 :     CheckDlg(hDlg, IDC_CARTOON, config->cartoon_mode);
1137 :     CheckDlg(hDlg, IDC_TURBO, config->turbo);
1138 :     SetDlgItemInt(hDlg, IDC_FRAMEDROP, config->frame_drop_ratio, FALSE);
1139 :     SetDlgItemInt(hDlg, IDC_MAXKEY, config->max_key_interval, FALSE);
1140 :     break;
1141 :    
1142 :     case IDD_QUANT :
1143 :     SetDlgItemInt(hDlg, IDC_MINIQUANT, config->min_iquant, FALSE);
1144 :     SetDlgItemInt(hDlg, IDC_MAXIQUANT, config->max_iquant, FALSE);
1145 :     SetDlgItemInt(hDlg, IDC_MINPQUANT, config->min_pquant, FALSE);
1146 :     SetDlgItemInt(hDlg, IDC_MAXPQUANT, config->max_pquant, FALSE);
1147 :     SetDlgItemInt(hDlg, IDC_MINBQUANT, config->min_bquant, FALSE);
1148 :     SetDlgItemInt(hDlg, IDC_MAXBQUANT, config->max_bquant, FALSE);
1149 :     CheckDlg(hDlg, IDC_TRELLISQUANT, config->trellis_quant);
1150 :     break;
1151 :    
1152 :     case IDD_DEBUG :
1153 :     CheckDlg(hDlg, IDC_CPU_MMX, (config->cpu & XVID_CPU_MMX));
1154 :     CheckDlg(hDlg, IDC_CPU_MMXEXT, (config->cpu & XVID_CPU_MMXEXT));
1155 :     CheckDlg(hDlg, IDC_CPU_SSE, (config->cpu & XVID_CPU_SSE));
1156 :     CheckDlg(hDlg, IDC_CPU_SSE2, (config->cpu & XVID_CPU_SSE2));
1157 :     CheckDlg(hDlg, IDC_CPU_3DNOW, (config->cpu & XVID_CPU_3DNOW));
1158 :     CheckDlg(hDlg, IDC_CPU_3DNOWEXT, (config->cpu & XVID_CPU_3DNOWEXT));
1159 :    
1160 :     CheckRadioButton(hDlg, IDC_CPU_AUTO, IDC_CPU_FORCE,
1161 :     config->cpu & XVID_CPU_FORCE ? IDC_CPU_FORCE : IDC_CPU_AUTO );
1162 :    
1163 :     SetDlgItemInt(hDlg, IDC_NUMTHREADS, config->num_threads, FALSE);
1164 :    
1165 :     SendDlgItemMessage(hDlg, IDC_FOURCC, CB_SETCURSEL, config->fourcc_used, 0);
1166 :     set_dlgitem_hex(hDlg, IDC_DEBUG, config->debug);
1167 :     CheckDlg(hDlg, IDC_VOPDEBUG, config->vop_debug);
1168 :     CheckDlg(hDlg, IDC_DISPLAY_STATUS, config->display_status);
1169 :     break;
1170 :    
1171 :     case IDD_DEC :
1172 : suxen_drol 1397 SendDlgItemMessage(hDlg, IDC_DEC_BRIGHTNESS, TBM_SETPOS, (WPARAM)TRUE, (LPARAM)pp_brightness);
1173 : edgomez 1382 CheckDlg(hDlg, IDC_DEC_DY, pp_dy);
1174 :     CheckDlg(hDlg, IDC_DEC_DUV, pp_duv);
1175 : syskin 1437 CheckDlg(hDlg, IDC_DEC_DRY, pp_dry);
1176 :     CheckDlg(hDlg, IDC_DEC_DRUV,pp_druv);
1177 : edgomez 1382 CheckDlg(hDlg, IDC_DEC_FE, pp_fe);
1178 : syskin 1437 EnableDlgWindow(hDlg, IDC_DEC_DRY, pp_dy);
1179 :     EnableDlgWindow(hDlg, IDC_DEC_DRUV, pp_duv);
1180 : edgomez 1382 break;
1181 :     }
1182 :     }
1183 :    
1184 :    
1185 :     /* download config data from dialog */
1186 :    
1187 :     static void adv_download(HWND hDlg, int idd, CONFIG * config)
1188 :     {
1189 :     switch (idd)
1190 :     {
1191 :     case IDD_PROFILE :
1192 :     config->profile = SendDlgItemMessage(hDlg, IDC_PROFILE_PROFILE, CB_GETCURSEL, 0, 0);
1193 :    
1194 :     config->quant_type = SendDlgItemMessage(hDlg, IDC_QUANTTYPE, CB_GETCURSEL, 0, 0);
1195 :     config->lum_masking = IsDlgChecked(hDlg, IDC_LUMMASK);
1196 :     config->interlacing = IsDlgChecked(hDlg, IDC_INTERLACING);
1197 :     config->qpel = IsDlgChecked(hDlg, IDC_QPEL);
1198 :     config->gmc = IsDlgChecked(hDlg, IDC_GMC);
1199 :     config->reduced_resolution = IsDlgChecked(hDlg, IDC_REDUCED);
1200 :    
1201 :     config->use_bvop = IsDlgChecked(hDlg, IDC_BVOP);
1202 :     config->max_bframes = config_get_uint(hDlg, IDC_MAXBFRAMES, config->max_bframes);
1203 :     config->bquant_ratio = get_dlgitem_float(hDlg, IDC_BQUANTRATIO, config->bquant_ratio);
1204 :     config->bquant_offset = get_dlgitem_float(hDlg, IDC_BQUANTOFFSET, config->bquant_offset);
1205 :     config->packed = IsDlgChecked(hDlg, IDC_PACKED);
1206 :     config->closed_gov = IsDlgChecked(hDlg, IDC_CLOSEDGOV);
1207 :     break;
1208 :    
1209 :     case IDD_AR:
1210 :     config->ar_mode = IsDlgChecked(hDlg, IDC_PAR) ? 0:1;
1211 :     config->ar_x = config_get_uint(hDlg, IDC_ARX, config->ar_x);
1212 :     config->ar_y = config_get_uint(hDlg, IDC_ARY, config->ar_y);
1213 :     config->display_aspect_ratio = SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_GETCURSEL, 0, 0);
1214 :     if (config->display_aspect_ratio == 5) {
1215 :     config->par_x = config_get_uint(hDlg, IDC_PARX, config->par_x);
1216 :     config->par_y = config_get_uint(hDlg, IDC_PARY, config->par_y);
1217 :     }
1218 :     break;
1219 :    
1220 :     case IDD_LEVEL :
1221 :     config->profile = SendDlgItemMessage(hDlg, IDC_LEVEL_PROFILE, CB_GETCURSEL, 0, 0);
1222 :     break;
1223 :    
1224 :     case IDD_RC_CBR :
1225 :     config->rc_reaction_delay_factor = config_get_uint(hDlg, IDC_CBR_REACTIONDELAY, config->rc_reaction_delay_factor);
1226 :     config->rc_averaging_period = config_get_uint(hDlg, IDC_CBR_AVERAGINGPERIOD, config->rc_averaging_period);
1227 :     config->rc_buffer = config_get_uint(hDlg, IDC_CBR_BUFFER, config->rc_buffer);
1228 :     break;
1229 :    
1230 :     case IDD_RC_2PASS1 :
1231 :     if (GetDlgItemText(hDlg, IDC_STATS, config->stats, MAX_PATH) == 0)
1232 :     lstrcpy(config->stats, CONFIG_2PASS_FILE);
1233 :     config->discard1pass = IsDlgChecked(hDlg, IDC_DISCARD1PASS);
1234 :     config->full1pass = IsDlgChecked(hDlg, IDC_FULL1PASS);
1235 :     break;
1236 :    
1237 :     case IDD_RC_2PASS2 :
1238 :     if (GetDlgItemText(hDlg, IDC_STATS, config->stats, MAX_PATH) == 0)
1239 :     lstrcpy(config->stats, CONFIG_2PASS_FILE);
1240 :    
1241 :     config->keyframe_boost = GetDlgItemInt(hDlg, IDC_KFBOOST, NULL, FALSE);
1242 :     config->kfreduction = GetDlgItemInt(hDlg, IDC_KFREDUCTION, NULL, FALSE);
1243 :     CONSTRAINVAL(config->keyframe_boost, 0, 1000);
1244 :    
1245 :     config->overflow_control_strength = GetDlgItemInt(hDlg, IDC_OVERFLOW_CONTROL_STRENGTH, NULL, FALSE);
1246 :     config->twopass_max_overflow_improvement = config_get_uint(hDlg, IDC_OVERIMP, config->twopass_max_overflow_improvement);
1247 :     config->twopass_max_overflow_degradation = config_get_uint(hDlg, IDC_OVERDEG, config->twopass_max_overflow_degradation);
1248 :     CONSTRAINVAL(config->twopass_max_overflow_improvement, 1, 80);
1249 :     CONSTRAINVAL(config->twopass_max_overflow_degradation, 1, 80);
1250 :     CONSTRAINVAL(config->overflow_control_strength, 0, 100);
1251 :    
1252 :     config->curve_compression_high = GetDlgItemInt(hDlg, IDC_CURVECOMPH, NULL, FALSE);
1253 :     config->curve_compression_low = GetDlgItemInt(hDlg, IDC_CURVECOMPL, NULL, FALSE);
1254 :     CONSTRAINVAL(config->curve_compression_high, 0, 100);
1255 :     CONSTRAINVAL(config->curve_compression_low, 0, 100);
1256 :    
1257 :     config->kfthreshold = config_get_uint(hDlg, IDC_MINKEY, config->kfthreshold);
1258 :    
1259 :     break;
1260 :    
1261 :     case IDD_BITRATE :
1262 :     config->container_type = SendDlgItemMessage(hDlg, IDC_BITRATE_CFORMAT, CB_GETCURSEL, 0, 0);
1263 :     config->target_size = config_get_uint(hDlg, IDC_BITRATE_TSIZE, config->target_size);
1264 :     config->subtitle_size = config_get_uint(hDlg, IDC_BITRATE_SSIZE, config->subtitle_size);
1265 :    
1266 :     config->hours = config_get_uint(hDlg, IDC_BITRATE_HOURS, config->hours);
1267 :     config->minutes = config_get_uint(hDlg, IDC_BITRATE_MINUTES, config->minutes);
1268 :     config->seconds = config_get_uint(hDlg, IDC_BITRATE_SECONDS, config->seconds);
1269 :     config->fps = SendDlgItemMessage(hDlg, IDC_BITRATE_FPS, CB_GETCURSEL, 0, 0);
1270 :    
1271 :     config->audio_type = SendDlgItemMessage(hDlg, IDC_BITRATE_AFORMAT, CB_GETCURSEL, 0, 0);
1272 :     config->audio_mode = IsDlgChecked(hDlg, IDC_BITRATE_AMODE_SIZE) ? 1 : 0 ;
1273 :     config->audio_rate = config_get_uint(hDlg, IDC_BITRATE_ARATE, config->audio_rate);
1274 :     config->audio_size = config_get_uint(hDlg, IDC_BITRATE_ASIZE, config->audio_size);
1275 :    
1276 :     /* the main window uses "AVI bitrate/filesize" not "video bitrate/filesize",
1277 :     so we have to compensate by frames * 24 bytes */
1278 :     {
1279 :     int frame_compensate = 24 * (int)(
1280 :     (3600*config->hours +
1281 :     60*config->minutes +
1282 :     config->seconds) * video_fps_list[config->fps].value) / 1024;
1283 :    
1284 :     int bitrate_compensate = (int)(24 * video_fps_list[config->fps].value) / 125;
1285 :    
1286 :     config->desired_size =
1287 :     config_get_uint(hDlg, IDC_BITRATE_VSIZE, config->desired_size) + frame_compensate;
1288 :    
1289 :     config->bitrate =
1290 :     config_get_uint(hDlg, IDC_BITRATE_VRATE, config->bitrate) + bitrate_compensate;
1291 :     }
1292 :     break;
1293 :    
1294 :     case IDD_ZONE :
1295 :     config->zones[config->cur_zone].frame = config_get_uint(hDlg, IDC_ZONE_FRAME, config->zones[config->cur_zone].frame);
1296 :    
1297 :     if (IsDlgChecked(hDlg, IDC_ZONE_MODE_WEIGHT)) {
1298 :     config->zones[config->cur_zone].mode = RC_ZONE_WEIGHT;
1299 :     }else if (IsDlgChecked(hDlg, IDC_ZONE_MODE_QUANT)) {
1300 :     config->zones[config->cur_zone].mode = RC_ZONE_QUANT;
1301 :     }
1302 :    
1303 :     config->zones[config->cur_zone].weight = get_dlgitem_float(hDlg, IDC_ZONE_WEIGHT, config->zones[config->cur_zone].weight);
1304 :     config->zones[config->cur_zone].quant = get_dlgitem_float(hDlg, IDC_ZONE_QUANT, config->zones[config->cur_zone].quant);
1305 :    
1306 :     config->zones[config->cur_zone].type = IsDlgButtonChecked(hDlg, IDC_ZONE_FORCEIVOP)?XVID_TYPE_IVOP:XVID_TYPE_AUTO;
1307 :     config->zones[config->cur_zone].greyscale = IsDlgButtonChecked(hDlg, IDC_ZONE_GREYSCALE);
1308 :     config->zones[config->cur_zone].chroma_opt = IsDlgButtonChecked(hDlg, IDC_ZONE_CHROMAOPT);
1309 :    
1310 :     config->zones[config->cur_zone].bvop_threshold = config_get_int(hDlg, IDC_ZONE_BVOPTHRESHOLD, config->zones[config->cur_zone].bvop_threshold);
1311 :     break;
1312 :    
1313 :     case IDD_MOTION :
1314 :     config->motion_search = SendDlgItemMessage(hDlg, IDC_MOTION, CB_GETCURSEL, 0, 0);
1315 :     config->vhq_mode = SendDlgItemMessage(hDlg, IDC_VHQ, CB_GETCURSEL, 0, 0);
1316 :     config->chromame = IsDlgChecked(hDlg, IDC_CHROMAME);
1317 :     config->cartoon_mode = IsDlgChecked(hDlg, IDC_CARTOON);
1318 :     config->turbo = IsDlgChecked(hDlg, IDC_TURBO);
1319 :    
1320 :     config->frame_drop_ratio = config_get_uint(hDlg, IDC_FRAMEDROP, config->frame_drop_ratio);
1321 :    
1322 :     config->max_key_interval = config_get_uint(hDlg, IDC_MAXKEY, config->max_key_interval);
1323 :     break;
1324 :    
1325 :     case IDD_QUANT :
1326 :     config->min_iquant = config_get_uint(hDlg, IDC_MINIQUANT, config->min_iquant);
1327 :     config->max_iquant = config_get_uint(hDlg, IDC_MAXIQUANT, config->max_iquant);
1328 :     config->min_pquant = config_get_uint(hDlg, IDC_MINPQUANT, config->min_pquant);
1329 :     config->max_pquant = config_get_uint(hDlg, IDC_MAXPQUANT, config->max_pquant);
1330 :     config->min_bquant = config_get_uint(hDlg, IDC_MINBQUANT, config->min_bquant);
1331 :     config->max_bquant = config_get_uint(hDlg, IDC_MAXBQUANT, config->max_bquant);
1332 :    
1333 :     CONSTRAINVAL(config->min_iquant, 1, 31);
1334 :     CONSTRAINVAL(config->max_iquant, config->min_iquant, 31);
1335 :     CONSTRAINVAL(config->min_pquant, 1, 31);
1336 :     CONSTRAINVAL(config->max_pquant, config->min_pquant, 31);
1337 :     CONSTRAINVAL(config->min_bquant, 1, 31);
1338 :     CONSTRAINVAL(config->max_bquant, config->min_bquant, 31);
1339 :    
1340 :     config->trellis_quant = IsDlgChecked(hDlg, IDC_TRELLISQUANT);
1341 :     break;
1342 :    
1343 :     case IDD_DEBUG :
1344 :     config->cpu = 0;
1345 :     config->cpu |= IsDlgChecked(hDlg, IDC_CPU_MMX) ? XVID_CPU_MMX : 0;
1346 :     config->cpu |= IsDlgChecked(hDlg, IDC_CPU_MMXEXT) ? XVID_CPU_MMXEXT : 0;
1347 :     config->cpu |= IsDlgChecked(hDlg, IDC_CPU_SSE) ? XVID_CPU_SSE : 0;
1348 :     config->cpu |= IsDlgChecked(hDlg, IDC_CPU_SSE2) ? XVID_CPU_SSE2 : 0;
1349 :     config->cpu |= IsDlgChecked(hDlg, IDC_CPU_3DNOW) ? XVID_CPU_3DNOW : 0;
1350 :     config->cpu |= IsDlgChecked(hDlg, IDC_CPU_3DNOWEXT) ? XVID_CPU_3DNOWEXT : 0;
1351 :     config->cpu |= IsDlgChecked(hDlg, IDC_CPU_FORCE) ? XVID_CPU_FORCE : 0;
1352 :    
1353 :     config->num_threads = config_get_uint(hDlg, IDC_NUMTHREADS, config->num_threads);
1354 :    
1355 :     config->fourcc_used = SendDlgItemMessage(hDlg, IDC_FOURCC, CB_GETCURSEL, 0, 0);
1356 :     config->debug = get_dlgitem_hex(hDlg, IDC_DEBUG, config->debug);
1357 :     config->vop_debug = IsDlgChecked(hDlg, IDC_VOPDEBUG);
1358 :     config->display_status = IsDlgChecked(hDlg, IDC_DISPLAY_STATUS);
1359 :     break;
1360 :    
1361 :     case IDD_DEC :
1362 : suxen_drol 1397 pp_brightness = SendDlgItemMessage(hDlg, IDC_DEC_BRIGHTNESS, TBM_GETPOS, (WPARAM)NULL, (LPARAM)NULL);
1363 : edgomez 1382 pp_dy = IsDlgChecked(hDlg, IDC_DEC_DY);
1364 :     pp_duv = IsDlgChecked(hDlg, IDC_DEC_DUV);
1365 : syskin 1437 pp_dry = IsDlgChecked(hDlg, IDC_DEC_DRY);
1366 :     pp_druv = IsDlgChecked(hDlg, IDC_DEC_DRUV);
1367 : edgomez 1382 pp_fe = IsDlgChecked(hDlg, IDC_DEC_FE);
1368 :     break;
1369 :     }
1370 :     }
1371 :    
1372 :    
1373 :    
1374 :     /* advanced dialog proc */
1375 :    
1376 :     static BOOL CALLBACK adv_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
1377 :     {
1378 :     PROPSHEETINFO *psi;
1379 :    
1380 :     psi = (PROPSHEETINFO*)GetWindowLong(hDlg, GWL_USERDATA);
1381 :    
1382 :     switch (uMsg)
1383 :     {
1384 :     case WM_INITDIALOG :
1385 :     psi = (PROPSHEETINFO*) ((LPPROPSHEETPAGE)lParam)->lParam;
1386 :     SetWindowLong(hDlg, GWL_USERDATA, (LPARAM)psi);
1387 :    
1388 :     if (g_hTooltip)
1389 :     EnumChildWindows(hDlg, enum_tooltips, 0);
1390 :    
1391 :     adv_init(hDlg, psi->idd, psi->config);
1392 :     break;
1393 :    
1394 :     case WM_COMMAND :
1395 :     if (HIWORD(wParam) == BN_CLICKED)
1396 :     {
1397 :     switch (LOWORD(wParam))
1398 :     {
1399 :     case IDC_BVOP :
1400 :     case IDC_ZONE_MODE_WEIGHT :
1401 :     case IDC_ZONE_MODE_QUANT :
1402 :     case IDC_ZONE_BVOPTHRESHOLD_ENABLE :
1403 :     case IDC_CPU_AUTO :
1404 :     case IDC_CPU_FORCE :
1405 :     case IDC_AR :
1406 :     case IDC_PAR :
1407 :     case IDC_BITRATE_AMODE_RATE :
1408 :     case IDC_BITRATE_AMODE_SIZE :
1409 :     adv_mode(hDlg, psi->idd, psi->config);
1410 :     break;
1411 :    
1412 :     case IDC_BITRATE_SSELECT :
1413 :     case IDC_BITRATE_ASELECT :
1414 :     {
1415 :     OPENFILENAME ofn;
1416 :     char filename[MAX_PATH] = "";
1417 :    
1418 :     memset(&ofn, 0, sizeof(OPENFILENAME));
1419 :     ofn.lStructSize = sizeof(OPENFILENAME);
1420 :    
1421 :     ofn.hwndOwner = hDlg;
1422 :     if (LOWORD(wParam)==IDC_BITRATE_SSELECT) {
1423 :     ofn.lpstrFilter = "Subtitle files (*.sub, *.ssa)\0*.sub;*.ssa\0All files (*.*)\0*.*\0\0";
1424 :     }else{
1425 :     ofn.lpstrFilter = "Audio files (*.mp3, *.ac3)\0*.mp3; *.ac3\0All files (*.*)\0*.*\0\0";
1426 :     }
1427 :    
1428 :     ofn.lpstrFile = filename;
1429 :     ofn.nMaxFile = MAX_PATH;
1430 :     ofn.Flags = OFN_PATHMUSTEXIST | OFN_FILEMUSTEXIST;
1431 :    
1432 :     if (GetOpenFileName(&ofn)) {
1433 :     HANDLE hFile;
1434 :     DWORD filesize;
1435 :    
1436 : syskin 1434 if ((hFile = CreateFile(filename, GENERIC_READ, FILE_SHARE_READ, 0, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, 0)) == INVALID_HANDLE_VALUE ||
1437 : edgomez 1382 (filesize = GetFileSize(hFile, NULL)) == INVALID_FILE_SIZE) {
1438 :     MessageBox(hDlg, "Could not get file size", "Error", 0);
1439 :     }else{
1440 :     SetDlgItemInt(hDlg,
1441 :     LOWORD(wParam)==IDC_BITRATE_SSELECT? IDC_BITRATE_SSIZE : IDC_BITRATE_ASIZE,
1442 :     filesize / 1024, FALSE);
1443 :     CloseHandle(hFile);
1444 :     }
1445 :     }
1446 :     }
1447 :     break;
1448 :    
1449 :     case IDC_QUANTMATRIX :
1450 :     DialogBoxParam(g_hInst, MAKEINTRESOURCE(IDD_QUANTMATRIX), hDlg, quantmatrix_proc, (LPARAM)psi->config);
1451 :     break;
1452 :    
1453 :     case IDC_STATS_BROWSE :
1454 :     {
1455 :     OPENFILENAME ofn;
1456 :     char tmp[MAX_PATH];
1457 :    
1458 :     GetDlgItemText(hDlg, IDC_STATS, tmp, MAX_PATH);
1459 :    
1460 :     memset(&ofn, 0, sizeof(OPENFILENAME));
1461 :     ofn.lStructSize = sizeof(OPENFILENAME);
1462 :    
1463 :     ofn.hwndOwner = hDlg;
1464 :     ofn.lpstrFilter = "bitrate curve (*.pass)\0*.pass\0All files (*.*)\0*.*\0\0";
1465 :     ofn.lpstrFile = tmp;
1466 :     ofn.nMaxFile = MAX_PATH;
1467 :     ofn.Flags = OFN_PATHMUSTEXIST;
1468 :    
1469 :     if (psi->idd == IDD_RC_2PASS1) {
1470 :     ofn.Flags |= OFN_OVERWRITEPROMPT;
1471 :     }else{
1472 :     ofn.Flags |= OFN_FILEMUSTEXIST;
1473 :     }
1474 :    
1475 :     if ((psi->idd==IDD_RC_2PASS1 && GetSaveFileName(&ofn)) ||
1476 :     (psi->idd==IDD_RC_2PASS2 && GetOpenFileName(&ofn))) {
1477 :     SetDlgItemText(hDlg, IDC_STATS, tmp);
1478 :     }
1479 :     }
1480 :     break;
1481 :    
1482 :     case IDC_ZONE_FETCH :
1483 :     SetDlgItemInt(hDlg, IDC_ZONE_FRAME, psi->config->ci.ciActiveFrame, FALSE);
1484 :     break;
1485 :    
1486 :     case IDC_AR_DEFAULT:
1487 :     CheckRadioButton(hDlg, IDC_AR, IDC_PAR, IDC_PAR);
1488 :     SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_SETCURSEL, 0, 0);
1489 :     adv_mode(hDlg, psi->idd, psi->config);
1490 :     break;
1491 :     case IDC_AR_4_3:
1492 :     SetDlgItemInt(hDlg, IDC_ARX, 4, FALSE);
1493 :     SetDlgItemInt(hDlg, IDC_ARY, 3, FALSE);
1494 :     CheckRadioButton(hDlg, IDC_AR, IDC_PAR, IDC_AR);
1495 :     adv_mode(hDlg, psi->idd, psi->config);
1496 :     break;
1497 :     case IDC_AR_16_9:
1498 :     SetDlgItemInt(hDlg, IDC_ARX, 16, FALSE);
1499 :     SetDlgItemInt(hDlg, IDC_ARY, 9, FALSE);
1500 :     CheckRadioButton(hDlg, IDC_AR, IDC_PAR, IDC_AR);
1501 :     adv_mode(hDlg, psi->idd, psi->config);
1502 :     break;
1503 :     case IDC_AR_235_100:
1504 :     SetDlgItemInt(hDlg, IDC_ARX, 235, FALSE);
1505 :     SetDlgItemInt(hDlg, IDC_ARY, 100, FALSE);
1506 :     CheckRadioButton(hDlg, IDC_AR, IDC_PAR, IDC_AR);
1507 :     adv_mode(hDlg, psi->idd, psi->config);
1508 :     break;
1509 : syskin 1437 case IDC_DEC_DY:
1510 :     case IDC_DEC_DUV:
1511 :     EnableDlgWindow(hDlg, IDC_DEC_DRY, IsDlgChecked(hDlg, IDC_DEC_DY));
1512 :     EnableDlgWindow(hDlg, IDC_DEC_DRUV, IsDlgChecked(hDlg, IDC_DEC_DUV));
1513 :     break;
1514 : edgomez 1382 default :
1515 :     return TRUE;
1516 :     }
1517 :     }else if ((HIWORD(wParam) == CBN_EDITCHANGE || HIWORD(wParam)==CBN_SELCHANGE) &&
1518 :     (LOWORD(wParam)==IDC_BITRATE_TSIZE ||
1519 :     LOWORD(wParam)==IDC_BITRATE_ARATE )) {
1520 :    
1521 :     adv_mode(hDlg, psi->idd, psi->config);
1522 :    
1523 :     }else if (HIWORD(wParam) == LBN_SELCHANGE &&
1524 :     (LOWORD(wParam) == IDC_PROFILE_PROFILE ||
1525 :     LOWORD(wParam) == IDC_LEVEL_PROFILE ||
1526 :     LOWORD(wParam) == IDC_QUANTTYPE ||
1527 :     LOWORD(wParam) == IDC_ASPECT_RATIO ||
1528 :     LOWORD(wParam) == IDC_BITRATE_CFORMAT ||
1529 :     LOWORD(wParam) == IDC_BITRATE_AFORMAT ||
1530 :     LOWORD(wParam) == IDC_BITRATE_FPS)) {
1531 :     adv_mode(hDlg, psi->idd, psi->config);
1532 :     }else if (HIWORD(wParam) == EN_UPDATE && (LOWORD(wParam)==IDC_ZONE_WEIGHT || LOWORD(wParam)==IDC_ZONE_QUANT)) {
1533 :    
1534 :     SendDlgItemMessage(hDlg, IDC_ZONE_SLIDER, TBM_SETPOS, TRUE,
1535 :     get_dlgitem_float(hDlg, LOWORD(wParam), 100));
1536 :    
1537 :     } else if (HIWORD(wParam) == EN_UPDATE && (LOWORD(wParam)==IDC_PARX || LOWORD(wParam)==IDC_PARY)) {
1538 :    
1539 :     if (5 == SendDlgItemMessage(hDlg, IDC_ASPECT_RATIO, CB_GETCURSEL, 0, 0)) {
1540 :     if(LOWORD(wParam)==IDC_PARX)
1541 :     psi->config->par_x = config_get_uint(hDlg, LOWORD(wParam), psi->config->par_x);
1542 :     else
1543 :     psi->config->par_y = config_get_uint(hDlg, LOWORD(wParam), psi->config->par_y);
1544 :     }
1545 :     } else if (HIWORD(wParam) == EN_UPDATE &&
1546 :     (LOWORD(wParam)==IDC_BITRATE_SSIZE ||
1547 :     LOWORD(wParam)==IDC_BITRATE_HOURS ||
1548 :     LOWORD(wParam)==IDC_BITRATE_MINUTES ||
1549 :     LOWORD(wParam)==IDC_BITRATE_SECONDS ||
1550 :     LOWORD(wParam)==IDC_BITRATE_ASIZE)) {
1551 :     adv_mode(hDlg, psi->idd, psi->config);
1552 :     } else
1553 :     return 0;
1554 :     break;
1555 :    
1556 :     case WM_HSCROLL :
1557 :     if((HWND)lParam == GetDlgItem(hDlg, IDC_ZONE_SLIDER)) {
1558 :     int idc = IsDlgChecked(hDlg, IDC_ZONE_MODE_WEIGHT) ? IDC_ZONE_WEIGHT : IDC_ZONE_QUANT;
1559 :     set_dlgitem_float(hDlg, idc, SendMessage((HWND)lParam, TBM_GETPOS, 0, 0) );
1560 :     break;
1561 :     }
1562 :     return 0;
1563 :    
1564 :    
1565 :     case WM_NOTIFY :
1566 :     switch (((NMHDR *)lParam)->code)
1567 :     {
1568 :     case PSN_SETACTIVE :
1569 :     DPRINTF("PSN_SET");
1570 :     adv_upload(hDlg, psi->idd, psi->config);
1571 :     adv_mode(hDlg, psi->idd, psi->config);
1572 :     SetWindowLong(hDlg, DWL_MSGRESULT, FALSE);
1573 :     break;
1574 :    
1575 :     case PSN_KILLACTIVE :
1576 :     DPRINTF("PSN_KILL");
1577 :     adv_download(hDlg, psi->idd, psi->config);
1578 :     SetWindowLong(hDlg, DWL_MSGRESULT, FALSE);
1579 :     break;
1580 :    
1581 :     case PSN_APPLY :
1582 :     DPRINTF("PSN_APPLY");
1583 :     psi->config->save = TRUE;
1584 :     SetWindowLong(hDlg, DWL_MSGRESULT, FALSE);
1585 :     break;
1586 :     }
1587 :     break;
1588 :    
1589 :     default :
1590 :     return 0;
1591 :     }
1592 :    
1593 :     return 1;
1594 :     }
1595 :    
1596 :    
1597 :    
1598 :    
1599 :     /* load advanced options property sheet
1600 :     returns true, if the user accepted the changes
1601 :     or fasle if changes were canceled.
1602 :    
1603 :     */
1604 :    
1605 :     #ifndef PSH_NOCONTEXTHELP
1606 :     #define PSH_NOCONTEXTHELP 0x02000000
1607 :     #endif
1608 :    
1609 :     static BOOL adv_dialog(HWND hParent, CONFIG * config, const int * dlgs, int size)
1610 :     {
1611 :     PROPSHEETINFO psi[6];
1612 :     PROPSHEETPAGE psp[6];
1613 :     PROPSHEETHEADER psh;
1614 :     CONFIG temp;
1615 :     int i;
1616 :    
1617 :     config->save = FALSE;
1618 :     memcpy(&temp, config, sizeof(CONFIG));
1619 :    
1620 :     for (i=0; i<size; i++)
1621 :     {
1622 :     psp[i].dwSize = sizeof(PROPSHEETPAGE);
1623 :     psp[i].dwFlags = 0;
1624 :     psp[i].hInstance = g_hInst;
1625 :     psp[i].pfnDlgProc = adv_proc;
1626 :     psp[i].lParam = (LPARAM)&psi[i];
1627 :     psp[i].pfnCallback = NULL;
1628 :     psp[i].pszTemplate = MAKEINTRESOURCE(dlgs[i]);
1629 :    
1630 :     psi[i].idd = dlgs[i];
1631 :     psi[i].config = &temp;
1632 :     }
1633 :    
1634 :     psh.dwSize = sizeof(PROPSHEETHEADER);
1635 :     psh.dwFlags = PSH_PROPSHEETPAGE | PSH_NOAPPLYNOW | PSH_NOCONTEXTHELP;
1636 :     psh.hwndParent = hParent;
1637 :     psh.hInstance = g_hInst;
1638 :     psh.pszCaption = (LPSTR) "XviD Configuration";
1639 :     psh.nPages = size;
1640 :     psh.nStartPage = 0;
1641 :     psh.ppsp = (LPCPROPSHEETPAGE)&psp;
1642 :     psh.pfnCallback = NULL;
1643 :     PropertySheet(&psh);
1644 :    
1645 :     if (temp.save)
1646 :     memcpy(config, &temp, sizeof(CONFIG));
1647 :    
1648 :     return temp.save;
1649 :     }
1650 :    
1651 :     /* ===================================================================================== */
1652 :     /* MAIN DIALOG ========================================================================= */
1653 :     /* ===================================================================================== */
1654 :    
1655 :    
1656 :     static void main_insert_zone(HWND hDlg, zone_t * s, int i, BOOL insert)
1657 :     {
1658 :     char tmp[32];
1659 :    
1660 :     wsprintf(tmp,"%i",s->frame);
1661 :    
1662 :     if (insert) {
1663 :     LVITEM lvi;
1664 :    
1665 :     lvi.mask = LVIF_TEXT | LVIF_IMAGE | LVIF_PARAM | LVIF_STATE;
1666 :     lvi.state = 0;
1667 :     lvi.stateMask = 0;
1668 :     lvi.iImage = 0;
1669 :     lvi.pszText = tmp;
1670 :     lvi.cchTextMax = strlen(tmp);
1671 :     lvi.iItem = i;
1672 :     lvi.iSubItem = 0;
1673 :     ListView_InsertItem(hDlg, &lvi);
1674 :     }else{
1675 :     ListView_SetItemText(hDlg, i, 0, tmp);
1676 :     }
1677 :    
1678 :     if (s->mode == RC_ZONE_WEIGHT) {
1679 :     sprintf(tmp,"W %.2f",(float)s->weight/100);
1680 :     }else if (s->mode == RC_ZONE_QUANT) {
1681 :     sprintf(tmp,"Q %.2f",(float)s->quant/100);
1682 :     }else {
1683 :     strcpy(tmp,"EXT");
1684 :     }
1685 :     ListView_SetItemText(hDlg, i, 1, tmp);
1686 :    
1687 :     tmp[0] = '\0';
1688 :     if (s->type==XVID_TYPE_IVOP)
1689 :     strcat(tmp, "K ");
1690 :    
1691 :     if (s->greyscale)
1692 :     strcat(tmp, "G ");
1693 :    
1694 :     if (s->chroma_opt)
1695 :     strcat(tmp, "C ");
1696 :    
1697 :     ListView_SetItemText(hDlg, i, 2, tmp);
1698 :     }
1699 :    
1700 :    
1701 :     static void main_mode(HWND hDlg, CONFIG * config)
1702 :     {
1703 :     const int profile = SendDlgItemMessage(hDlg, IDC_PROFILE, CB_GETCURSEL, 0, 0);
1704 :     const int rc_mode = SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0);
1705 :     /* enable target rate/size control only for 1pass and 2pass modes*/
1706 :     const int target_en = rc_mode==RC_MODE_1PASS || rc_mode==RC_MODE_2PASS2;
1707 :     const int target_en_slider = rc_mode==RC_MODE_1PASS ||
1708 :     (rc_mode==RC_MODE_2PASS2 && config->use_2pass_bitrate);
1709 :    
1710 :     char buf[16];
1711 :     int max;
1712 :    
1713 :     g_use_bitrate = config->use_2pass_bitrate;
1714 :    
1715 :     if (g_use_bitrate) {
1716 :     SetDlgItemText(hDlg, IDC_BITRATE_S, "Target bitrate (kbps):");
1717 :    
1718 :     wsprintf(buf, "%i kbps", DEFAULT_MIN_KBPS);
1719 :     SetDlgItemText(hDlg, IDC_BITRATE_MIN, buf);
1720 :    
1721 :     max = profiles[profile].max_bitrate;
1722 :     if (max == 0) max = DEFAULT_MAX_KBPS;
1723 :     wsprintf(buf, "%i kbps", max);
1724 :     SetDlgItemText(hDlg, IDC_BITRATE_MAX, buf);
1725 :    
1726 :     SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETRANGE, TRUE, MAKELONG(DEFAULT_MIN_KBPS, max));
1727 :     SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETPOS, TRUE,
1728 :     config_get_uint(hDlg, IDC_BITRATE, DEFAULT_MIN_KBPS) );
1729 :    
1730 :     } else if (rc_mode==RC_MODE_2PASS2) {
1731 :     SetDlgItemText(hDlg, IDC_BITRATE_S, "Target size (kbytes):");
1732 :     } else if (rc_mode==RC_MODE_1PASS) {
1733 :     SetDlgItemText(hDlg, IDC_BITRATE_S, "Target quantizer:");
1734 :     SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETRANGE, TRUE, MAKELONG(100, 3100));
1735 :     SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETPOS, TRUE,
1736 :     get_dlgitem_float(hDlg, IDC_BITRATE, DEFAULT_QUANT ));
1737 :     SetDlgItemText(hDlg, IDC_BITRATE_MIN, "1 (maximum quality)");
1738 :     SetDlgItemText(hDlg, IDC_BITRATE_MAX, "(smallest file) 31");
1739 :    
1740 :     }
1741 :    
1742 :     EnableDlgWindow(hDlg, IDC_BITRATE_S, target_en);
1743 :     EnableDlgWindow(hDlg, IDC_BITRATE, target_en);
1744 :     EnableDlgWindow(hDlg, IDC_BITRATE_ADV, target_en);
1745 :    
1746 :     EnableDlgWindow(hDlg, IDC_BITRATE_MIN, target_en_slider);
1747 :     EnableDlgWindow(hDlg, IDC_BITRATE_MAX, target_en_slider);
1748 :     EnableDlgWindow(hDlg, IDC_SLIDER, target_en_slider);
1749 :     }
1750 :    
1751 :    
1752 :     static void main_upload(HWND hDlg, CONFIG * config)
1753 :     {
1754 :    
1755 :     SendDlgItemMessage(hDlg, IDC_PROFILE, CB_SETCURSEL, config->profile, 0);
1756 :     SendDlgItemMessage(hDlg, IDC_MODE, CB_SETCURSEL, config->mode, 0);
1757 :    
1758 :     g_use_bitrate = config->use_2pass_bitrate;
1759 :    
1760 :     if (g_use_bitrate) {
1761 :     SetDlgItemInt(hDlg, IDC_BITRATE, config->bitrate, FALSE);
1762 :     } else if (config->mode == RC_MODE_2PASS2) {
1763 :     SetDlgItemInt(hDlg, IDC_BITRATE, config->desired_size, FALSE);
1764 :     } else if (config->mode == RC_MODE_1PASS) {
1765 :     set_dlgitem_float(hDlg, IDC_BITRATE, config->desired_quant);
1766 :     }
1767 :    
1768 :     zones_update(hDlg, config);
1769 :     }
1770 :    
1771 :    
1772 :     /* downloads data from main dialog */
1773 :     static void main_download(HWND hDlg, CONFIG * config)
1774 :     {
1775 :     config->profile = SendDlgItemMessage(hDlg, IDC_PROFILE, CB_GETCURSEL, 0, 0);
1776 :     config->mode = SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0);
1777 :    
1778 :     if (g_use_bitrate) {
1779 :     config->bitrate = config_get_uint(hDlg, IDC_BITRATE, config->bitrate);
1780 :     } else if (config->mode == RC_MODE_2PASS2) {
1781 :     config->desired_size = config_get_uint(hDlg, IDC_BITRATE, config->desired_size);
1782 :     } else if (config->mode == RC_MODE_1PASS) {
1783 :     config->desired_quant = get_dlgitem_float(hDlg, IDC_BITRATE, config->desired_quant);
1784 :     }
1785 :     }
1786 :    
1787 :    
1788 :     /* main dialog proc */
1789 :    
1790 :     static const int profile_dlgs[] = { IDD_PROFILE, IDD_LEVEL, IDD_AR };
1791 :     static const int single_dlgs[] = { IDD_RC_CBR };
1792 :     static const int pass1_dlgs[] = { IDD_RC_2PASS1 };
1793 :     static const int pass2_dlgs[] = { IDD_RC_2PASS2 };
1794 :     static const int bitrate_dlgs[] = { IDD_BITRATE };
1795 :     static const int zone_dlgs[] = { IDD_ZONE };
1796 :     static const int decoder_dlgs[] = { IDD_DEC };
1797 :     static const int adv_dlgs[] = { IDD_MOTION, IDD_QUANT, IDD_DEBUG};
1798 :    
1799 :    
1800 :     BOOL CALLBACK main_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
1801 :     {
1802 :     CONFIG* config = (CONFIG*)GetWindowLong(hDlg, GWL_USERDATA);
1803 :     unsigned int i;
1804 :    
1805 :     switch (uMsg)
1806 :     {
1807 :     case WM_INITDIALOG :
1808 :     SetWindowLong(hDlg, GWL_USERDATA, lParam);
1809 :     config = (CONFIG*)lParam;
1810 :    
1811 :     for (i=0; i<sizeof(profiles)/sizeof(profile_t); i++)
1812 :     SendDlgItemMessage(hDlg, IDC_PROFILE, CB_ADDSTRING, 0, (LPARAM)profiles[i].name);
1813 :    
1814 :     SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"Single pass");
1815 :     SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"Twopass - 1st pass");
1816 :     SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"Twopass - 2nd pass");
1817 :     #ifdef _DEBUG
1818 :     SendDlgItemMessage(hDlg, IDC_MODE, CB_ADDSTRING, 0, (LPARAM)"Null test speed");
1819 :     #endif
1820 :    
1821 :     InitCommonControls();
1822 :    
1823 :     if ((g_hTooltip = CreateWindow(TOOLTIPS_CLASS, NULL, TTS_ALWAYSTIP,
1824 :     CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT,
1825 :     NULL, NULL, g_hInst, NULL)))
1826 :     {
1827 :     SetWindowPos(g_hTooltip, HWND_TOPMOST, 0, 0, 0, 0, SWP_NOMOVE|SWP_NOSIZE|SWP_NOACTIVATE);
1828 :     SendMessage(g_hTooltip, TTM_SETDELAYTIME, TTDT_AUTOMATIC, MAKELONG(1500, 0));
1829 :     SendMessage(g_hTooltip, TTM_SETMAXTIPWIDTH, 0, 400);
1830 :    
1831 :     EnumChildWindows(hDlg, enum_tooltips, 0);
1832 :     }
1833 :    
1834 :     SetClassLong(GetDlgItem(hDlg, IDC_BITRATE_S), GCL_HCURSOR, (LONG)LoadCursor(NULL, IDC_HAND));
1835 :    
1836 :     {
1837 :     DWORD ext_style = ListView_GetExtendedListViewStyle(GetDlgItem(hDlg,IDC_ZONES));
1838 :     ext_style |= LVS_EX_FULLROWSELECT | LVS_EX_FLATSB ;
1839 :     ListView_SetExtendedListViewStyle(GetDlgItem(hDlg,IDC_ZONES), ext_style);
1840 :     }
1841 :    
1842 :     {
1843 :     typedef struct {
1844 :     char * name;
1845 :     int value;
1846 :     } char_int_t;
1847 :    
1848 :     const static char_int_t columns[] = {
1849 :     {"Frame #", 64},
1850 :     {"Weight/Quant", 82},
1851 :     {"Modifiers", 120}};
1852 :    
1853 :     LVCOLUMN lvc;
1854 :     int i;
1855 :    
1856 :     /* Initialize the LVCOLUMN structure. */
1857 :     lvc.mask = LVCF_FMT | LVCF_WIDTH | LVCF_TEXT | LVCF_SUBITEM;
1858 :     lvc.fmt = LVCFMT_LEFT;
1859 :    
1860 :     /* Add the columns. */
1861 :     for (i=0; i<sizeof(columns)/sizeof(char_int_t); i++) {
1862 :     lvc.pszText = (char*)columns[i].name;
1863 :     lvc.cchTextMax = strlen(columns[i].name);
1864 :     lvc.iSubItem = i;
1865 :     lvc.cx = columns[i].value; /* column width, pixels */
1866 :     ListView_InsertColumn(GetDlgItem(hDlg,IDC_ZONES), i, &lvc);
1867 :     }
1868 :     }
1869 :    
1870 :     /* XXX: main_mode needs RC_MODE_xxx, main_upload needs g_use_bitrate set correctly... */
1871 :     main_upload(hDlg, config);
1872 :     main_mode(hDlg, config);
1873 :     main_upload(hDlg, config);
1874 :     break;
1875 :    
1876 :     case WM_NOTIFY :
1877 :     {
1878 :     NMHDR * n = (NMHDR*)lParam;
1879 :    
1880 :     if (n->code == NM_DBLCLK) {
1881 :     NMLISTVIEW * nmlv = (NMLISTVIEW*) lParam;
1882 :     config->cur_zone = nmlv->iItem;
1883 :    
1884 :     main_download(hDlg, config);
1885 :     if (config->cur_zone >= 0 && adv_dialog(hDlg, config, zone_dlgs, sizeof(zone_dlgs)/sizeof(int))) {
1886 :     zones_update(hDlg, config);
1887 :     }
1888 :     break;
1889 :     }
1890 :    
1891 :     break;
1892 :     }
1893 :    
1894 :     case WM_COMMAND :
1895 :     if (HIWORD(wParam) == BN_CLICKED) {
1896 :    
1897 :     switch(LOWORD(wParam)) {
1898 :     case IDC_PROFILE_ADV :
1899 :     main_download(hDlg, config);
1900 :     adv_dialog(hDlg, config, profile_dlgs, sizeof(profile_dlgs)/sizeof(int));
1901 :    
1902 :     SendDlgItemMessage(hDlg, IDC_PROFILE, CB_SETCURSEL, config->profile, 0);
1903 :     main_mode(hDlg, config);
1904 :     break;
1905 :    
1906 :     case IDC_MODE_ADV :
1907 :     main_download(hDlg, config);
1908 :     if (config->mode == RC_MODE_1PASS) {
1909 :     adv_dialog(hDlg, config, single_dlgs, sizeof(single_dlgs)/sizeof(int));
1910 :     }else if (config->mode == RC_MODE_2PASS1) {
1911 :     adv_dialog(hDlg, config, pass1_dlgs, sizeof(pass1_dlgs)/sizeof(int));
1912 :     }else if (config->mode == RC_MODE_2PASS2) {
1913 :     adv_dialog(hDlg, config, pass2_dlgs, sizeof(pass2_dlgs)/sizeof(int));
1914 :     }
1915 :     break;
1916 :    
1917 :     case IDC_BITRATE_S :
1918 :     /* alternate between bitrate/desired_length metrics */
1919 :     main_download(hDlg, config);
1920 :     config->use_2pass_bitrate = !config->use_2pass_bitrate;
1921 :     main_mode(hDlg, config);
1922 :     main_upload(hDlg, config);
1923 :     break;
1924 :    
1925 :     case IDC_BITRATE_ADV :
1926 :     main_download(hDlg, config);
1927 :     adv_dialog(hDlg, config, bitrate_dlgs, sizeof(bitrate_dlgs)/sizeof(int));
1928 :     main_mode(hDlg, config);
1929 :     main_upload(hDlg, config);
1930 :     break;
1931 :    
1932 :     case IDC_DECODER :
1933 :     main_download(hDlg, config);
1934 :     adv_dialog(hDlg, config, decoder_dlgs, sizeof(decoder_dlgs)/sizeof(int));
1935 :     main_mode(hDlg, config);
1936 :     break;
1937 :    
1938 :     case IDC_ADD :
1939 :     {
1940 :     int i, sel, new_frame;
1941 :    
1942 :     if (config->num_zones >= MAX_ZONES) {
1943 :     MessageBox(hDlg, "Exceeded maximum number of zones.\nIncrease config.h:MAX_ZONES and rebuild.", "Warning", 0);
1944 :     break;
1945 :     }
1946 :    
1947 :     sel = ListView_GetNextItem(GetDlgItem(hDlg, IDC_ZONES), -1, LVNI_SELECTED);
1948 :    
1949 :     if (sel<0) {
1950 :     if (config->ci_valid && config->ci.ciActiveFrame>0) {
1951 :     for(sel=0; sel<config->num_zones-1 && config->zones[sel].frame<config->ci.ciActiveFrame; sel++) ;
1952 :     sel--;
1953 :     new_frame = config->ci.ciActiveFrame;
1954 :     }else{
1955 :     sel = config->num_zones-1;
1956 :     new_frame = sel<0 ? 0 : config->zones[sel].frame + 1;
1957 :     }
1958 :     }else{
1959 :     new_frame = config->zones[sel].frame + 1;
1960 :     }
1961 :    
1962 :     for(i=config->num_zones-1; i>sel; i--) {
1963 :     config->zones[i+1] = config->zones[i];
1964 :     }
1965 :     config->num_zones++;
1966 :     config->zones[sel+1].frame = new_frame;
1967 :     config->zones[sel+1].mode = RC_ZONE_WEIGHT;
1968 :     config->zones[sel+1].weight = 100;
1969 :     config->zones[sel+1].quant = 500;
1970 :     config->zones[sel+1].type = XVID_TYPE_AUTO;
1971 :     config->zones[sel+1].greyscale = 0;
1972 :     config->zones[sel+1].chroma_opt = 0;
1973 :     config->zones[sel+1].bvop_threshold = 0;
1974 :    
1975 :     ListView_SetItemState(GetDlgItem(hDlg, IDC_ZONES), sel, 0x00000000, LVIS_SELECTED);
1976 :     zones_update(hDlg, config);
1977 :     ListView_SetItemState(GetDlgItem(hDlg, IDC_ZONES), sel+1, 0xffffffff, LVIS_SELECTED);
1978 :     break;
1979 :     }
1980 :    
1981 :     case IDC_REMOVE :
1982 :     {
1983 :     int i, sel;
1984 :     sel = ListView_GetNextItem(GetDlgItem(hDlg, IDC_ZONES), -1, LVNI_SELECTED);
1985 :    
1986 :     if (sel == -1 || config->num_zones < 1) {
1987 :     /*MessageBox(hDlg, "Nothing selected", "Warning", 0);*/
1988 :     break;
1989 :     }
1990 :    
1991 :     for (i=sel; i<config->num_zones-1; i++)
1992 :     config->zones[i] = config->zones[i+1];
1993 :    
1994 :     config->num_zones--;
1995 :    
1996 :     zones_update(hDlg, config);
1997 :     break;
1998 :     }
1999 :    
2000 :     case IDC_EDIT :
2001 :     main_download(hDlg, config);
2002 :     config->cur_zone = ListView_GetNextItem(GetDlgItem(hDlg, IDC_ZONES), -1, LVNI_SELECTED);
2003 :     if (config->cur_zone != -1 && adv_dialog(hDlg, config, zone_dlgs, sizeof(zone_dlgs)/sizeof(int))) {
2004 :     zones_update(hDlg, config);
2005 :     }
2006 :     break;
2007 :    
2008 :     case IDC_ADVANCED :
2009 :     main_download(hDlg, config);
2010 :     adv_dialog(hDlg, config, adv_dlgs, sizeof(adv_dlgs)/sizeof(int));
2011 :     break;
2012 :    
2013 :     case IDC_DEFAULTS :
2014 :     config_reg_default(config);
2015 : syskin 1440 SendDlgItemMessage(hDlg, IDC_PROFILE, CB_SETCURSEL, config->profile, 0);
2016 :     SendDlgItemMessage(hDlg, IDC_MODE, CB_SETCURSEL, config->mode, 0);
2017 : edgomez 1382 main_mode(hDlg, config);
2018 :     main_upload(hDlg, config);
2019 :     break;
2020 :    
2021 :     case IDOK :
2022 :     main_download(hDlg, config);
2023 :     config->save = TRUE;
2024 :     EndDialog(hDlg, IDOK);
2025 :     break;
2026 :    
2027 :     case IDCANCEL :
2028 :     config->save = FALSE;
2029 :     EndDialog(hDlg, IDCANCEL);
2030 :     break;
2031 :     }
2032 :     } else if (HIWORD(wParam) == LBN_SELCHANGE &&
2033 :     (LOWORD(wParam)==IDC_PROFILE || LOWORD(wParam)==IDC_MODE)) {
2034 :    
2035 :     config->mode = SendDlgItemMessage(hDlg, IDC_MODE, CB_GETCURSEL, 0, 0);
2036 :     config->profile = SendDlgItemMessage(hDlg, IDC_PROFILE, CB_GETCURSEL, 0, 0);
2037 :    
2038 :     if (!g_use_bitrate) {
2039 :     if (config->mode == RC_MODE_1PASS)
2040 :     set_dlgitem_float(hDlg, IDC_BITRATE, config->desired_quant);
2041 :     else if (config->mode == RC_MODE_2PASS2)
2042 :     SetDlgItemInt(hDlg, IDC_BITRATE, config->desired_size, FALSE);
2043 :     }
2044 :    
2045 :     main_mode(hDlg, config);
2046 :     main_upload(hDlg, config);
2047 :    
2048 :     }else if (HIWORD(wParam)==EN_UPDATE && LOWORD(wParam)==IDC_BITRATE) {
2049 :    
2050 :     if (g_use_bitrate) {
2051 :     SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETPOS, TRUE,
2052 :     config_get_uint(hDlg, IDC_BITRATE, DEFAULT_MIN_KBPS) );
2053 :     } else if (config->mode == RC_MODE_1PASS) {
2054 :     SendDlgItemMessage(hDlg, IDC_SLIDER, TBM_SETPOS, TRUE,
2055 :     get_dlgitem_float(hDlg, IDC_BITRATE, DEFAULT_QUANT) );
2056 :     }
2057 :     main_download(hDlg, config);
2058 :    
2059 :     }else {
2060 :     return 0;
2061 :     }
2062 :     break;
2063 :    
2064 :     case WM_HSCROLL :
2065 :     if((HWND)lParam == GetDlgItem(hDlg, IDC_SLIDER)) {
2066 :     if (g_use_bitrate)
2067 :     SetDlgItemInt(hDlg, IDC_BITRATE, SendMessage((HWND)lParam, TBM_GETPOS, 0, 0), FALSE);
2068 :     else
2069 :     set_dlgitem_float(hDlg, IDC_BITRATE, SendMessage((HWND)lParam, TBM_GETPOS, 0, 0));
2070 :    
2071 :     main_download(hDlg, config);
2072 :     break;
2073 :     }
2074 :     return 0;
2075 :    
2076 :     default :
2077 :     return 0;
2078 :     }
2079 :    
2080 :     return 1;
2081 :     }
2082 :    
2083 :    
2084 :    
2085 :     /* ===================================================================================== */
2086 :     /* ABOUT DIALOG ======================================================================== */
2087 :     /* ===================================================================================== */
2088 :    
2089 :     BOOL CALLBACK about_proc(HWND hDlg, UINT uMsg, WPARAM wParam, LPARAM lParam)
2090 :     {
2091 :     switch (uMsg)
2092 :     {
2093 :     case WM_INITDIALOG :
2094 :     {
2095 :     xvid_gbl_info_t info;
2096 :     char core[100];
2097 :     HFONT hFont;
2098 :     LOGFONT lfData;
2099 :     HINSTANCE m_hdll;
2100 :    
2101 :     SetDlgItemText(hDlg, IDC_BUILD, XVID_BUILD);
2102 :     SetDlgItemText(hDlg, IDC_SPECIAL_BUILD, XVID_SPECIAL_BUILD);
2103 :    
2104 :     memset(&info, 0, sizeof(info));
2105 :     info.version = XVID_VERSION;
2106 :    
2107 :     m_hdll = LoadLibrary(XVID_DLL_NAME);
2108 :     if (m_hdll != NULL) {
2109 :    
2110 :     ((int (__cdecl *)(void *, int, void *, void *))GetProcAddress(m_hdll, "xvid_global"))
2111 :     (0, XVID_GBL_INFO, &info, NULL);
2112 :    
2113 :     wsprintf(core, "xvidcore.dll version %d.%d.%d (\"%s\")",
2114 :     XVID_VERSION_MAJOR(info.actual_version),
2115 :     XVID_VERSION_MINOR(info.actual_version),
2116 :     XVID_VERSION_PATCH(info.actual_version),
2117 :     info.build);
2118 :    
2119 :     FreeLibrary(m_hdll);
2120 :     } else {
2121 :     wsprintf(core, "xvidcore.dll not found!");
2122 :     }
2123 :    
2124 :     SetDlgItemText(hDlg, IDC_CORE, core);
2125 :    
2126 :     hFont = (HFONT)SendDlgItemMessage(hDlg, IDC_WEBSITE, WM_GETFONT, 0, 0L);
2127 :    
2128 :     if (GetObject(hFont, sizeof(LOGFONT), &lfData)) {
2129 :     lfData.lfUnderline = 1;
2130 :    
2131 :     hFont = CreateFontIndirect(&lfData);
2132 :     if (hFont) {
2133 :     SendDlgItemMessage(hDlg, IDC_WEBSITE, WM_SETFONT, (WPARAM)hFont, 1L);
2134 :     }
2135 :     }
2136 :    
2137 :     SetClassLong(GetDlgItem(hDlg, IDC_WEBSITE), GCL_HCURSOR, (LONG)LoadCursor(NULL, IDC_HAND));
2138 :     SetDlgItemText(hDlg, IDC_WEBSITE, XVID_WEBSITE);
2139 :     }
2140 :     break;
2141 :     case WM_CTLCOLORSTATIC :
2142 :     if ((HWND)lParam == GetDlgItem(hDlg, IDC_WEBSITE))
2143 :     {
2144 :     SetBkMode((HDC)wParam, TRANSPARENT) ;
2145 :     SetTextColor((HDC)wParam, RGB(0x00,0x00,0xc0));
2146 :     return (BOOL)GetStockObject(NULL_BRUSH);
2147 :     }
2148 :     return 0;
2149 :    
2150 :     case WM_COMMAND :
2151 :     if (LOWORD(wParam) == IDC_WEBSITE && HIWORD(wParam) == STN_CLICKED)
2152 :     {
2153 :     ShellExecute(hDlg, "open", XVID_WEBSITE, NULL, NULL, SW_SHOWNORMAL);
2154 :     }
2155 :     else if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
2156 :     {
2157 :     EndDialog(hDlg, LOWORD(wParam));
2158 :     }
2159 :     break;
2160 :    
2161 :     default :
2162 :     return 0;
2163 :     }
2164 :    
2165 :     return 1;
2166 :     }
2167 :    
2168 :    
2169 :     void
2170 :     sort_zones(zone_t * zones, int zone_num, int * sel)
2171 :     {
2172 :     int i, j;
2173 :     zone_t tmp;
2174 :     for (i = 0; i < zone_num; i++) {
2175 :     int cur = i;
2176 :     int min_f = zones[i].frame;
2177 :     for (j = i + 1; j < zone_num; j++) {
2178 :     if (zones[j].frame < min_f) {
2179 :     min_f = zones[j].frame;
2180 :     cur = j;
2181 :     }
2182 :     }
2183 :     if (cur != i) {
2184 :     tmp = zones[i];
2185 :     zones[i] = zones[cur];
2186 :     zones[cur] = tmp;
2187 :     if (i == *sel) *sel = cur;
2188 :     else if (cur == *sel) *sel = i;
2189 :     }
2190 :     }
2191 :     }
2192 :    
2193 :    
2194 :     static void
2195 :     zones_update(HWND hDlg, CONFIG * config)
2196 :     {
2197 :     int i, sel;
2198 :    
2199 :     sel = ListView_GetNextItem(GetDlgItem(hDlg, IDC_ZONES), -1, LVNI_SELECTED);
2200 :    
2201 :     sort_zones(config->zones, config->num_zones, &sel);
2202 :    
2203 :     ListView_DeleteAllItems(GetDlgItem(hDlg,IDC_ZONES));
2204 :    
2205 :     for (i = 0; i < config->num_zones; i++)
2206 :     main_insert_zone(GetDlgItem(hDlg,IDC_ZONES), &config->zones[i], i, TRUE);
2207 :    
2208 :     if (sel == -1 && config->num_zones > 0) sel = 0;
2209 :     if (sel >= config->num_zones) sel = config->num_zones-1;
2210 :    
2211 :     config->cur_zone = sel;
2212 :     ListView_SetItemState(GetDlgItem(hDlg, IDC_ZONES), sel, 0xffffffff, LVIS_SELECTED);
2213 :     }

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4