* Todo:
* - Finish implementation (see WX)
* - Improvements over WX
- * - Password field implementation (through "pwd" bool param
* - Validator for modulelist
* - Implement update stuff using a general Updated signal
*/
text->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
if( label )
label->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( text, SIGNAL(textChanged( const QString & )), this,
+ SIGNAL(Updated()) );
}
/*********** File **************/
text->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
if( label )
label->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( text, SIGNAL(textChanged( const QString & )), this,
+ SIGNAL(Updated()) );
}
/********* String / Directory **********/
combo->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
if( label )
label->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( combo, SIGNAL(currentIndexChanged( int )), this,
+ SIGNAL(Updated()) );
}
QString StringListConfigControl::getValue()
combo->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
if( label )
label->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( combo, SIGNAL(currentIndexChanged( int )), this,
+ SIGNAL(Updated()) );
}
QString ModuleConfigControl::getValue()
{
groupBox = new QGroupBox ( qtr(p_item->psz_text) );
text = new QLineEdit();
+ connect( text, SIGNAL(textChanged( const QString & )), this,
+ SIGNAL(Updated()) );
QGridLayout *layoutGroupBox = new QGridLayout( groupBox );
finish( bycat );
}
}
}
+ emit Updated();
}
/**************************************************************************
spin->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
if( label )
label->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( spin, SIGNAL(valueChanged( int )), this,
+ SIGNAL(Updated()) );
}
int IntegerConfigControl::getValue()
combo->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
if( label )
label->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( combo, SIGNAL(currentIndexChanged( int )), this,
+ SIGNAL(Updated()) );
}
int IntegerListConfigControl::getValue()
checkbox->setCheckState( p_item->value.i == VLC_TRUE ? Qt::Checked
: Qt::Unchecked );
checkbox->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( checkbox, SIGNAL(stateChanged( int )), this,
+ SIGNAL(Updated()) );
}
int BoolConfigControl::getValue()
spin->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
if( label )
label->setToolTip( formatTooltip(qtr(p_item->psz_longtext)) );
+ connect( spin, SIGNAL(valueChanged( double )), this,
+ SIGNAL(Updated()) );
}
float FloatConfigControl::getValue()
{
/* Video Panel Implementation */
START_SPREFS_CAT( Video , qtr("General video settings") );
- CONFIG_GENERIC( "video", Bool, NULL, enableVideo );
+ CONFIG_GENERIC( "video", Bool, NULL, enableVideo );
CONFIG_GENERIC( "fullscreen", Bool, NULL, fullscreen );
CONFIG_GENERIC( "overlay", Bool, NULL, overlay );
/* Audio Panel Implementation */
START_SPREFS_CAT( Audio, qtr("General audio settings") );
-#ifdef WIN32
- ui.OSSBrowse->hide();
- ui.OSSDevice->hide();
- ui.OSSLabel->hide();
- ui.alsaDevice->hide();
- ui.alsaLabel->hide();
-#else
- ui.DirectXLabel->setVisible( false );
- ui.DirectXDevice->setVisible( false );
-#endif
- CONFIG_GENERIC( "audio", Bool, NULL, enableAudio );
- CONFIG_GENERIC_NO_BOOL( "volume" , IntegerRangeSlider, NULL,
+ CONFIG_GENERIC( "audio", Bool, NULL, enableAudio );
+
+ CONFIG_GENERIC_NO_BOOL( "volume" , IntegerRangeSlider, NULL,
defaultVolume );
- CONFIG_GENERIC( "audio-language" , String , NULL,
+ CONFIG_GENERIC( "audio-language" , String , NULL,
preferredAudioLanguage );
- CONFIG_GENERIC( "spdif" , Bool , NULL, spdifBox );
- CONFIG_GENERIC( "force-dolby-surround" , IntegerList , NULL,
+ CONFIG_GENERIC( "spdif" , Bool , NULL, spdifBox );
+ CONFIG_GENERIC( "force-dolby-surround" , IntegerList , NULL,
detectionDolby );
CONFIG_GENERIC( "aout" , Module , NULL, outputModule );
+ CONNECT( control, Updated(), this, AudioDeviceChanged() );
+ QString aout_value = (dynamic_cast<ModuleConfigControl*>(control))->getValue();
#ifndef WIN32
- CONFIG_GENERIC( "alsadev" , StringList , NULL, alsaDevice );
- CONFIG_GENERIC_FILE( "dspdev" , File , NULL, OSSDevice, OSSBrowse );
+ CONFIG_GENERIC( "alsadev" , StringList , ui.alsaLabel, alsaDevice );
+ alsa_options = control;
+ CONFIG_GENERIC_FILE( "dspdev" , File , ui.OSSLabel, OSSDevice,
+ OSSBrowse );
+ oss_options = control;
#else
- CONFIG_GENERIC( "directx-audio-device" , IntegerList, NULL,
+ CONFIG_GENERIC( "directx-audio-device" , IntegerList, ui.DirectXLabel,
DirectXDevice );
+ directx_options = control;
#endif
- CONFIG_GENERIC_FILE( "audiofile-file" , File , NULL, FileName,
+ CONFIG_GENERIC_FILE( "audiofile-file" , File , ui.FileLabel, FileName,
fileBrowseButton );
+ file_options = control;
+
+#ifdef WIN32
+ ui.OSSBrowse->hide();
+ ui.OSSDevice->hide();
+ ui.OSSLabel->hide();
+ ui.alsaDevice->hide();
+ ui.alsaLabel->hide();
+#else
+ ui.DirectXLabel->setVisible( false );
+ ui.DirectXDevice->setVisible( false );
+#endif
+
+ updateAudioOptions( aout_value );
CONFIG_GENERIC( "headphone-dolby" , Bool , NULL, headphoneEffect );
// CONFIG_GENERIC( "" , Bool, NULL, ); activation of normalizer //FIXME
this->setLayout(panel_layout);
}
+void SPrefsPanel::AudioDeviceChanged()
+{
+ ModuleConfigControl *module_config =
+ dynamic_cast<ModuleConfigControl*>( sender() );
+ updateAudioOptions( module_config->getValue() );
+}
+
+void SPrefsPanel::updateAudioOptions( QString value )
+{
+#ifndef WIN32
+ alsa_options->hide();
+ oss_options->hide();
+#else
+ directx_options->hide();
+#endif
+ file_options->hide();
+
+ if( value == "aout_file" )
+ file_options->show();
+#ifndef WIN32
+ else if( value == "alsa" )
+ alsa_options->show();
+ else if( value == "oss" )
+ oss_options->show();
+#else
+ else if( value == "directx" )
+ directx_options->show();
+#endif
+}
+
void SPrefsPanel::apply()
{
QList<ConfigControl *>::Iterator i;