/*****************************************************************************
* simple_preferences.cpp : "Simple preferences"
****************************************************************************
- * Copyright (C) 2006-2007 the VideoLAN team
+ * Copyright (C) 2006-2008 the VideoLAN team
* $Id$
*
* Authors: Clément Stenac <zorglub@videolan.org>
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/
+
#ifdef HAVE_CONFIG_H
# include "config.h"
#endif
#include <QFont>
#include <QToolButton>
#include <QButtonGroup>
-#include <QUrl>
#include <QVBoxLayout>
+#include <QtAlgorithms>
+
#include <string>
#define ICON_HEIGHT 64
#define ADD_CATEGORY( button, label, icon, numb ) \
QToolButton * button = new QToolButton( this ); \
- button->setIcon( QIcon( ":/pixmaps/" #icon ) ); \
+ button->setIcon( QIcon( ":/pixmaps/prefs/" #icon ) ); \
button->setIconSize( QSize( ICON_HEIGHT , ICON_HEIGHT ) ); \
button->setText( label ); \
button->setToolButtonStyle( Qt::ToolButtonTextUnderIcon ); \
spref_cone_Interface_64.png, 0 );
ADD_CATEGORY( SPrefsAudio, qtr("Audio"), spref_cone_Audio_64.png, 1 );
ADD_CATEGORY( SPrefsVideo, qtr("Video"), spref_cone_Video_64.png, 2 );
- ADD_CATEGORY( SPrefsSubtitles, qtr("Subtitles & OSD"),
+ ADD_CATEGORY( SPrefsSubtitles, qtr("Subtitles && OSD"),
spref_cone_Subtitles_64.png, 3 );
- ADD_CATEGORY( SPrefsInputAndCodecs, qtr("Input and Codecs"),
+ ADD_CATEGORY( SPrefsInputAndCodecs, qtr("Input && Codecs"),
spref_cone_Input_64.png, 4 );
ADD_CATEGORY( SPrefsHotkeys, qtr("Hotkeys"), spref_cone_Hotkeys_64.png, 5 );
/******************************
* VIDEO Panel Implementation *
******************************/
- START_SPREFS_CAT( Video , qtr("General video settings") );
+ START_SPREFS_CAT( Video , qtr("General Video Settings") );
CONFIG_GENERIC( "video", Bool, NULL, enableVideo );
CONFIG_GENERIC( "fullscreen", Bool, NULL, fullscreen );
CONFIG_GENERIC( "directx-wallpaper" , Bool , NULL, wallpaperMode );
CONFIG_GENERIC( "directx-device", StringList, NULL,
dXdisplayDevice );
+ CONFIG_GENERIC( "directx-hw-yuv", Bool, NULL, hwYUVBox );
#else
ui.directXBox->setVisible( false );
+ ui.hwYUVBox->setVisible( false );
#endif
CONFIG_GENERIC_FILE( "snapshot-path", Directory, NULL,
/******************************
* AUDIO Panel Implementation *
******************************/
- START_SPREFS_CAT( Audio, qtr("General audio settings") );
+ START_SPREFS_CAT( Audio, qtr("General Audio Settings") );
CONFIG_GENERIC( "audio", Bool, NULL, enableAudio );
CONFIG_GENERIC2( "directx-audio-device", IntegerList,
DirectXLabel, DirectXDevice );
#else
- if( module_Exists( p_intf, "alsa" ) )
+ if( module_exists( "alsa" ) )
{
audioControl( alsa );
optionWidgets.append( alsaControl );
- CONFIG_GENERIC2( "alsadev" , StringList , alsaLabel,
+ CONFIG_GENERIC2( "alsa-audio-device" , StringList , alsaLabel,
alsaDevice );
}
else
optionWidgets.append( NULL );
- if( module_Exists( p_intf, "oss" ) )
+ if( module_exists( "oss" ) )
{
audioControl2( OSS );
optionWidgets.append( OSSControl );
- CONFIG_GENERIC_FILE( "dspdev" , File , OSSLabel, OSSDevice,
+ CONFIG_GENERIC_FILE( "oss-audio-device" , File , OSSLabel, OSSDevice,
OSSBrowse );
}
else
CONNECT( ui.outputModule, currentIndexChanged( int ),
this, updateAudioOptions( int ) );
- // File exists everywhere
+ /* File output exists on all platforms */
CONFIG_GENERIC_FILE( "audiofile-file" , File , ui.fileLabel,
ui.fileName, ui.fileBrowseButton );
updateAudioOptions( ui.outputModule->currentIndex() );
/* LastFM */
- if( module_Exists( p_intf, "audioscrobbler" ) )
+ if( module_exists( "audioscrobbler" ) )
{
CONFIG_GENERIC( "lastfm-username", String, ui.lastfm_user_label,
lastfm_user_edit );
CONNECT( ui.volNormBox, toggled( bool ), ui.volNormSpin,
setEnabled( bool ) );
- qs_filter = qfu( config_GetPsz( p_intf, "audio-filter" ) );
+ char* psz = config_GetPsz( p_intf, "audio-filter" );
+ qs_filter = qfu( psz );
+ free( psz );
bool b_normalizer = ( qs_filter.contains( "volnorm" ) );
{
ui.volNormBox->setChecked( b_normalizer );
END_SPREFS_CAT;
/* Input and Codecs Panel Implementation */
- START_SPREFS_CAT( InputAndCodecs, qtr("Input & Codecs settings") );
+ START_SPREFS_CAT( InputAndCodecs, qtr("Input & Codecs Settings") );
/* Disk Devices */
{
ui.DVDDevice->setToolTip(
- //TODO: make this sentence understandable
- qtr( "If this property is blank, then you have\n"
- "values for DVD, VCD, and CDDA.\n"
- "You can define a unique one or set that in"
- "the advanced preferences" ) );
+ qtr( "If this property is blank, different values\n"
+ "for DVD, VCD, and CDDA are set.\n"
+ "You can define a unique one or configure them \n"
+ "individually in the advanced preferences." ) );
char *psz_dvddiscpath = config_GetPsz( p_intf, "dvd" );
char *psz_vcddiscpath = config_GetPsz( p_intf, "vcd" );
char *psz_cddadiscpath = config_GetPsz( p_intf, "cd-audio" );
{
ui.DVDDevice->setText( qfu( psz_dvddiscpath ) );
}
- delete psz_cddadiscpath; delete psz_dvddiscpath;
- delete psz_vcddiscpath;
+ free( psz_cddadiscpath );
+ free( psz_dvddiscpath );
+ free( psz_vcddiscpath );
}
CONFIG_GENERIC_NO_BOOL( "server-port", Integer, NULL, UDPPort );
ui.systemCodecBox->hide();
#endif
/* Access Filters */
- qs_filter = qfu( config_GetPsz( p_intf, "access-filter" ) );
+ char* psz = config_GetPsz( p_intf, "access-filter" );
+ qs_filter = qfu( psz );
+ free( psz );
ui.timeshiftBox->setChecked( qs_filter.contains( "timeshift" ) );
ui.dumpBox->setChecked( qs_filter.contains( "dump" ) );
- ui.recordBox->setChecked( qs_filter.contains( "record" ) );
ui.bandwidthBox->setChecked( qs_filter.contains( "bandwidth" ) );
- optionWidgets.append( ui.recordBox );
optionWidgets.append( ui.dumpBox );
optionWidgets.append( ui.bandwidthBox );
optionWidgets.append( ui.timeshiftBox );
/* Caching */
/* Add the things to the ComboBox */
#define addToCachingBox( str, cachingNumber ) \
- ui.cachingCombo->addItem( str, QVariant( cachingNumber ) );
- addToCachingBox( "Custom", CachingCustom );
- addToCachingBox( "Lowest latency", CachingLowest );
- addToCachingBox( "Low latency", CachingLow );
- addToCachingBox( "Normal", CachingNormal );
- addToCachingBox( "High latency", CachingHigh );
- addToCachingBox( "Higher latency", CachingHigher );
+ ui.cachingCombo->addItem( qtr(str), QVariant( cachingNumber ) );
+ addToCachingBox( N_("Custom"), CachingCustom );
+ addToCachingBox( N_("Lowest latency"), CachingLowest );
+ addToCachingBox( N_("Low latency"), CachingLow );
+ addToCachingBox( N_("Normal"), CachingNormal );
+ addToCachingBox( N_("High latency"), CachingHigh );
+ addToCachingBox( N_("Higher latency"), CachingHigher );
#define TestCaC( name ) \
b_cache_equal = b_cache_equal && \
int i_cache = config_GetInt( p_intf, "file-caching");
TestCaC( "udp-caching" );
- if (module_Exists (p_intf, "dvdread"))
+ if (module_exists ("dvdread"))
TestCaC( "dvdread-caching" );
- if (module_Exists (p_intf, "dvdnav"))
+ if (module_exists ("dvdnav"))
TestCaC( "dvdnav-caching" );
TestCaC( "tcp-caching" );
TestCaC( "fake-caching" ); TestCaC( "cdda-caching" );
#ifdef WIN32
TestCaC( "dshow-caching" );
#else
- if (module_Exists (p_intf, "v4l"))
+ if (module_exists ("v4l"))
TestCaC( "v4l-caching" );
- if (module_Exists (p_intf, "access_jack"))
+ if (module_exists ("access_jack"))
TestCaC( "jack-input-caching" );
- if (module_Exists (p_intf, "v4l2"))
+ if (module_exists ("v4l2"))
TestCaC( "v4l2-caching" );
- if (module_Exists (p_intf, "pvr"))
+ if (module_exists ("pvr"))
TestCaC( "pvr-caching" );
#endif
TestCaCi( "rtsp-caching", 4 ); TestCaCi( "ftp-caching", 2 );
TestCaCi( "http-caching", 4 );
- if (module_Exists (p_intf, "access_realrtsp"))
+ if (module_exists ("access_realrtsp"))
TestCaCi( "realrtsp-caching", 10 );
TestCaCi( "mms-caching", 19 );
if( b_cache_equal ) ui.cachingCombo->setCurrentIndex(
/*******************
* Interface Panel *
*******************/
- START_SPREFS_CAT( Interface, qtr("Interface settings") );
+ START_SPREFS_CAT( Interface, qtr("Interface Settings") );
ui.defaultLabel->setFont( italicFont );
ui.skinsLabel->setFont( italicFont );
else if( strstr( psz_intf, "qt" ) )
ui.qt4->setChecked( true );
}
- delete psz_intf;
+ free( psz_intf );
optionWidgets.append( ui.skins );
optionWidgets.append( ui.qt4 );
CONFIG_GENERIC( "qt-display-mode", IntegerList, NULL,
displayModeBox );
CONFIG_GENERIC( "embedded-video", Bool, NULL, embedVideo );
+ CONFIG_GENERIC( "qt-fs-controller", Bool, NULL, fsController );
+ CONFIG_GENERIC( "qt-system-tray", Bool, NULL, systrayBox );
CONFIG_GENERIC_FILE( "skins2-last", File, NULL, ui.fileSkin,
ui.skinBrowse );
CONFIG_GENERIC( "album-art", IntegerList, ui.artFetchLabel,
artFetcher );
- CONFIG_GENERIC( "fetch-meta", Bool, NULL, metaFetcher );
/* UPDATE options */
#ifdef UPDATE_CHECK
#else
ui.OneInterfaceBox->hide();
#endif
+ /* RECENTLY PLAYED options */
+ CONNECT( ui.saveRecentlyPlayed, toggled( bool ),
+ ui.recentlyPlayedFilters, setEnabled( bool ) );
+ ui.recentlyPlayedFilters->setEnabled( false );
+ CONFIG_GENERIC( "qt-recentplay", Bool, NULL, saveRecentlyPlayed );
+ CONFIG_GENERIC( "qt-recentplay-filter", String, NULL,
+ recentlyPlayedFilters );
+
END_SPREFS_CAT;
- START_SPREFS_CAT( Subtitles, qtr("Subtitles & OSD settings") );
+ START_SPREFS_CAT( Subtitles, qtr("Subtitles & On Screen Display Settings") );
CONFIG_GENERIC( "osd", Bool, NULL, OSDBox);
+ CONFIG_GENERIC( "video-title-show", Bool, NULL, OSDTitleBox);
+
CONFIG_GENERIC( "subsdec-encoding", StringList, NULL, encoding );
CONFIG_GENERIC( "sub-language", String, NULL, preferredLanguage );
CONFIG_GENERIC( "freetype-rel-fontsize", IntegerList, NULL,
fontSize );
CONFIG_GENERIC( "freetype-effect", IntegerList, NULL, effect );
+ CONFIG_GENERIC_NO_BOOL( "sub-margin", Integer, NULL, subsPosition );
END_SPREFS_CAT;
optionWidgets[fileW]->setVisible( ( value == "aout_file" ) );
}
+
+SPrefsPanel::~SPrefsPanel()
+{
+ qDeleteAll( controls ); controls.clear();
+}
+
void SPrefsPanel::updateAudioVolume( int volume )
{
qobject_cast<QSpinBox *>(optionWidgets[volLW])
bool b_first = true;
qs_filter.clear();
- saveBox( "record", qobject_cast<QCheckBox *>(optionWidgets[recordChB]) );
saveBox( "dump", qobject_cast<QCheckBox *>(optionWidgets[dumpChB]) );
saveBox( "timeshift", qobject_cast<QCheckBox *>(optionWidgets[timeshiftChB]) );
saveBox( "bandwidth", qobject_cast<QCheckBox *>(optionWidgets[bandwidthChB] ) );
if( i_comboValue )
{
CaC( "udp-caching" );
- if (module_Exists (p_intf, "dvdread" ))
+ if (module_exists ("dvdread" ))
CaC( "dvdread-caching" );
- if (module_Exists (p_intf, "dvdnav" ))
+ if (module_exists ("dvdnav" ))
CaC( "dvdnav-caching" );
CaC( "tcp-caching" ); CaC( "vcd-caching" );
CaC( "fake-caching" ); CaC( "cdda-caching" ); CaC( "file-caching" );
CaC( "screen-caching" );
- CaCi( "rtsp-caching", 4 ); CaCi( "ftp-caching", 2 );
- CaCi( "http-caching", 4 );
- if (module_Exists (p_intf, "access_realrtsp" ))
+ CaCi( "rtsp-caching", 2 ); CaCi( "ftp-caching", 2 );
+ CaCi( "http-caching", 2 );
+ if (module_exists ("access_realrtsp" ))
CaCi( "realrtsp-caching", 10 );
- CaCi( "mms-caching", 19 );
+ CaCi( "mms-caching", 10 );
#ifdef WIN32
CaC( "dshow-caching" );
#else
- if (module_Exists (p_intf, "v4l" ))
+ if (module_exists ( "v4l" ))
CaC( "v4l-caching" );
- if (module_Exists (p_intf, "access_jack" ))
+ if (module_exists ( "access_jack" ))
CaC( "jack-input-caching" );
- if (module_Exists (p_intf, "v4l2" ))
+ if (module_exists ( "v4l2" ))
CaC( "v4l2-caching" );
- if (module_Exists (p_intf, "pvr" ))
+ if (module_exists ( "pvr" ))
CaC( "pvr-caching" );
#endif
//CaCi( "dv-caching" ) too short...
aTa( ".a52" ); aTa( ".aac" ); aTa( ".ac3" ); aTa( ".dts" ); aTa( ".flac" );
aTa( ".m4a" ); aTa( ".m4p" ); aTa( ".mka" ); aTa( ".mod" ); aTa( ".mp1" );
- aTa( ".mp2" ); aTa( ".mp3" ); aTa( ".ogg" ); aTa( ".spx" ); aTa( ".wav" );
- aTa( ".wma" ); aTa( ".xm" );
+ aTa( ".mp2" ); aTa( ".mp3" ); aTa( ".oma" ); aTa( ".oga" ); aTa( ".spx" );
+ aTa( ".wav" ); aTa( ".wma" ); aTa( ".xm" );
audioType->setCheckState( 0, ( i_temp > 0 ) ?
( ( i_temp == audioType->childCount() ) ?
Qt::Checked : Qt::PartiallyChecked )
i_temp = 0;
aTv( ".asf" ); aTv( ".avi" ); aTv( ".divx" ); aTv( ".dv" ); aTv( ".flv" );
- aTv( ".gxf" ); aTv( ".m1v" ); aTv( ".m2v" ); aTv( ".m4v" ); aTv( ".mkv" );
- aTv( ".mov" ); aTv( ".mp2" ); aTv( ".mp4" ); aTv( ".mpeg" );
+ aTv( ".gxf" ); aTv( ".m1v" ); aTv( ".m2v" ); aTv( ".m2ts" ); aTv( ".m4v" );
+ aTv( ".mkv" ); aTv( ".mov" ); aTv( ".mp2" ); aTv( ".mp4" ); aTv( ".mpeg" );
aTv( ".mpeg1" ); aTv( ".mpeg2" ); aTv( ".mpeg4" ); aTv( ".mpg" );
- aTv( ".mxf" ); aTv( ".ogm" ); aTv( ".ps" ); aTv( ".ts" );
+ aTv( ".mts" ); aTv( ".mxf" );
+ aTv( ".ogg" ); aTv( ".ogm" ); aTv( ".ogx" ); aTv( ".ogv" ); aTv( ".ts" );
aTv( ".vob" ); aTv( ".wmv" );
videoType->setCheckState( 0, ( i_temp > 0 ) ?
( ( i_temp == audioType->childCount() ) ?