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

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

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

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

Legend:
Removed from v.1497  
changed lines
  Added in v.1864

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