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

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