Commit f57fdbdd authored by Gildas Bazin's avatar Gildas Bazin

* modules/gui/wxwindows/preferences.cpp: compilation fix + cosmetic code clean-up
(indentations mainly).
parent a8855655
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* preferences.cpp : wxWindows plugin for vlc * preferences.cpp : wxWindows plugin for vlc
***************************************************************************** *****************************************************************************
* Copyright (C) 2000-2001 VideoLAN * Copyright (C) 2000-2001 VideoLAN
* $Id: preferences.cpp,v 1.28 2003/09/22 14:40:10 zorglub Exp $ * $Id: preferences.cpp,v 1.29 2003/09/22 21:07:35 gbazin Exp $
* *
* Authors: Gildas Bazin <gbazin@netcourrier.com> * Authors: Gildas Bazin <gbazin@netcourrier.com>
* *
...@@ -121,7 +121,7 @@ public: ...@@ -121,7 +121,7 @@ public:
PrefsPanel() { } PrefsPanel() { }
PrefsPanel( wxWindow *parent, intf_thread_t *_p_intf, PrefsPanel( wxWindow *parent, intf_thread_t *_p_intf,
PrefsDialog *_p_prefs_dialog, int i_object_id, char *, char * ); PrefsDialog *, int i_object_id, char *, char * );
virtual ~PrefsPanel() {} virtual ~PrefsPanel() {}
void ApplyChanges(); void ApplyChanges();
...@@ -344,32 +344,32 @@ void PrefsDialog::OnAdvanced( wxCommandEvent& event ) ...@@ -344,32 +344,32 @@ void PrefsDialog::OnAdvanced( wxCommandEvent& event )
static char * GetCapabilityHelp( char *psz_capability) static char * GetCapabilityHelp( char *psz_capability)
{ {
if( psz_capability == NULL) if( psz_capability == NULL)
return NULL; return NULL;
if( !strcasecmp(psz_capability,"access") ) if( !strcasecmp(psz_capability,"access") )
return strdup(ACCESS_HELP); return strdup(ACCESS_HELP);
if( !strcasecmp(psz_capability,"audio filter") ) if( !strcasecmp(psz_capability,"audio filter") )
return strdup(AUDIO_FILTER_HELP); return strdup(AUDIO_FILTER_HELP);
if( !strcasecmp(psz_capability,"audio output") ) if( !strcasecmp(psz_capability,"audio output") )
return strdup(AOUT_HELP); return strdup(AOUT_HELP);
if( !strcasecmp(psz_capability,"chroma") ) if( !strcasecmp(psz_capability,"chroma") )
return strdup(CHROMA_HELP); return strdup(CHROMA_HELP);
if( !strcasecmp(psz_capability,"decoder") ) if( !strcasecmp(psz_capability,"decoder") )
return strdup(DECODER_HELP); return strdup(DECODER_HELP);
if( !strcasecmp(psz_capability,"demux") ) if( !strcasecmp(psz_capability,"demux") )
return strdup(DEMUX_HELP); return strdup(DEMUX_HELP);
if( !strcasecmp(psz_capability,"interface") ) if( !strcasecmp(psz_capability,"interface") )
return strdup(INTERFACE_HELP); return strdup(INTERFACE_HELP);
if( !strcasecmp(psz_capability,"sout access") ) if( !strcasecmp(psz_capability,"sout access") )
return strdup(SOUT_HELP); return strdup(SOUT_HELP);
if( !strcasecmp(psz_capability,"subtitle demux") ) if( !strcasecmp(psz_capability,"subtitle demux") )
return strdup(SUBTITLE_DEMUX_HELP); return strdup(SUBTITLE_DEMUX_HELP);
if( !strcasecmp(psz_capability,"text renderer") ) if( !strcasecmp(psz_capability,"text renderer") )
return strdup(TEXT_HELP); return strdup(TEXT_HELP);
if( !strcasecmp(psz_capability,"video output") ) if( !strcasecmp(psz_capability,"video output") )
return strdup(VOUT_HELP); return strdup(VOUT_HELP);
if( !strcasecmp(psz_capability,"video filter") ) if( !strcasecmp(psz_capability,"video filter") )
return strdup(VIDEO_FILTER_HELP); return strdup(VIDEO_FILTER_HELP);
return strdup(UNKNOWN_HELP); return strdup(UNKNOWN_HELP);
} }
...@@ -410,9 +410,8 @@ PrefsTreeCtrl::PrefsTreeCtrl( wxWindow *_p_parent, intf_thread_t *_p_intf, ...@@ -410,9 +410,8 @@ PrefsTreeCtrl::PrefsTreeCtrl( wxWindow *_p_parent, intf_thread_t *_p_intf,
config_data->psz_section = NULL; config_data->psz_section = NULL;
config_data->i_object_id = GENERAL_ID; config_data->i_object_id = GENERAL_ID;
config_data->psz_help = strdup( GENERAL_HELP ); config_data->psz_help = strdup( GENERAL_HELP );
printf("dans pouet: %i\n",config_data->i_object_id);
general_item = AppendItem( root_item, wxU(_("General Settings")), general_item = AppendItem( root_item, wxU(_("General Settings")),
-1, -1, config_data ); -1, -1, config_data );
for( i_index = 0; i_index < p_list->i_count; i_index++ ) for( i_index = 0; i_index < p_list->i_count; i_index++ )
{ {
...@@ -435,14 +434,14 @@ printf("dans pouet: %i\n",config_data->i_object_id); ...@@ -435,14 +434,14 @@ printf("dans pouet: %i\n",config_data->i_object_id);
case CONFIG_HINT_CATEGORY: case CONFIG_HINT_CATEGORY:
ConfigTreeData *config_data = new ConfigTreeData; ConfigTreeData *config_data = new ConfigTreeData;
config_data->psz_section = strdup(p_item->psz_text); config_data->psz_section = strdup(p_item->psz_text);
if( p_item->psz_longtext ) if( p_item->psz_longtext )
{ {
config_data->psz_help = strdup( p_item->psz_longtext); config_data->psz_help = strdup( p_item->psz_longtext);
} }
else else
{ {
config_data->psz_help = NULL; config_data->psz_help = NULL;
} }
config_data->i_object_id = p_module->i_object_id; config_data->i_object_id = p_module->i_object_id;
/* Add the category to the tree */ /* Add the category to the tree */
...@@ -465,7 +464,7 @@ printf("dans pouet: %i\n",config_data->i_object_id); ...@@ -465,7 +464,7 @@ printf("dans pouet: %i\n",config_data->i_object_id);
config_data->i_object_id = PLUGIN_ID; config_data->i_object_id = PLUGIN_ID;
config_data->psz_help = strdup( PLUGIN_HELP ); config_data->psz_help = strdup( PLUGIN_HELP );
plugins_item = AppendItem( root_item, wxU(_("Plugins")), plugins_item = AppendItem( root_item, wxU(_("Plugins")),
-1,-1,config_data ); -1,-1,config_data );
for( i_index = 0; i_index < p_list->i_count; i_index++ ) for( i_index = 0; i_index < p_list->i_count; i_index++ )
{ {
...@@ -513,11 +512,11 @@ printf("dans pouet: %i\n",config_data->i_object_id); ...@@ -513,11 +512,11 @@ printf("dans pouet: %i\n",config_data->i_object_id);
ConfigTreeData *config_data = new ConfigTreeData; ConfigTreeData *config_data = new ConfigTreeData;
config_data->psz_section = NULL; config_data->psz_section = NULL;
config_data->psz_help = config_data->psz_help =
GetCapabilityHelp( p_module->psz_capability ); GetCapabilityHelp( p_module->psz_capability );
config_data->i_object_id = CAPABILITY_ID; config_data->i_object_id = CAPABILITY_ID;
capability_item = AppendItem( plugins_item, capability_item = AppendItem( plugins_item,
wxU(p_module->psz_capability), wxU(p_module->psz_capability),
-1,-1,config_data ); -1,-1,config_data );
} }
/* Add the plugin to the tree */ /* Add the plugin to the tree */
...@@ -526,7 +525,7 @@ printf("dans pouet: %i\n",config_data->i_object_id); ...@@ -526,7 +525,7 @@ printf("dans pouet: %i\n",config_data->i_object_id);
config_data->i_object_id = p_module->b_submodule ? config_data->i_object_id = p_module->b_submodule ?
((module_t *)p_module->p_parent)->i_object_id : ((module_t *)p_module->p_parent)->i_object_id :
p_module->i_object_id; p_module->i_object_id;
config_data->psz_help = strdup( "" ); config_data->psz_help = strdup( "" );
AppendItem( capability_item, wxU(p_module->psz_object_name), -1, -1, AppendItem( capability_item, wxU(p_module->psz_object_name), -1, -1,
config_data ); config_data );
} }
...@@ -727,7 +726,7 @@ void PrefsTreeCtrl::OnSelectTreeItem( wxTreeEvent& event ) ...@@ -727,7 +726,7 @@ void PrefsTreeCtrl::OnSelectTreeItem( wxTreeEvent& event )
new PrefsPanel( p_parent, p_intf, p_prefs_dialog, new PrefsPanel( p_parent, p_intf, p_prefs_dialog,
config_data->i_object_id, config_data->i_object_id,
config_data->psz_section, config_data->psz_section,
config_data->psz_help); config_data->psz_help);
config_data->panel->SwitchAdvanced( b_advanced ); config_data->panel->SwitchAdvanced( b_advanced );
} }
else else
...@@ -765,7 +764,7 @@ void PrefsTreeCtrl::OnAdvanced( wxCommandEvent& event ) ...@@ -765,7 +764,7 @@ void PrefsTreeCtrl::OnAdvanced( wxCommandEvent& event )
*****************************************************************************/ *****************************************************************************/
PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf, PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf,
PrefsDialog *_p_prefs_dialog, PrefsDialog *_p_prefs_dialog,
int i_object_id, char *psz_section, char*psz_help ) int i_object_id, char *psz_section, char *psz_help )
: wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize ) : wxPanel( parent, -1, wxDefaultPosition, wxDefaultSize )
{ {
module_config_t *p_item; module_config_t *p_item;
...@@ -795,18 +794,15 @@ PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf, ...@@ -795,18 +794,15 @@ PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf,
if( i_object_id == PLUGIN_ID || i_object_id == GENERAL_ID || if( i_object_id == PLUGIN_ID || i_object_id == GENERAL_ID ||
i_object_id == CAPABILITY_ID ) i_object_id == CAPABILITY_ID )
{ {
wxStaticBox *static_box = new wxStaticBox( this, -1, wxT( "" ) ); wxStaticBox *static_box = new wxStaticBox( this, -1, wxT("") );
wxStaticBoxSizer *box_sizer = new wxStaticBoxSizer( static_box, wxStaticBoxSizer *box_sizer = new wxStaticBoxSizer( static_box,
wxVERTICAL ); wxVERTICAL );
label = new wxStaticText( this, -1, label = new wxStaticText( this, -1, wxU(_( psz_help) ) );
wxU(_( psz_help) ) );
box_sizer->Add( label, 1, wxEXPAND | wxLEFT | wxRIGHT, 5 ); box_sizer->Add( label, 1, wxEXPAND | wxLEFT | wxRIGHT, 5 );
sizer->Add( box_sizer, 0, wxEXPAND | wxALL , 5 );
sizer->Add( box_sizer, 0, wxEXPAND | wxALL , 5 ); }
}
else else
{ {
/* Get a pointer to the module */ /* Get a pointer to the module */
...@@ -820,248 +816,244 @@ PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf, ...@@ -820,248 +816,244 @@ PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf,
/* Enumerate config options and add corresponding config boxes /* Enumerate config options and add corresponding config boxes
* (submodules don't have config options, they are stored in the * (submodules don't have config options, they are stored in the
* parent module) */ * parent module) */
if( p_module->b_submodule ) if( p_module->b_submodule )
p_item = ((module_t *)p_module->p_parent)->p_config; p_item = ((module_t *)p_module->p_parent)->p_config;
else else
p_item = p_module->p_config; p_item = p_module->p_config;
/* Find the category if it has been specified */ /* Find the category if it has been specified */
if( psz_section && p_item->i_type == CONFIG_HINT_CATEGORY ) if( psz_section && p_item->i_type == CONFIG_HINT_CATEGORY )
{ {
while( !p_item->i_type == CONFIG_HINT_CATEGORY || while( !p_item->i_type == CONFIG_HINT_CATEGORY ||
strcmp( psz_section, p_item->psz_text ) ) strcmp( psz_section, p_item->psz_text ) )
{ {
if( p_item->i_type == CONFIG_HINT_END ) if( p_item->i_type == CONFIG_HINT_END )
break; break;
p_item++; p_item++;
} }
} }
/* Add a head title to the panel */
wxStaticBox *static_box = new wxStaticBox( this, -1, wxT( "" ) ); /* Add a head title to the panel */
wxStaticBoxSizer *box_sizer = new wxStaticBoxSizer( static_box, wxStaticBox *static_box = new wxStaticBox( this, -1, wxT("") );
wxStaticBoxSizer *box_sizer = new wxStaticBoxSizer( static_box,
wxVERTICAL ); wxVERTICAL );
wxStaticBox *help_box = NULL; wxStaticBox *help_box = NULL;
wxStaticBoxSizer *help_sizer = NULL; wxStaticBoxSizer *help_sizer = NULL;
label = new wxStaticText( this, -1, label = new wxStaticText( this, -1,
wxU(_(psz_section ? p_item->psz_text : wxU(_(psz_section ? p_item->psz_text :
p_module->psz_longname ))); p_module->psz_longname )));
box_sizer->Add( label, 1, wxEXPAND | wxLEFT | wxRIGHT, 5 ); box_sizer->Add( label, 1, wxEXPAND | wxLEFT | wxRIGHT, 5 );
sizer->Add( box_sizer, 0, wxEXPAND | wxLEFT | wxRIGHT , 5 ); sizer->Add( box_sizer, 0, wxEXPAND | wxLEFT | wxRIGHT , 5 );
if( psz_help && psz_help[1] ) /* Check that we have at least something */
/* Check that we have at least something */ if( psz_help && psz_help[1] )
{ {
help_box = new wxStaticBox( this, -1, wxT( "" ) ); help_box = new wxStaticBox( this, -1, wxT("") );
help_sizer = new wxStaticBoxSizer( help_box, help_sizer = new wxStaticBoxSizer( help_box, wxHORIZONTAL ) ;
wxHORIZONTAL ) ; help = new wxStaticText( this, -1, wxU(_(psz_help)),
help = new wxStaticText( this, -1, wxDefaultPosition, wxDefaultSize,
wxT(_( psz_help) ), wxST_NO_AUTORESIZE | wxALIGN_LEFT,
wxDefaultPosition, wxDefaultSize, wxT("") );
wxST_NO_AUTORESIZE | wxALIGN_LEFT,
wxT("") ); help_sizer->Add( help, 1, wxALL | wxEXPAND , 5 );
sizer->Add( help_sizer ,0 ,wxEXPAND | wxALL, 5 );
help_sizer->Add( help, 1, wxALL | wxEXPAND , 5 ); }
sizer->Add( help_sizer ,0 ,wxEXPAND | wxALL, 5 );
} /* Now put all the config options into a scrolled window */
config_sizer = new wxBoxSizer( wxVERTICAL );
/* Now put all the config options into a scrolled window */ config_window = new wxScrolledWindow( this, -1, wxDefaultPosition,
config_sizer = new wxBoxSizer( wxVERTICAL );
config_window = new wxScrolledWindow( this, -1, wxDefaultPosition,
wxDefaultSize, wxSTATIC_BORDER | wxHSCROLL | wxVSCROLL ); wxDefaultSize, wxSTATIC_BORDER | wxHSCROLL | wxVSCROLL );
config_window->SetAutoLayout( TRUE ); config_window->SetAutoLayout( TRUE );
config_window->SetScrollRate( 5, 5 ); config_window->SetScrollRate( 5, 5 );
if( p_item ) do if( p_item ) do
{ {
/* If a category has been specified, check we finished the job */ /* If a category has been specified, check we finished the job */
if( psz_section && p_item->i_type == CONFIG_HINT_CATEGORY && if( psz_section && p_item->i_type == CONFIG_HINT_CATEGORY &&
strcmp( psz_section, p_item->psz_text ) ) strcmp( psz_section, p_item->psz_text ) )
break; break;
/* put each config option in a separate panel so we can hide advanced
* options easily */
wxPanel *panel = new wxPanel( config_window, -1, wxDefaultPosition,
wxDefaultSize );
wxBoxSizer *panel_sizer = new wxBoxSizer( wxHORIZONTAL );
ConfigData *config_data =
new ConfigData( panel, p_item->i_type,
p_item->b_advanced, p_item->psz_name );
switch( p_item->i_type )
{
case CONFIG_ITEM_MODULE:
label = new wxStaticText(panel, -1, wxU(p_item->psz_text));
combo = new wxComboBox( panel, -1, wxU(p_item->psz_value),
wxDefaultPosition, wxDefaultSize,
0, NULL, wxCB_READONLY | wxCB_SORT );
/* build a list of available modules */
p_list = vlc_list_find( p_intf,
VLC_OBJECT_MODULE, FIND_ANYWHERE );
combo->Append( wxU(_("Default")), (void *)NULL );
combo->SetSelection( 0 );
for( int i_index = 0; i_index < p_list->i_count; i_index++ )
{
p_parser = (module_t *)p_list->p_values[i_index].p_object ;
if( !strcmp( p_parser->psz_capability, /* put each config option in a separate panel so we can hide
p_item->psz_type ) ) * advanced options easily */
{ wxPanel *panel = new wxPanel( config_window, -1, wxDefaultPosition,
combo->Append( wxU(p_parser->psz_longname), wxDefaultSize );
p_parser->psz_object_name ); wxBoxSizer *panel_sizer = new wxBoxSizer( wxHORIZONTAL );
if( p_item->psz_value && ConfigData *config_data =
!strcmp(p_item->psz_value, new ConfigData( panel, p_item->i_type,
p_parser->psz_object_name) ) p_item->b_advanced, p_item->psz_name );
combo->SetValue( wxU(p_parser->psz_longname) );
}
}
vlc_list_release( p_list );
combo->SetToolTip( wxU(p_item->psz_longtext) ); switch( p_item->i_type )
config_data->control.combobox = combo; {
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL case CONFIG_ITEM_MODULE:
| wxALL, 5 ); label = new wxStaticText(panel, -1, wxU(p_item->psz_text));
panel_sizer->Add( combo, 1, wxALIGN_CENTER_VERTICAL combo = new wxComboBox( panel, -1, wxU(p_item->psz_value),
| wxALL, 5 );
break;
case CONFIG_ITEM_STRING:
case CONFIG_ITEM_FILE:
case CONFIG_ITEM_DIRECTORY:
label = new wxStaticText(panel, -1, wxU(p_item->psz_text));
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 );
if( !p_item->ppsz_list )
{
textctrl = new wxTextCtrl( panel, -1,
wxU(p_item->psz_value),
wxDefaultPosition, wxDefaultSize,
wxTE_PROCESS_ENTER);
textctrl->SetToolTip( wxU(p_item->psz_longtext) );
config_data->control.textctrl = textctrl;
panel_sizer->Add( textctrl, 1, wxALL, 5 );
}
else
{
combo = new wxComboBox( panel, -1, wxU(p_item->psz_value),
wxDefaultPosition, wxDefaultSize, wxDefaultPosition, wxDefaultSize,
0, NULL, wxCB_READONLY | wxCB_SORT ); 0, NULL, wxCB_READONLY | wxCB_SORT );
/* build a list of available options */ /* build a list of available modules */
for( int i_index = 0; p_item->ppsz_list[i_index]; p_list = vlc_list_find( p_intf,
i_index++ ) VLC_OBJECT_MODULE, FIND_ANYWHERE );
{ combo->Append( wxU(_("Default")), (void *)NULL );
combo->Append( wxU(p_item->ppsz_list[i_index]) ); combo->SetSelection( 0 );
if( p_item->psz_value && !strcmp( p_item->psz_value, for( int i_index = 0; i_index < p_list->i_count; i_index++ )
p_item->ppsz_list[i_index] ) ) {
combo->SetSelection( i_index ); p_parser = (module_t *)p_list->p_values[i_index].p_object ;
}
if( !strcmp( p_parser->psz_capability, p_item->psz_type ) )
if( p_item->psz_value ) {
combo->SetValue( wxU(p_item->psz_value) ); combo->Append( wxU(p_parser->psz_longname),
combo->SetToolTip( wxU(p_item->psz_longtext) ); p_parser->psz_object_name );
config_data->control.combobox = combo; if( p_item->psz_value && !strcmp(p_item->psz_value,
config_data->b_config_list = VLC_TRUE; p_parser->psz_object_name) )
panel_sizer->Add( combo, 1, wxALIGN_CENTER_VERTICAL combo->SetValue( wxU(p_parser->psz_longname) );
|wxALL, 5 );
} }
}
if( p_item->i_type == CONFIG_ITEM_FILE ) vlc_list_release( p_list );
combo->SetToolTip( wxU(p_item->psz_longtext) );
config_data->control.combobox = combo;
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 );
panel_sizer->Add( combo, 1, wxALIGN_CENTER_VERTICAL
| wxALL, 5 );
break;
case CONFIG_ITEM_STRING:
case CONFIG_ITEM_FILE:
case CONFIG_ITEM_DIRECTORY:
label = new wxStaticText(panel, -1, wxU(p_item->psz_text));
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 );
if( !p_item->ppsz_list )
{
textctrl = new wxTextCtrl( panel, -1,
wxU(p_item->psz_value),
wxDefaultPosition,
wxDefaultSize,
wxTE_PROCESS_ENTER);
textctrl->SetToolTip( wxU(p_item->psz_longtext) );
config_data->control.textctrl = textctrl;
panel_sizer->Add( textctrl, 1, wxALL, 5 );
}
else
{
combo = new wxComboBox( panel, -1, wxU(p_item->psz_value),
wxDefaultPosition, wxDefaultSize,
0, NULL, wxCB_READONLY|wxCB_SORT );
/* build a list of available options */
for( int i_index = 0; p_item->ppsz_list[i_index];
i_index++ )
{ {
button = new wxButton( panel, -1, wxU(_("Browse...")) ); combo->Append( wxU(p_item->ppsz_list[i_index]) );
panel_sizer->Add( button, 0, wxALIGN_CENTER_VERTICAL if( p_item->psz_value && !strcmp( p_item->psz_value,
|wxALL, 5); p_item->ppsz_list[i_index] ) )
button->SetClientData((void *)config_data); combo->SetSelection( i_index );
} }
if( p_item->b_advanced ) b_has_advanced = VLC_TRUE;
break;
case CONFIG_ITEM_INTEGER: if( p_item->psz_value )
label = new wxStaticText(panel, -1, wxU(p_item->psz_text)); combo->SetValue( wxU(p_item->psz_value) );
spin = new wxSpinCtrl( panel, -1, combo->SetToolTip( wxU(p_item->psz_longtext) );
wxString::Format(wxT("%d"),p_item->i_value), config_data->control.combobox = combo;
config_data->b_config_list = VLC_TRUE;
panel_sizer->Add( combo, 1, wxALIGN_CENTER_VERTICAL
|wxALL, 5 );
}
if( p_item->i_type == CONFIG_ITEM_FILE )
{
button = new wxButton( panel, -1, wxU(_("Browse...")) );
panel_sizer->Add( button, 0, wxALIGN_CENTER_VERTICAL
|wxALL, 5);
button->SetClientData((void *)config_data);
}
if( p_item->b_advanced ) b_has_advanced = VLC_TRUE;
break;
case CONFIG_ITEM_INTEGER:
label = new wxStaticText(panel, -1, wxU(p_item->psz_text));
spin = new wxSpinCtrl( panel, -1,
wxString::Format(wxT("%d"),
p_item->i_value),
wxDefaultPosition, wxDefaultSize, wxDefaultPosition, wxDefaultSize,
wxSP_ARROW_KEYS, wxSP_ARROW_KEYS,
-16000, 16000, p_item->i_value); -16000, 16000, p_item->i_value);
spin->SetToolTip( wxU(p_item->psz_longtext) ); spin->SetToolTip( wxU(p_item->psz_longtext) );
config_data->control.spinctrl = spin; config_data->control.spinctrl = spin;
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 ); | wxALL, 5 );
panel_sizer->Add( spin, 0, wxALIGN_CENTER_VERTICAL panel_sizer->Add( spin, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 ); | wxALL, 5 );
spin->SetClientData((void *)config_data); spin->SetClientData((void *)config_data);
if( p_item->b_advanced ) b_has_advanced = VLC_TRUE; if( p_item->b_advanced ) b_has_advanced = VLC_TRUE;
break; break;
case CONFIG_ITEM_KEY: case CONFIG_ITEM_KEY:
{
label = new wxStaticText(panel, -1, wxU(p_item->psz_text));
wxCheckBox *alt = new wxCheckBox( panel, -1, wxU(_("Alt")) );
alt->SetValue( p_item->i_value & KEY_MODIFIER_ALT );
wxCheckBox *ctrl = new wxCheckBox( panel, -1, wxU(_("Ctrl")) );
ctrl->SetValue( p_item->i_value & KEY_MODIFIER_CTRL );
wxCheckBox *shift = new wxCheckBox( panel, -1,
wxU(_("Shift")) );
shift->SetValue( p_item->i_value & KEY_MODIFIER_SHIFT );
combo = new wxComboBox( panel, -1, wxU("f"),
wxDefaultPosition, wxDefaultSize, 0
, NULL, wxCB_READONLY | wxCB_SORT );
for( int i=0; i < sizeof(keys)/sizeof(key_descriptor_s); i++ )
{ {
label = new wxStaticText(panel, -1, wxU(p_item->psz_text)); combo->Append( wxU(_(keys[i].psz_key_string)),
wxCheckBox *alt = new wxCheckBox( panel, -1, wxU(_("Alt")) ); (void*)&keys[i].i_key_code );
alt->SetValue( p_item->i_value & KEY_MODIFIER_ALT );
wxCheckBox *ctrl = new wxCheckBox( panel, -1, wxU(_("Ctrl")) );
ctrl->SetValue( p_item->i_value & KEY_MODIFIER_CTRL );
wxCheckBox *shift = new wxCheckBox( panel, -1,
wxU(_("Shift")) );
shift->SetValue( p_item->i_value & KEY_MODIFIER_SHIFT );
combo = new wxComboBox( panel, -1, wxU("f"),
wxDefaultPosition, wxDefaultSize, 0
, NULL, wxCB_READONLY | wxCB_SORT );
for( int i = 0; i < sizeof(keys)/sizeof(key_descriptor_s);
i++ )
{
combo->Append( wxU(_(keys[i].psz_key_string)),
(void*)&keys[i].i_key_code );
}
combo->SetValue( wxU( KeyToString(
p_item->i_value&~KEY_MODIFIER )));
config_data->control.combobox = combo;
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 );
panel_sizer->Add( alt, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5 );
panel_sizer->Add( ctrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5 );
panel_sizer->Add( shift, 0, wxALIGN_CENTER_VERTICAL |
wxALL, 5 );
panel_sizer->Add( combo, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 );
break;
} }
combo->SetValue( wxU( KeyToString(
case CONFIG_ITEM_FLOAT: p_item->i_value&~KEY_MODIFIER )));
label = new wxStaticText(panel, -1, wxU(p_item->psz_text)); config_data->control.combobox = combo;
textctrl = new wxTextCtrl( panel, -1, panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL
wxString::Format(wxT("%f"),p_item->f_value), | wxALL, 5 );
wxDefaultPosition, wxDefaultSize, panel_sizer->Add( alt, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5 );
wxTE_PROCESS_ENTER ); panel_sizer->Add( ctrl, 0, wxALIGN_CENTER_VERTICAL | wxALL, 5);
textctrl->SetToolTip( wxU(p_item->psz_longtext) ); panel_sizer->Add( shift, 0, wxALIGN_CENTER_VERTICAL |wxALL, 5);
config_data->control.textctrl = textctrl; panel_sizer->Add( combo, 0, wxALIGN_CENTER_VERTICAL |wxALL, 5);
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL break;
| wxALL, 5 ); }
panel_sizer->Add( textctrl, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5); case CONFIG_ITEM_FLOAT:
if( p_item->b_advanced ) b_has_advanced = VLC_TRUE; label = new wxStaticText(panel, -1, wxU(p_item->psz_text));
break; textctrl = new wxTextCtrl( panel, -1,
wxString::Format(wxT("%f"),
p_item->f_value),
wxDefaultPosition, wxDefaultSize,
wxTE_PROCESS_ENTER );
textctrl->SetToolTip( wxU(p_item->psz_longtext) );
config_data->control.textctrl = textctrl;
panel_sizer->Add( label, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5 );
panel_sizer->Add( textctrl, 0, wxALIGN_CENTER_VERTICAL
| wxALL, 5);
if( p_item->b_advanced ) b_has_advanced = VLC_TRUE;
break;
case CONFIG_ITEM_BOOL:
checkbox = new wxCheckBox( panel, -1, wxU(p_item->psz_text) );
if( p_item->i_value ) checkbox->SetValue(TRUE);
checkbox->SetToolTip( wxU(p_item->psz_longtext) );
config_data->control.checkbox = checkbox;
panel_sizer->Add( checkbox, 0, wxALL, 5 );
if( p_item->b_advanced ) b_has_advanced = VLC_TRUE;
break;
case CONFIG_ITEM_BOOL: default:
checkbox = new wxCheckBox( panel, -1, wxU(p_item->psz_text) ); delete panel; panel = NULL;
if( p_item->i_value ) checkbox->SetValue(TRUE); delete panel_sizer;
checkbox->SetToolTip( wxU(p_item->psz_longtext) ); delete config_data;
config_data->control.checkbox = checkbox; break;
panel_sizer->Add( checkbox, 0, wxALL, 5 );
if( p_item->b_advanced ) b_has_advanced = VLC_TRUE;
break;
default:
delete panel; panel = NULL;
delete panel_sizer;
delete config_data;
break;
} }
/* Don't add items that were not recognized */ /* Don't add items that were not recognized */
...@@ -1076,6 +1068,7 @@ PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf, ...@@ -1076,6 +1068,7 @@ PrefsPanel::PrefsPanel( wxWindow* parent, intf_thread_t *_p_intf,
config_sizer->Add( panel, 0, wxEXPAND | wxALL, 2 ); config_sizer->Add( panel, 0, wxEXPAND | wxALL, 2 );
} }
while( p_item->i_type != CONFIG_HINT_END && p_item++ ); while( p_item->i_type != CONFIG_HINT_END && p_item++ );
config_sizer->Layout(); config_sizer->Layout();
config_window->SetSizer( config_sizer ); config_window->SetSizer( config_sizer );
sizer->Add( config_window, 1, wxEXPAND | wxALL, 5 ); sizer->Add( config_window, 1, wxEXPAND | wxALL, 5 );
...@@ -1154,7 +1147,7 @@ void PrefsPanel::SwitchAdvanced( vlc_bool_t b_new_advanced ) ...@@ -1154,7 +1147,7 @@ void PrefsPanel::SwitchAdvanced( vlc_bool_t b_new_advanced )
config_window->FitInside(); config_window->FitInside();
config_window->Refresh(); config_window->Refresh();
} }
return; return;
} }
/***************************************************************************** /*****************************************************************************
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment