1 /*****************************************************************************
2 * menus.cpp : WinCE gui plugin for VLC
3 *****************************************************************************
4 * Copyright (C) 2000-2004 the VideoLAN team
7 * Authors: Marodon Cedric <cedric_marodon@yahoo.fr>
8 * Gildas Bazin <gbazin@videolan.org>
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
23 *****************************************************************************/
25 /*****************************************************************************
27 *****************************************************************************/
29 #include <vlc_interface.h>
33 /*****************************************************************************
35 *****************************************************************************/
37 /* IDs for the controls and the menu commands */
41 MenuDummy_Event = 1000,
42 OpenFileSimple_Event = 1100,
46 FirstAutoGenerated_Event = 1999,
47 SettingsMenu_Events = 2000,
48 AudioMenu_Events = 3000,
49 VideoMenu_Events = 4000,
50 NavigMenu_Events = 5000,
51 PopupMenu_Events = 6000
54 HMENU OpenStreamMenu( intf_thread_t *p_intf )
56 HMENU hmenu = CreatePopupMenu();
57 AppendMenu( hmenu, MF_STRING, ID_FILE_QUICKOPEN,
58 _T("Quick &Open File...") );
59 AppendMenu( hmenu, MF_STRING, ID_FILE_OPENFILE,
60 _T("Open &File...") );
61 AppendMenu( hmenu, MF_STRING, ID_FILE_OPENNET,
62 _T("Open &Network Stream...") );
66 HMENU MiscMenu( intf_thread_t *p_intf )
68 HMENU hmenu = CreatePopupMenu();
69 AppendMenu( hmenu, MF_STRING, ID_VIEW_STREAMINFO, _T("Media &Info...") );
70 AppendMenu( hmenu, MF_STRING, ID_VIEW_MESSAGES, _T("&Messages...") );
71 AppendMenu( hmenu, MF_STRING, ID_PREFERENCES, _T("&Preferences...") );
75 void PopupMenu( intf_thread_t *p_intf, HWND p_parent, POINT point )
77 #define MAX_POPUP_ITEMS 45
79 vlc_object_t *p_object, *p_input;
80 char *ppsz_varnames[MAX_POPUP_ITEMS];
81 int pi_objects[MAX_POPUP_ITEMS];
82 int i = 0, i_last_separator = 0;
85 memset( pi_objects, 0, MAX_POPUP_ITEMS * sizeof(int) );
87 ppsz_varnames[i] = "VLC media player";
89 ppsz_varnames[i++] = NULL; /* Separator */
93 p_object = (vlc_object_t *)vlc_object_find( p_intf, VLC_OBJECT_INPUT,
95 if( p_object != NULL )
97 ppsz_varnames[i] = "bookmark";
98 pi_objects[i++] = p_object->i_object_id;
99 ppsz_varnames[i] = "title";
100 pi_objects[i++] = p_object->i_object_id;
101 ppsz_varnames[i] = "chapter";
102 pi_objects[i++] = p_object->i_object_id;
103 ppsz_varnames[i] = "program";
104 pi_objects[i++] = p_object->i_object_id;
105 ppsz_varnames[i] = "navigation";
106 pi_objects[i++] = p_object->i_object_id;
107 ppsz_varnames[i] = "dvd_menus";
108 pi_objects[i++] = p_object->i_object_id;
110 ppsz_varnames[i] = "video-es";
111 pi_objects[i++] = p_object->i_object_id;
112 ppsz_varnames[i] = "audio-es";
113 pi_objects[i++] = p_object->i_object_id;
114 ppsz_varnames[i] = "spu-es";
115 pi_objects[i++] = p_object->i_object_id;
118 if( !p_input ) goto interfacemenu;
121 if( i != i_last_separator ) ppsz_varnames[i++] = NULL; /* Separator */
122 i_last_separator = i;
124 p_object = (vlc_object_t *)vlc_object_find( p_intf, VLC_OBJECT_VOUT,
126 if( p_object != NULL )
128 vlc_object_t *p_dec_obj;
130 ppsz_varnames[i] = "fullscreen";
131 pi_objects[i++] = p_object->i_object_id;
132 ppsz_varnames[i] = "zoom";
133 pi_objects[i++] = p_object->i_object_id;
134 ppsz_varnames[i] = "deinterlace";
135 pi_objects[i++] = p_object->i_object_id;
136 ppsz_varnames[i] = "aspect-ratio";
137 pi_objects[i++] = p_object->i_object_id;
138 ppsz_varnames[i] = "crop";
139 pi_objects[i++] = p_object->i_object_id;
140 ppsz_varnames[i] = "video-on-top";
141 pi_objects[i++] = p_object->i_object_id;
142 ppsz_varnames[i] = "directx-wallpaper";
143 pi_objects[i++] = p_object->i_object_id;
144 ppsz_varnames[i] = "video-snapshot";
145 pi_objects[i++] = p_object->i_object_id;
147 p_dec_obj = (vlc_object_t *)vlc_object_find( p_object,
150 if( p_dec_obj != NULL )
152 ppsz_varnames[i] = "ffmpeg-pp-q";
153 pi_objects[i++] = p_dec_obj->i_object_id;
154 vlc_object_release( p_dec_obj );
157 vlc_object_release( p_object );
161 if( i != i_last_separator ) ppsz_varnames[i++] = NULL; /* Separator */
162 i_last_separator = i;
164 p_object = (vlc_object_t *)vlc_object_find( p_intf, VLC_OBJECT_AOUT,
166 if( p_object != NULL )
168 ppsz_varnames[i] = "audio-device";
169 pi_objects[i++] = p_object->i_object_id;
170 ppsz_varnames[i] = "audio-channels";
171 pi_objects[i++] = p_object->i_object_id;
172 ppsz_varnames[i] = "visual";
173 pi_objects[i++] = p_object->i_object_id;
174 ppsz_varnames[i] = "equalizer";
175 pi_objects[i++] = p_object->i_object_id;
176 vlc_object_release( p_object );
181 if( i != i_last_separator ) ppsz_varnames[i++] = NULL; /* Separator */
182 i_last_separator = i;
184 /* vlc_object_find is needed because of the dialogs provider case */
185 p_object = (vlc_object_t *)vlc_object_find( p_intf, VLC_OBJECT_INTF,
187 if( p_object != NULL )
189 /* Nothing for now */
190 vlc_object_release( p_object );
194 vector<MenuItemExt*> popup_menu;
195 HMENU hmenu = CreatePopupMenu();
196 RefreshMenu( p_intf, &popup_menu, hmenu, i,
197 ppsz_varnames, pi_objects, PopupMenu_Events );
198 MenuItemExt::ClearList( &popup_menu );
201 /* Add static entries */
202 if( p_input != NULL )
205 AppendMenu( hmenu, MF_SEPARATOR, 0, _T("") );
206 AppendMenu( hmenu, MF_STRING, StopStream_Event, _T("Stop") );
207 AppendMenu( hmenu, MF_STRING, PrevStream_Event, _T("Previous") );
208 AppendMenu( hmenu, MF_STRING, NextStream_Event, _T("Next") );
210 var_Get( p_input, "state", &val );
211 if( val.i_int == PAUSE_S )
212 AppendMenu( hmenu, MF_STRING, PlayStream_Event, _T("Play") );
214 AppendMenu( hmenu, MF_STRING, PlayStream_Event, _T("Pause") );
216 vlc_object_release( p_input );
220 playlist_t * p_playlist =
221 (playlist_t *)vlc_object_find( p_intf, VLC_OBJECT_PLAYLIST,
223 if( p_playlist && p_playlist->i_size )
225 AppendMenu( hmenu, MF_SEPARATOR, 0, _T("") );
226 AppendMenu( hmenu, MF_STRING, PlayStream_Event, _T("Play") );
228 if( p_playlist ) vlc_object_release( p_playlist );
231 AppendMenu( hmenu, MF_POPUP|MF_STRING, (UINT)MiscMenu( p_intf ),
232 _T("Miscellaneous") );
233 AppendMenu( hmenu, MF_POPUP|MF_STRING, (UINT)OpenStreamMenu( p_intf ),
236 TrackPopupMenu( hmenu, 0, point.x, point.y, 0, p_parent, 0 );
237 PostMessage( p_parent, WM_NULL, 0, 0 );
238 DestroyMenu( hmenu );
241 void RefreshAudioMenu( intf_thread_t *p_intf, HMENU hMenu )
243 #define MAX_AUDIO_ITEMS 10
245 vlc_object_t *p_object;
246 char *ppsz_varnames[MAX_AUDIO_ITEMS];
247 int pi_objects[MAX_AUDIO_ITEMS];
250 /* Delete old menu */
251 int count = wce_GetMenuItemCount( hMenu );
252 for( i = 0; i <= count; i++ ) RemoveMenu( hMenu, 0, MF_BYPOSITION );
254 if( p_intf->p_sys->p_audio_menu )
255 MenuItemExt::ClearList( p_intf->p_sys->p_audio_menu );
256 else p_intf->p_sys->p_audio_menu = new vector<MenuItemExt*>;
259 /* Initializations */
260 memset( pi_objects, 0, MAX_AUDIO_ITEMS * sizeof(int) );
263 p_object = (vlc_object_t *)
264 vlc_object_find( p_intf, VLC_OBJECT_INPUT, FIND_ANYWHERE );
265 if( p_object != NULL )
267 ppsz_varnames[i] = "audio-es";
268 pi_objects[i++] = p_object->i_object_id;
269 vlc_object_release( p_object );
272 p_object = (vlc_object_t *)
273 vlc_object_find( p_intf, VLC_OBJECT_AOUT, FIND_ANYWHERE );
274 if( p_object != NULL )
276 ppsz_varnames[i] = "audio-device";
277 pi_objects[i++] = p_object->i_object_id;
278 ppsz_varnames[i] = "audio-channels";
279 pi_objects[i++] = p_object->i_object_id;
280 ppsz_varnames[i] = "visual";
281 pi_objects[i++] = p_object->i_object_id;
282 vlc_object_release( p_object );
286 RefreshMenu( p_intf, p_intf->p_sys->p_audio_menu,
287 hMenu, i, ppsz_varnames, pi_objects, AudioMenu_Events );
290 void RefreshVideoMenu( intf_thread_t *p_intf, HMENU hMenu )
292 #define MAX_VIDEO_ITEMS 15
294 vlc_object_t *p_object;
295 char *ppsz_varnames[MAX_VIDEO_ITEMS];
296 int pi_objects[MAX_VIDEO_ITEMS];
299 /* Delete old menu */
300 int count = wce_GetMenuItemCount( hMenu );
301 for( i = 0; i <= count; i++ ) RemoveMenu( hMenu, 0, MF_BYPOSITION );
303 if( p_intf->p_sys->p_video_menu )
304 MenuItemExt::ClearList( p_intf->p_sys->p_video_menu );
305 else p_intf->p_sys->p_video_menu = new vector<MenuItemExt*>;
307 /* Initializations */
308 memset( pi_objects, 0, MAX_VIDEO_ITEMS * sizeof(int) );
311 p_object = (vlc_object_t *)
312 vlc_object_find( p_intf, VLC_OBJECT_INPUT, FIND_ANYWHERE );
313 if( p_object != NULL )
315 ppsz_varnames[i] = "video-es";
316 pi_objects[i++] = p_object->i_object_id;
317 ppsz_varnames[i] = "spu-es";
318 pi_objects[i++] = p_object->i_object_id;
319 vlc_object_release( p_object );
322 p_object = (vlc_object_t *)
323 vlc_object_find( p_intf, VLC_OBJECT_VOUT, FIND_ANYWHERE );
324 if( p_object != NULL )
326 vlc_object_t *p_dec_obj;
328 ppsz_varnames[i] = "fullscreen";
329 pi_objects[i++] = p_object->i_object_id;
331 ppsz_varnames[i] = "transform";
332 pi_objects[i++] = p_object->i_object_id;
334 ppsz_varnames[i] = "zoom";
335 pi_objects[i++] = p_object->i_object_id;
336 ppsz_varnames[i] = "deinterlace";
337 pi_objects[i++] = p_object->i_object_id;
338 ppsz_varnames[i] = "aspect-ratio";
339 pi_objects[i++] = p_object->i_object_id;
340 ppsz_varnames[i] = "crop";
341 pi_objects[i++] = p_object->i_object_id;
342 ppsz_varnames[i] = "directx-on-top";
343 pi_objects[i++] = p_object->i_object_id;
345 p_dec_obj = (vlc_object_t *)
346 vlc_object_find( p_object, VLC_OBJECT_DECODER, FIND_PARENT );
347 if( p_dec_obj != NULL )
349 ppsz_varnames[i] = "ffmpeg-pp-q";
350 pi_objects[i++] = p_dec_obj->i_object_id;
351 vlc_object_release( p_dec_obj );
354 vlc_object_release( p_object );
358 RefreshMenu( p_intf, p_intf->p_sys->p_video_menu, hMenu, i,
359 ppsz_varnames, pi_objects, VideoMenu_Events );
362 void RefreshNavigMenu( intf_thread_t *p_intf, HMENU hMenu )
364 #define MAX_NAVIG_ITEMS 10
366 vlc_object_t *p_object;
367 char *ppsz_varnames[MAX_NAVIG_ITEMS];
368 int pi_objects[MAX_NAVIG_ITEMS];
371 /* Delete old menu */
372 int count = wce_GetMenuItemCount( hMenu );
373 for( i = 0; i <= count; i++ ) RemoveMenu( hMenu, 0, MF_BYPOSITION );
375 if( p_intf->p_sys->p_navig_menu )
376 MenuItemExt::ClearList( p_intf->p_sys->p_navig_menu );
377 else p_intf->p_sys->p_navig_menu = new vector<MenuItemExt*>;
379 /* Initializations */
380 memset( pi_objects, 0, MAX_NAVIG_ITEMS * sizeof(int) );
383 p_object = (vlc_object_t *)
384 vlc_object_find( p_intf, VLC_OBJECT_INPUT, FIND_ANYWHERE );
385 if( p_object != NULL )
387 ppsz_varnames[i] = "title";
388 pi_objects[i++] = p_object->i_object_id;
389 ppsz_varnames[i] = "chapter";
390 pi_objects[i++] = p_object->i_object_id;
391 ppsz_varnames[i] = "program";
392 pi_objects[i++] = p_object->i_object_id;
393 ppsz_varnames[i] = "navigation";
394 pi_objects[i++] = p_object->i_object_id;
395 ppsz_varnames[i] = "dvd_menus";
396 pi_objects[i++] = p_object->i_object_id;
398 ppsz_varnames[i] = "prev-title";
399 pi_objects[i++] = p_object->i_object_id;
400 ppsz_varnames[i] = "next-title";
401 pi_objects[i++] = p_object->i_object_id;
402 ppsz_varnames[i] = "prev-chapter";
403 pi_objects[i++] = p_object->i_object_id;
404 ppsz_varnames[i] = "next-chapter";
405 pi_objects[i++] = p_object->i_object_id;
407 vlc_object_release( p_object );
411 RefreshMenu( p_intf, p_intf->p_sys->p_navig_menu, hMenu, i,
412 ppsz_varnames, pi_objects, NavigMenu_Events );
415 void RefreshSettingsMenu( intf_thread_t *p_intf, HMENU hMenu )
417 #define MAX_SETTINGS_ITEMS 10
419 vlc_object_t *p_object;
420 char *ppsz_varnames[MAX_SETTINGS_ITEMS];
421 int pi_objects[MAX_SETTINGS_ITEMS];
424 /* Delete old menu */
425 int count = wce_GetMenuItemCount( hMenu );
426 for( i = 0; i <= count; i++ ) RemoveMenu( hMenu, 0, MF_BYPOSITION );
428 if( p_intf->p_sys->p_settings_menu )
429 MenuItemExt::ClearList( p_intf->p_sys->p_settings_menu );
430 else p_intf->p_sys->p_settings_menu = new vector<MenuItemExt*>;
432 /* Initializations */
433 memset( pi_objects, 0, MAX_SETTINGS_ITEMS * sizeof(int) );
436 AppendMenu( hMenu, MF_STRING, ID_PREFERENCES, _T("&Preferences...") );
438 p_object = (vlc_object_t *)
439 vlc_object_find( p_intf, VLC_OBJECT_INTF, FIND_PARENT );
440 if( p_object != NULL )
442 ppsz_varnames[i] = "intf-switch";
443 pi_objects[i++] = p_object->i_object_id;
444 ppsz_varnames[i] = "intf-add";
445 pi_objects[i++] = p_object->i_object_id;
446 vlc_object_release( p_object );
450 RefreshMenu( p_intf, p_intf->p_sys->p_settings_menu, hMenu, i,
451 ppsz_varnames, pi_objects, SettingsMenu_Events );
454 /*****************************************************************************
456 *****************************************************************************/
457 void RefreshMenu( intf_thread_t *p_intf, vector<MenuItemExt*> *p_menu_list,
458 HMENU hMenu , int i_count, char **ppsz_varnames,
459 int *pi_objects, int i_start_id )
461 vlc_object_t *p_object;
462 vlc_bool_t b_section_empty = VLC_FALSE;
465 /* Initializations */
466 int i_item_id = i_start_id;
468 for( i = 0; i < i_count; i++ )
470 if( !ppsz_varnames[i] )
472 if( b_section_empty )
474 AppendMenu( hMenu, MF_GRAYED | MF_STRING,
475 MenuDummy_Event + i, _T("Empty") );
478 AppendMenu( hMenu, MF_SEPARATOR, 0, _T("") );
479 b_section_empty = VLC_TRUE;
485 AppendMenu( hMenu, MF_GRAYED | MF_STRING,
486 MenuDummy_Event, _FROMMB(ppsz_varnames[i]) );
488 b_section_empty = VLC_FALSE;
492 p_object = (vlc_object_t *)vlc_object_get( p_intf, pi_objects[i] );
493 if( p_object == NULL ) continue;
495 b_section_empty = VLC_FALSE;
496 CreateMenuItem( p_intf, p_menu_list, hMenu, ppsz_varnames[i],
497 p_object, &i_item_id );
498 vlc_object_release( p_object );
501 /* Special case for empty menus */
502 if( wce_GetMenuItemCount(hMenu) == 0 || b_section_empty )
504 AppendMenu( hMenu, MF_GRAYED | MF_STRING,
505 MenuDummy_Event + i, _T("Empty") );
509 /*****************************************************************************
511 *****************************************************************************/
512 void CreateMenuItem( intf_thread_t *p_intf, vector<MenuItemExt*> *p_menu_list,
513 HMENU hMenu, char *psz_var, vlc_object_t *p_object,
516 MenuItemExt *pMenuItemExt;
518 vlc_value_t val, text;
521 /* Check the type of the object variable */
522 i_type = var_Type( p_object, psz_var );
524 switch( i_type & VLC_VAR_TYPE )
528 case VLC_VAR_VARIABLE:
530 case VLC_VAR_INTEGER:
534 /* Variable doesn't exist or isn't handled */
538 /* Make sure we want to display the variable */
539 if( i_type & VLC_VAR_HASCHOICE )
541 var_Change( p_object, psz_var, VLC_VAR_CHOICESCOUNT, &val, NULL );
542 if( val.i_int == 0 ) return;
543 if( (i_type & VLC_VAR_TYPE) != VLC_VAR_VARIABLE && val.i_int == 1 )
547 /* Get the descriptive name of the variable */
548 var_Change( p_object, psz_var, VLC_VAR_GETTEXT, &text, NULL );
550 var_Get( p_object, psz_var, &val );
552 if( i_type & VLC_VAR_HASCHOICE )
554 hMenuItem = CreateChoicesMenu( p_intf, p_menu_list, psz_var,
555 p_object, pi_item_id );
556 AppendMenu( hMenu, MF_STRING | MF_POPUP, (UINT)hMenuItem,
557 _FROMMB(text.psz_string ? text.psz_string : psz_var) );
558 if( (i_type & VLC_VAR_TYPE) == VLC_VAR_STRING ) free( val.psz_string );
559 if( text.psz_string ) free( text.psz_string );
563 switch( i_type & VLC_VAR_TYPE )
566 AppendMenu( hMenu, MF_STRING , ++(*pi_item_id),
567 _FROMMB(text.psz_string ? text.psz_string : psz_var) );
568 pMenuItemExt = new MenuItemExt( p_intf, *pi_item_id, psz_var,
569 p_object->i_object_id, val, i_type );
570 p_menu_list->push_back( pMenuItemExt );
574 val.b_bool = !val.b_bool;
575 AppendMenu( hMenu, MF_STRING | MF_CHECKED, ++(*pi_item_id),
576 _FROMMB(text.psz_string ? text.psz_string : psz_var) );
577 pMenuItemExt = new MenuItemExt( p_intf, *pi_item_id, psz_var,
578 p_object->i_object_id, val, i_type );
579 p_menu_list->push_back( pMenuItemExt );
580 CheckMenuItem( hMenu, *pi_item_id ,
581 ( val.b_bool ? MF_UNCHECKED : MF_CHECKED ) |
586 if( text.psz_string ) free( text.psz_string );
590 if( (i_type & VLC_VAR_TYPE) == VLC_VAR_STRING ) free( val.psz_string );
591 if( text.psz_string ) free( text.psz_string );
594 HMENU CreateChoicesMenu( intf_thread_t *p_intf,
595 vector<MenuItemExt*> *p_menu_list, char *psz_var,
596 vlc_object_t *p_object, int *pi_item_id )
598 MenuItemExt *pMenuItemExt;
599 vlc_value_t val, val_list, text_list;
601 HMENU hSubMenu = CreatePopupMenu();
603 /* Check the type of the object variable */
604 i_type = var_Type( p_object, psz_var );
606 /* Make sure we want to display the variable */
607 if( i_type & VLC_VAR_HASCHOICE )
609 var_Change( p_object, psz_var, VLC_VAR_CHOICESCOUNT, &val, NULL );
610 if( val.i_int == 0 ) return NULL;
611 if( (i_type & VLC_VAR_TYPE) != VLC_VAR_VARIABLE && val.i_int == 1 )
619 switch( i_type & VLC_VAR_TYPE )
623 case VLC_VAR_VARIABLE:
625 case VLC_VAR_INTEGER:
628 /* Variable doesn't exist or isn't handled */
632 if( var_Get( p_object, psz_var, &val ) < 0 ) return NULL;
634 if( var_Change( p_object, psz_var, VLC_VAR_GETLIST,
635 &val_list, &text_list ) < 0 )
637 if( (i_type & VLC_VAR_TYPE) == VLC_VAR_STRING ) free( val.psz_string );
641 for( i = 0; i < val_list.p_list->i_count; i++ )
643 vlc_value_t another_val;
647 switch( i_type & VLC_VAR_TYPE )
649 case VLC_VAR_VARIABLE:
650 hMenuItem = CreateChoicesMenu( p_intf, p_menu_list,
651 val_list.p_list->p_values[i].psz_string, p_object, pi_item_id );
652 AppendMenu( hSubMenu, MF_STRING | MF_POPUP, (UINT)hMenuItem,
653 _FROMMB(text_list.p_list->p_values[i].psz_string ?
654 text_list.p_list->p_values[i].psz_string :
655 val_list.p_list->p_values[i].psz_string) );
659 another_val.psz_string =
660 strdup(val_list.p_list->p_values[i].psz_string);
661 AppendMenu( hSubMenu, MF_STRING, ++(*pi_item_id),
662 _FROMMB(text_list.p_list->p_values[i].psz_string ?
663 text_list.p_list->p_values[i].psz_string :
664 val_list.p_list->p_values[i].psz_string) );
665 pMenuItemExt = new MenuItemExt( p_intf, *pi_item_id, psz_var,
666 p_object->i_object_id, another_val, i_type );
667 p_menu_list->push_back( pMenuItemExt );
669 if( !(i_type & VLC_VAR_ISCOMMAND) && val.psz_string &&
670 !strcmp( val.psz_string,
671 val_list.p_list->p_values[i].psz_string ) )
672 CheckMenuItem( hSubMenu, *pi_item_id, MF_CHECKED | MF_BYCOMMAND);
675 case VLC_VAR_INTEGER:
676 asprintf( &psz_tmp, "%d", val_list.p_list->p_values[i].i_int );
677 AppendMenu( hSubMenu, MF_STRING, ++(*pi_item_id),
678 _FROMMB(text_list.p_list->p_values[i].psz_string ?
679 text_list.p_list->p_values[i].psz_string : psz_tmp));
680 pMenuItemExt = new MenuItemExt( p_intf, *pi_item_id, psz_var,
681 p_object->i_object_id, val_list.p_list->p_values[i], i_type );
682 p_menu_list->push_back( pMenuItemExt );
684 if( val_list.p_list->p_values[i].i_int == val.i_int )
685 CheckMenuItem( hSubMenu, *pi_item_id, MF_CHECKED | MF_BYCOMMAND);
693 /* Clean up everything */
694 if( (i_type & VLC_VAR_TYPE) == VLC_VAR_STRING ) free( val.psz_string );
695 var_Change( p_object, psz_var, VLC_VAR_FREELIST, &val_list, &text_list );
700 int wce_GetMenuItemCount(HMENU hMenu)
702 const int MAX_NUM_ITEMS = 256;
706 memset( (char *)&mii, 0, sizeof(MENUITEMINFO) );
707 mii.cbSize = sizeof(MENUITEMINFO);
710 for( iPos = 0; iPos < MAX_NUM_ITEMS; iPos++ )
712 if( !GetMenuItemInfo(hMenu, (UINT)iPos, TRUE, &mii) ) break;
719 void OnMenuEvent( intf_thread_t *p_intf, int id )
721 MenuItemExt *p_menuitemext = NULL;
722 vector<MenuItemExt*>::iterator iter;
724 if( p_intf->p_sys->p_settings_menu )
725 for( iter = p_intf->p_sys->p_settings_menu->begin();
726 iter != p_intf->p_sys->p_settings_menu->end(); iter++ )
727 if( (*iter)->id == id )
729 p_menuitemext = *iter;
733 if( p_intf->p_sys->p_audio_menu && !p_menuitemext )
734 for( iter = p_intf->p_sys->p_audio_menu->begin();
735 iter != p_intf->p_sys->p_audio_menu->end(); iter++ )
736 if( (*iter)->id == id )
738 p_menuitemext = *iter;
742 if( p_intf->p_sys->p_video_menu && !p_menuitemext )
743 for( iter = p_intf->p_sys->p_video_menu->begin();
744 iter != p_intf->p_sys->p_video_menu->end(); iter++ )
745 if( (*iter)->id == id )
747 p_menuitemext = *iter;
751 if( p_intf->p_sys->p_navig_menu && !p_menuitemext )
752 for( iter = p_intf->p_sys->p_navig_menu->begin();
753 iter != p_intf->p_sys->p_navig_menu->end(); iter++ )
754 if( (*iter)->id == id )
756 p_menuitemext = *iter;
762 vlc_object_t *p_object = (vlc_object_t *)
763 vlc_object_get( p_intf, p_menuitemext->i_object_id );
764 if( p_object == NULL ) return;
766 var_Set( p_object, p_menuitemext->psz_var, p_menuitemext->val );
767 int i_type = var_Type( p_object, p_menuitemext->psz_var );
768 switch( i_type & VLC_VAR_TYPE )
772 case VLC_VAR_VARIABLE:
774 case VLC_VAR_INTEGER:
777 /* Variable doesn't exist or isn't handled */
781 vlc_object_release( p_object );
785 /*****************************************************************************
786 * A small helper class which encapsulate wxMenuitem with some other useful
788 *****************************************************************************/
789 MenuItemExt::MenuItemExt( intf_thread_t *p_intf, int _id, char *_psz_var,
790 int _i_object_id, vlc_value_t _val, int _i_val_type )
792 /* Initializations */
795 psz_var = strdup( _psz_var );
796 i_val_type = _i_val_type;
797 i_object_id = _i_object_id;
801 MenuItemExt::~MenuItemExt()
803 if( psz_var ) free( psz_var );
804 if( ((i_val_type & VLC_VAR_TYPE) == VLC_VAR_STRING)
805 && val.psz_string ) free( val.psz_string );
808 void MenuItemExt::ClearList( vector<MenuItemExt*> *p_menu_list )
810 vector<MenuItemExt*>::iterator iter;
812 if( !p_menu_list ) return;
813 for( iter = p_menu_list->begin(); iter != p_menu_list->end(); iter++ )
817 p_menu_list->clear();