X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=modules%2Fgui%2Fqt4%2Fcomponents%2Fopen_panels.cpp;h=59fe5c0bbe1974c700590141645a60736b7a9266;hb=59117b28623d003c2bf3374bf551f126da4322dc;hp=0cbb871306084d38148a91d831d0cd492d21dbd5;hpb=58efdeb9564ec85be251a8c62e42be53192c9208;p=vlc diff --git a/modules/gui/qt4/components/open_panels.cpp b/modules/gui/qt4/components/open_panels.cpp index 0cbb871306..59fe5c0bbe 100644 --- a/modules/gui/qt4/components/open_panels.cpp +++ b/modules/gui/qt4/components/open_panels.cpp @@ -35,6 +35,8 @@ #include "dialogs/open.hpp" #include "dialogs_provider.hpp" /* Open Subtitle file */ #include "util/qt_dirs.hpp" +#include +#include #include #include @@ -46,8 +48,12 @@ #include #include #include +#include -#define I_DEVICE_TOOLTIP N_("Select the device or the VIDEO_TS directory") + +#define I_DEVICE_TOOLTIP \ + I_DIR_OR_FOLDER( N_("Select a device or a VIDEO_TS directory"), \ + N_("Select a device or a VIDEO_TS folder") ) static const char *psz_devModule[] = { "v4l", "v4l2", "pvr", "dvb", "bda", "dshow", "screen", "jack" }; @@ -61,6 +67,8 @@ FileOpenPanel::FileOpenPanel( QWidget *_parent, intf_thread_t *_p_intf ) : /* Classic UI Setup */ ui.setupUi( this ); + setAcceptDrops( true ); + /* Set Filters for file selection */ /* QString fileTypes = ""; ADD_FILTER_MEDIA( fileTypes ); @@ -76,7 +84,7 @@ FileOpenPanel::FileOpenPanel( QWidget *_parent, intf_thread_t *_p_intf ) : QCompleter *fileCompleter = new QCompleter( fileCompleteList, this ); fileCompleter->setModel( new QDirModel( fileCompleter ) ); lineFileEdit->setCompleter( fileCompleter );*/ - if( config_GetInt( p_intf, "qt-embedded-open" ) ) + if( var_InheritBool( p_intf, "qt-embedded-open" ) ) { ui.tempWidget->hide(); BuildOldPanel(); @@ -93,7 +101,7 @@ FileOpenPanel::FileOpenPanel( QWidget *_parent, intf_thread_t *_p_intf ) : /* Connects */ BUTTONACT( ui.fileBrowseButton, browseFile() ); - BUTTONACT( ui.delFileButton, deleteFile() ); + BUTTONACT( ui.removeFileButton, removeFile() ); BUTTONACT( ui.subBrowseButton, browseFileSub() ); CONNECT( ui.subCheckBox, toggled( bool ), this, toggleSubtitleFrame( bool ) ); @@ -102,6 +110,7 @@ FileOpenPanel::FileOpenPanel( QWidget *_parent, intf_thread_t *_p_intf ) : CONNECT( ui.subInput, textChanged( const QString& ), this, updateMRL() ); CONNECT( ui.alignSubComboBox, currentIndexChanged( int ), this, updateMRL() ); CONNECT( ui.sizeSubComboBox, currentIndexChanged( int ), this, updateMRL() ); + updateButtons(); } inline void FileOpenPanel::BuildOldPanel() @@ -113,7 +122,7 @@ inline void FileOpenPanel::BuildOldPanel() /* Make this QFileDialog a child of tempWidget from the ui. */ dialogBox = new FileOpenBox( ui.tempWidget, NULL, - qfu( p_intf->p_sys->psz_filepath ), "" ); + p_intf->p_sys->filepath, "" ); dialogBox->setFileMode( QFileDialog::ExistingFiles ); dialogBox->setAcceptMode( QFileDialog::AcceptOpen ); @@ -161,19 +170,61 @@ FileOpenPanel::~FileOpenPanel() getSettings()->setValue( "file-dialog-state", dialogBox->saveState() ); } +void FileOpenPanel::dragEnterEvent( QDragEnterEvent *event ) +{ + event->acceptProposedAction(); +} + +void FileOpenPanel::dragMoveEvent( QDragMoveEvent *event ) +{ + event->acceptProposedAction(); +} + +void FileOpenPanel::dragLeaveEvent( QDragLeaveEvent *event ) +{ + event->accept(); +} + +void FileOpenPanel::dropEvent( QDropEvent *event ) +{ + if( event->possibleActions() & Qt::CopyAction ) + event->setDropAction( Qt::CopyAction ); + else + return; + + const QMimeData *mimeData = event->mimeData(); + foreach( const QUrl &url, mimeData->urls() ) + { + if( url.isValid() ) + { + QListWidgetItem *item = new QListWidgetItem( + toNativeSeparators( url.toLocalFile() ), + ui.fileListWidg ); + item->setFlags( Qt::ItemIsEditable | Qt::ItemIsEnabled ); + ui.fileListWidg->addItem( item ); + } + } + updateMRL(); + updateButtons(); + event->accept(); +} + void FileOpenPanel::browseFile() { - QStringList files = QFileDialog::getOpenFileNames( this ); - foreach( const QString &file, files) + QStringList files = QFileDialog::getOpenFileNames( this, qtr( "Select one or multiple files" ), p_intf->p_sys->filepath) ; + foreach( const QString &file, files ) { - QListWidgetItem *item = new QListWidgetItem( file, ui.fileListWidg ); + QListWidgetItem *item = + new QListWidgetItem( toNativeSeparators( file ), ui.fileListWidg ); item->setFlags( Qt::ItemIsEditable | Qt::ItemIsEnabled ); ui.fileListWidg->addItem( item ); + savedirpathFromFile( file ); } + updateButtons(); updateMRL(); } -void FileOpenPanel::deleteFile() +void FileOpenPanel::removeFile() { int i = ui.fileListWidg->currentRow(); if( i != -1 ) @@ -183,6 +234,7 @@ void FileOpenPanel::deleteFile() } updateMRL(); + updateButtons(); } /* Show a fileBrowser to select a subtitle */ @@ -190,10 +242,10 @@ void FileOpenPanel::browseFileSub() { // TODO Handle selection of more than one subtitles file QStringList files = THEDP->showSimpleOpen( qtr("Open subtitles file"), - EXT_FILTER_SUBTITLE, p_intf->p_sys->psz_filepath ); + EXT_FILTER_SUBTITLE, p_intf->p_sys->filepath ); if( files.isEmpty() ) return; - ui.subInput->setText( files.join(" ") ); + ui.subInput->setText( toNativeSeparators( files.join(" ") ) ); updateMRL(); } @@ -220,7 +272,11 @@ void FileOpenPanel::updateMRL() fileList << ui.fileListWidg->item( i )->text(); } else + { fileList = dialogBox->selectedFiles(); + for( int i = 0; i < fileList.count(); i++ ) + fileList[i] = toNativeSeparators( fileList[i] ); + } /* Options */ if( ui.subCheckBox->isChecked() && !ui.subInput->text().isEmpty() ) { @@ -240,8 +296,8 @@ void FileOpenPanel::updateMRL() /* Function called by Open Dialog when clicke on Play/Enqueue */ void FileOpenPanel::accept() { - //FIXME - // p_intf->p_sys->psz_filepath = qtu( dialogBox->directory().absolutePath() ); + if( dialogBox ) + p_intf->p_sys->filepath = dialogBox->directory().absolutePath(); ui.fileListWidg->clear(); } @@ -252,6 +308,14 @@ void FileOpenPanel::clear() ui.subInput->clear(); } +/* Update buttons depending on current selection */ +void FileOpenPanel::updateButtons() +{ + bool b_has_files = ( ui.fileListWidg->count() > 0 ); + ui.removeFileButton->setEnabled( b_has_files ); + ui.subCheckBox->setEnabled( b_has_files ); +} + /************************************************************************** * Open Discs ( DVD, CD, VCD and similar devices ) * **************************************************************************/ @@ -261,14 +325,12 @@ DiscOpenPanel::DiscOpenPanel( QWidget *_parent, intf_thread_t *_p_intf ) : ui.setupUi( this ); /* Get the default configuration path for the devices */ - psz_dvddiscpath = config_GetPsz( p_intf, "dvd" ); - psz_vcddiscpath = config_GetPsz( p_intf, "vcd" ); - psz_cddadiscpath = config_GetPsz( p_intf, "cd-audio" ); + psz_dvddiscpath = var_InheritString( p_intf, "dvd" ); + psz_vcddiscpath = var_InheritString( p_intf, "vcd" ); + psz_cddadiscpath = var_InheritString( p_intf, "cd-audio" ); /* State to avoid overwritting the users changes with the configuration */ - b_firstdvd = true; - b_firstvcd = true; - b_firstcdda = true; + m_discType = None; ui.browseDiscButton->setToolTip( qtr( I_DEVICE_TOOLTIP )); ui.deviceCombo->setToolTip( qtr(I_DEVICE_TOOLTIP) ); @@ -302,7 +364,7 @@ DiscOpenPanel::DiscOpenPanel( QWidget *_parent, intf_thread_t *_p_intf ) : BUTTONACT( ui.audioCDRadioButton, updateButtons() ); BUTTONACT( ui.dvdsimple, updateButtons() ); BUTTONACT( ui.browseDiscButton, browseDevice() ); - BUTTON_SET_ACT_I( ui.ejectButton, "", eject, qtr( "Eject the disc" ), + BUTTON_SET_ACT_I( ui.ejectButton, "", toolbar/eject, qtr( "Eject the disc" ), eject() ); CONNECT( ui.deviceCombo, editTextChanged( QString ), this, updateMRL()); @@ -328,9 +390,7 @@ void DiscOpenPanel::clear() ui.chapterSpin->setValue( 0 ); ui.subtitlesSpin->setValue( -1 ); ui.audioSpin->setValue( -1 ); - b_firstcdda = true; - b_firstdvd = true; - b_firstvcd = true; + m_discType = None; } #ifdef WIN32 @@ -347,10 +407,10 @@ void DiscOpenPanel::updateButtons() { if ( ui.dvdRadioButton->isChecked() ) { - if( b_firstdvd ) + if( m_discType != Dvd ) { setDrive( psz_dvddiscpath ); - b_firstdvd = false; + m_discType = Dvd; } ui.titleLabel->setText( qtr("Title") ); ui.chapterLabel->show(); @@ -360,10 +420,10 @@ void DiscOpenPanel::updateButtons() } else if ( ui.vcdRadioButton->isChecked() ) { - if( b_firstvcd ) + if( m_discType != Vcd ) { setDrive( psz_vcddiscpath ); - b_firstvcd = false; + m_discType = Vcd; } ui.titleLabel->setText( qtr("Entry") ); ui.chapterLabel->hide(); @@ -373,10 +433,10 @@ void DiscOpenPanel::updateButtons() } else /* CDDA */ { - if( b_firstcdda ) + if( m_discType != Cdda ) { setDrive( psz_cddadiscpath ); - b_firstcdda = false; + m_discType = Cdda; } ui.titleLabel->setText( qtr("Track") ); ui.chapterLabel->hide(); @@ -388,6 +448,8 @@ void DiscOpenPanel::updateButtons() updateMRL(); } +#undef setDrive + /* Update the current MRL */ void DiscOpenPanel::updateMRL() { @@ -402,7 +464,10 @@ void DiscOpenPanel::updateMRL() else mrl = "dvdsimple://"; mrl += ui.deviceCombo->currentText(); - emit methodChanged( "dvdnav-caching" ); + if( !ui.dvdsimple->isChecked() ) + emit methodChanged( "dvdnav-caching" ); + else + emit methodChanged( "dvdread-caching" ); if ( ui.titleSpin->value() > 0 ) { mrl += QString("@%1").arg( ui.titleSpin->value() ); @@ -423,9 +488,7 @@ void DiscOpenPanel::updateMRL() /* CDDA */ } else { mrl = "cdda://" + ui.deviceCombo->currentText(); - if( ui.titleSpin->value() > 0 ) { - mrl += QString(" :cdda-track=%1").arg( ui.titleSpin->value() ); - } + emit methodChanged( "cdda-caching" ); } fileList << mrl; mrl = ""; @@ -441,6 +504,11 @@ void DiscOpenPanel::updateMRL() QString("%1").arg( ui.subtitlesSpin->value() ); } } + else + { + if( ui.titleSpin->value() > 0 ) + mrl += QString(" :cdda-track=%1").arg( ui.titleSpin->value() ); + } emit mrlUpdated( fileList, mrl ); } @@ -471,34 +539,21 @@ NetOpenPanel::NetOpenPanel( QWidget *_parent, intf_thread_t *_p_intf ) : ui.setupUi( this ); /* CONNECTs */ - CONNECT( ui.protocolCombo, activated( int ), - this, updateProtocol( int ) ); - CONNECT( ui.portSpin, valueChanged( int ), this, updateMRL() ); - CONNECT( ui.addressText, textChanged( const QString& ), this, updateMRL()); - - ui.protocolCombo->addItem( "" ); - ui.protocolCombo->addItem("HTTP", QVariant("http")); - ui.protocolCombo->addItem("HTTPS", QVariant("https")); - ui.protocolCombo->addItem("MMS", QVariant("mms")); - ui.protocolCombo->addItem("FTP", QVariant("ftp")); - ui.protocolCombo->addItem("RTSP", QVariant("rtsp")); - ui.protocolCombo->addItem("RTP", QVariant("rtp")); - ui.protocolCombo->addItem("UDP", QVariant("udp")); - ui.protocolCombo->addItem("RTMP", QVariant("rtmp")); - - updateProtocol( ui.protocolCombo->currentIndex() ); - - if( config_GetInt( p_intf, "qt-recentplay" ) ) + CONNECT( ui.urlText, textChanged( const QString& ), this, updateMRL()); + + if( var_InheritBool( p_intf, "qt-recentplay" ) ) { mrlList = new QStringListModel( getSettings()->value( "Open/netMRL" ).toStringList() ); QCompleter *completer = new QCompleter( mrlList, this ); - ui.addressText->setCompleter( completer ); + ui.urlText->setCompleter( completer ); - CONNECT( ui.addressText, editingFinished(), this, updateCompleter() ); + CONNECT( ui.urlText, editingFinished(), this, updateCompleter() ); } else mrlList = NULL; + + ui.urlText->setValidator( new UrlValidator( this ) ); } NetOpenPanel::~NetOpenPanel() @@ -509,113 +564,57 @@ NetOpenPanel::~NetOpenPanel() while( tempL.size() > 8 ) tempL.removeFirst(); getSettings()->setValue( "Open/netMRL", tempL ); + + delete mrlList; } void NetOpenPanel::clear() {} -/* update the widgets according the type of protocol */ -void NetOpenPanel::updateProtocol( int idx_proto ) { - QString addr = ui.addressText->text(); - QString proto = ui.protocolCombo->itemData( idx_proto ).toString(); - - ui.portSpin->setEnabled( idx_proto == UDP_PROTO || - idx_proto == RTP_PROTO ); - - if( idx_proto == NO_PROTO ) return; - - /* If we already have a protocol in the address, replace it */ - if( addr.contains( "://")) - { - if( idx_proto != UDP_PROTO && idx_proto != RTP_PROTO ) - addr.replace( QRegExp("^.*://@*"), proto + "://"); - else if ( ( addr.contains(QRegExp("://((22[4-9])|(23\\d)|(\\[?[fF]{2}[0-9a-fA-F]{2}:))"))) || - ( !addr.contains(QRegExp("^\\d{1,3}[.]\\d{1,3}[.]\\d{1,3}[.]\\d{1,3}")) && - !addr.contains(QRegExp(":[a-fA-F0-9]{1,4}:")) ) ) - addr.replace( QRegExp("^.*://"), proto + "://@"); - else - addr.replace( QRegExp("^.*://"), proto + "://"); - addr.replace( QRegExp("@+"), "@"); - ui.addressText->setText( addr ); - } - updateMRL(); +static int strcmp_void( const void *k, const void *e ) +{ + return strcmp( (const char *)k, (const char *)e ); } -void NetOpenPanel::updateMRL() { - QString mrl = ""; - QString addr = ui.addressText->text(); - addr = QUrl::toPercentEncoding( addr, ":/?#@!$&'()*+,;=" ); - int idx_proto = ui.protocolCombo->currentIndex(); - int addr_is_multicast = addr.contains(QRegExp("^(22[4-9])|(23\\d)|(\\[?[fF]{2}[0-9a-fA-F]{2}:)"))?1:0; - int addr_is_ipv4 = addr.contains(QRegExp("^\\d{1,3}[.]\\d{1,3}[.]\\d{1,3}[.]\\d{1,3}"))?1:0; - int addr_is_ipv6 = addr.contains(QRegExp(":[a-fA-F0-9]{1,4}:"))?1:0; - int addr_has_port = addr.contains(QRegExp("[^:]{5}:\\d{1,5}$"))?1:0; - if( addr.contains( "://")) - { - /* Match the correct item in the comboBox */ - ui.protocolCombo->setCurrentIndex( - ui.protocolCombo->findData( addr.section( ':', 0, 0 ) ) ); - mrl = addr; - } - else +void NetOpenPanel::updateMRL() +{ + static const struct caching_map { - switch( idx_proto ) { - case HTTP_PROTO: - mrl = "http://" + addr; - emit methodChanged("http-caching"); - break; - case HTTPS_PROTO: - mrl = "https://" + addr; - emit methodChanged("http-caching"); - break; - case MMS_PROTO: - mrl = "mms://" + addr; - emit methodChanged("mms-caching"); - break; - case FTP_PROTO: - mrl = "ftp://" + addr; - emit methodChanged("ftp-caching"); - break; - case RTSP_PROTO: - mrl = "rtsp://" + addr; - emit methodChanged("rtsp-caching"); - break; - case UDP_PROTO: - if(( addr_is_multicast ) || ( !addr_is_ipv4 && !addr_is_ipv6 )) - mrl = "udp://@"; - else - mrl = "udp://"; - /* Add [] to IPv6 */ - if ( addr_is_ipv6 && !addr.contains('[') ) - { - mrl += "[" + addr + "]"; - } - else mrl += addr; - if(!addr_has_port) - mrl += QString(":%1").arg( ui.portSpin->value() ); - emit methodChanged("udp-caching"); - break; - case RTP_PROTO: - if(( addr_is_multicast ) || ( !addr_is_ipv4 && !addr_is_ipv6 )) - mrl = "rtp://@"; - else - mrl = "rtp://"; - if ( addr_is_ipv6 && !addr.contains('[') ) - mrl += "[" + addr + "]"; /* Add [] to IPv6 */ - else - mrl += addr; - if(!addr_has_port) - mrl += QString(":%1").arg( ui.portSpin->value() ); - emit methodChanged("rtp-caching"); - break; - case RTMP_PROTO: - mrl = "rtmp://" + addr; - emit methodChanged("rtmp-caching"); - break; - } - } - - QStringList qsl; qsl<< mrl; + char proto[6]; + char caching[6]; + } schemes[] = + { /* KEEP alphabetical order on first column!! */ + { "dccp", "rtp" }, + { "ftp", "ftp" }, + { "ftps", "ftp" }, + { "http", "http" }, + { "https", "http" }, + { "mms", "mms" }, + { "mmsh", "mms" }, + { "mmst", "mms" }, + { "mmsu", "mms" }, + { "sftp", "sftp" }, + { "smb", "smb" }, + { "rtmp", "rtmp" }, + { "rtp", "rtp" }, + { "rtsp", "rtsp" }, + { "udp", "udp" }, + }; + + QString url = ui.urlText->text(); + if( !url.contains( "://") ) + return; /* nothing to do this far */ + + /* Match the correct item in the comboBox */ + QString proto = url.section( ':', 0, 0 ); + const struct caching_map *r = (const struct caching_map *) + bsearch( qtu(proto), schemes, sizeof(schemes) / sizeof(schemes[0]), + sizeof(schemes[0]), strcmp_void ); + if( r ) + emit methodChanged( qfu( r->caching ) + qfu( "-caching" ) ); + + QStringList qsl; + qsl << url; emit mrlUpdated( qsl, "" ); } @@ -623,11 +622,25 @@ void NetOpenPanel::updateCompleter() { assert( mrlList ); QStringList tempL = mrlList->stringList(); - if( !tempL.contains( ui.addressText->text() ) ) - tempL.append( ui.addressText->text() ); + if( !tempL.contains( ui.urlText->text() ) ) + tempL.append( ui.urlText->text() ); mrlList->setStringList( tempL ); } +void UrlValidator::fixup( QString& str ) const +{ + str = str.trimmed(); +} + +QValidator::State UrlValidator::validate( QString& str, int& pos ) const +{ + if( str.contains( ' ' ) ) + return QValidator::Invalid; + if( !str.contains( "://" ) ) + return QValidator::Intermediate; + return QValidator::Acceptable; +} + /************************************************************************** * Open Capture device ( DVB, PVR, V4L, and similar ) * **************************************************************************/ @@ -656,13 +669,13 @@ void CaptureOpenPanel::initialize() ui.optionsBox->setLayout( stackedPropLayout ); /* Creation and connections of the WIdgets in the stacked layout */ -#define addModuleAndLayouts( number, name, label ) \ +#define addModuleAndLayouts( number, name, label, layout ) \ QWidget * name ## DevPage = new QWidget( this ); \ QWidget * name ## PropPage = new QWidget( this ); \ stackedDevLayout->addWidget( name ## DevPage ); \ stackedPropLayout->addWidget( name ## PropPage ); \ - QGridLayout * name ## DevLayout = new QGridLayout; \ - QGridLayout * name ## PropLayout = new QGridLayout; \ + layout * name ## DevLayout = new layout; \ + layout * name ## PropLayout = new layout; \ name ## DevPage->setLayout( name ## DevLayout ); \ name ## PropPage->setLayout( name ## PropLayout ); \ ui.deviceCombo->addItem( qtr( label ), QVariant( number ) ); @@ -674,7 +687,7 @@ void CaptureOpenPanel::initialize() * DirectShow Stuffs * *********************/ if( module_exists( "dshow" ) ){ - addModuleAndLayouts( DSHOW_DEVICE, dshow, "DirectShow" ); + addModuleAndLayouts( DSHOW_DEVICE, dshow, "DirectShow", QGridLayout ); /* dshow Main */ int line = 0; @@ -708,7 +721,7 @@ void CaptureOpenPanel::initialize() * BDA Stuffs * **************/ if( module_exists( "bda" ) ){ - addModuleAndLayouts( BDA_DEVICE, bda, "DVB DirectShow" ); + addModuleAndLayouts( BDA_DEVICE, bda, "DVB DirectShow", QGridLayout ); /* bda Main */ QLabel *bdaTypeLabel = new QLabel( qtr( "DVB Type:" ) ); @@ -718,12 +731,14 @@ void CaptureOpenPanel::initialize() bdac = new QRadioButton( "DVB-C" ); bdat = new QRadioButton( "DVB-T" ); bdaa = new QRadioButton( "ATSC" ); + bdaq = new QRadioButton( "Clear QAM" ); bdaDevLayout->addWidget( bdaTypeLabel, 0, 0 ); bdaDevLayout->addWidget( bdas, 0, 1 ); bdaDevLayout->addWidget( bdac, 0, 2 ); bdaDevLayout->addWidget( bdat, 0, 3 ); bdaDevLayout->addWidget( bdaa, 0, 4 ); + bdaDevLayout->addWidget( bdaq, 0, 5 ); /* bda Props */ QLabel *bdaFreqLabel = @@ -766,10 +781,12 @@ void CaptureOpenPanel::initialize() BUTTONACT( bdat, updateButtons() ); BUTTONACT( bdac, updateButtons() ); BUTTONACT( bdaa, updateButtons() ); + BUTTONACT( bdaq, updateButtons() ); BUTTONACT( bdas, updateMRL() ); BUTTONACT( bdat, updateMRL() ); BUTTONACT( bdac, updateMRL() ); BUTTONACT( bdaa, updateMRL() ); + BUTTONACT( bdaq, updateMRL() ); } #else /* WIN32 */ @@ -777,7 +794,7 @@ void CaptureOpenPanel::initialize() * V4L2* *******/ if( module_exists( "v4l2" ) ){ - addModuleAndLayouts( V4L2_DEVICE, v4l2, "Video for Linux 2" ); + addModuleAndLayouts( V4L2_DEVICE, v4l2, "Video for Linux 2", QGridLayout ); /* V4l Main panel */ QLabel *v4l2VideoDeviceLabel = new QLabel( qtr( "Video device name" ) ); @@ -812,7 +829,7 @@ void CaptureOpenPanel::initialize() * V4L * *******/ if( module_exists( "v4l" ) ){ - addModuleAndLayouts( V4L_DEVICE, v4l, "Video for Linux" ); + addModuleAndLayouts( V4L_DEVICE, v4l, "Video for Linux", QGridLayout ); /* V4l Main panel */ QLabel *v4lVideoDeviceLabel = new QLabel( qtr( "Video device name" ) ); @@ -857,7 +874,8 @@ void CaptureOpenPanel::initialize() * JACK * *******/ if( module_exists( "jack" ) ){ - addModuleAndLayouts( JACK_DEVICE, jack, "JACK Audio Connection Kit" ); + addModuleAndLayouts( JACK_DEVICE, jack, "JACK Audio Connection Kit", + QGridLayout); /* Jack Main panel */ /* Channels */ @@ -896,7 +914,7 @@ void CaptureOpenPanel::initialize() jackPropLayout->addWidget( jackPace, 2, 1 ); /* Auto Connect */ - jackConnect = new QCheckBox( qtr( "Auto connnection" )); + jackConnect = new QCheckBox( qtr( "Auto connection" )); jackPropLayout->addWidget( jackConnect, 2, 2 ); /* Jack CONNECTs */ @@ -911,7 +929,7 @@ void CaptureOpenPanel::initialize() * PVR * ************/ if( module_exists( "pvr" ) ){ - addModuleAndLayouts( PVR_DEVICE, pvr, "PVR" ); + addModuleAndLayouts( PVR_DEVICE, pvr, "PVR", QGridLayout ); /* PVR Main panel */ QLabel *pvrDeviceLabel = new QLabel( qtr( "Device name" ) ); @@ -967,7 +985,7 @@ void CaptureOpenPanel::initialize() * DVB Stuffs * **************/ if( module_exists( "dvb" ) ){ - addModuleAndLayouts( DVB_DEVICE, dvb, "DVB" ); + addModuleAndLayouts( DVB_DEVICE, dvb, "DVB", QGridLayout ); /* DVB Main */ QLabel *dvbDeviceLabel = new QLabel( qtr( "Adapter card to tune" ) ); @@ -998,10 +1016,11 @@ void CaptureOpenPanel::initialize() dvbFreq = new QSpinBox; dvbFreq->setAlignment( Qt::AlignRight ); dvbFreq->setSuffix(" kHz"); + dvbFreq->setSingleStep( 1000 ); setSpinBoxFreq( dvbFreq ); dvbPropLayout->addWidget( dvbFreq, 0, 1 ); - QLabel *dvbSrateLabel = new QLabel( qtr( "Transponder symbol rate" ) ); + dvbSrateLabel = new QLabel( qtr( "Transponder symbol rate" ) ); dvbPropLayout->addWidget( dvbSrateLabel, 1, 0 ); dvbSrate = new QSpinBox; @@ -1009,6 +1028,24 @@ void CaptureOpenPanel::initialize() dvbSrate->setSuffix(" kHz"); setSpinBoxFreq( dvbSrate ); dvbPropLayout->addWidget( dvbSrate, 1, 1 ); + + dvbBandLabel = new QLabel( qtr( "Bandwidth" ) ); + dvbPropLayout->addWidget( dvbBandLabel, 2, 0 ); + + dvbBandBox = new QComboBox; + /* This doesn't work since dvb-bandwidth doesn't seem to be a + list of Integers + setfillVLCConfigCombo( "dvb-bandwidth", p_intf, bdaBandBox ); + */ + dvbBandBox->addItem( qtr( "Auto" ), 0 ); + dvbBandBox->addItem( qtr( "6 MHz" ), 6 ); + dvbBandBox->addItem( qtr( "7 MHz" ), 7 ); + dvbBandBox->addItem( qtr( "8 MHz" ), 8 ); + dvbPropLayout->addWidget( dvbBandBox, 2, 1 ); + + dvbBandLabel->hide(); + dvbBandBox->hide(); + dvbPropLayout->addItem( new QSpacerItem( 20, 20, QSizePolicy::Expanding ), 2, 0, 2, 1 ); @@ -1016,10 +1053,14 @@ void CaptureOpenPanel::initialize() CuMRL( dvbCard, valueChanged ( int ) ); CuMRL( dvbFreq, valueChanged ( int ) ); CuMRL( dvbSrate, valueChanged ( int ) ); + CuMRL( dvbBandBox, currentIndexChanged ( int ) ); BUTTONACT( dvbs, updateButtons() ); BUTTONACT( dvbt, updateButtons() ); BUTTONACT( dvbc, updateButtons() ); + BUTTONACT( dvbs, updateMRL() ); + BUTTONACT( dvbt, updateMRL() ); + BUTTONACT( dvbc, updateMRL() ); } #endif @@ -1028,9 +1069,9 @@ void CaptureOpenPanel::initialize() /********** * Screen * **********/ - addModuleAndLayouts( SCREEN_DEVICE, screen, "Desktop" ); - QLabel *screenLabel = new QLabel( "Your display will will be " - "opened and played in order to stream or save it." ); + addModuleAndLayouts( SCREEN_DEVICE, screen, "Desktop", QGridLayout ); + QLabel *screenLabel = new QLabel( qtr( "Your display will be " + "opened and played in order to stream or save it." ) ); screenLabel->setWordWrap( true ); screenDevLayout->addWidget( screenLabel, 0, 0 ); @@ -1038,11 +1079,17 @@ void CaptureOpenPanel::initialize() qtr( "Desired frame rate for the capture." ) ); screenPropLayout->addWidget( screenFPSLabel, 0, 0 ); - screenFPS = new QSpinBox; - screenFPS->setValue( 1 ); + screenFPS = new QDoubleSpinBox; + screenFPS->setValue( 1. ); + screenFPS->setRange( .01, 100. ); screenFPS->setAlignment( Qt::AlignRight ); + /* xgettext: frames per second */ + screenFPS->setSuffix( qtr( " f/s" ) ); screenPropLayout->addWidget( screenFPS, 0, 1 ); + /* Screen connect */ + CuMRL( screenFPS, valueChanged( double ) ); + /* General connects */ CONNECT( ui.deviceCombo, activated( int ) , stackedDevLayout, setCurrentIndex( int ) ); @@ -1051,7 +1098,8 @@ void CaptureOpenPanel::initialize() CONNECT( ui.deviceCombo, activated( int ), this, updateMRL() ); CONNECT( ui.deviceCombo, activated( int ), this, updateButtons() ); -#undef addModule +#undef CuMRL +#undef addModuleAndLayouts } CaptureOpenPanel::~CaptureOpenPanel() @@ -1077,38 +1125,41 @@ void CaptureOpenPanel::updateMRL() else if( bdat->isChecked() ) mrl = "dvb-t://"; else if( bdac->isChecked() ) mrl = "dvb-c://"; else if( bdaa->isChecked() ) mrl = "atsc://"; + else if( bdaq->isChecked() ) mrl = "cqam://"; else return; + mrl += "frequency=" + QString::number( bdaFreq->value() ); + if( bdac->isChecked() || bdat->isChecked() || bdaa->isChecked() ) + mrl +="000"; fileList << mrl; mrl = ""; - mrl += " :dvb-frequency=" + QString::number( bdaFreq->value() ); if( bdas->isChecked() || bdac->isChecked() ) mrl += " :dvb-srate=" + QString::number( bdaSrate->value() ); - else if( bdat->isChecked() ) + else if( bdat->isChecked() || bdaa->isChecked() ) mrl += " :dvb-bandwidth=" + QString::number( bdaBandBox->itemData( bdaBandBox->currentIndex() ).toInt() ); + emit methodChanged( "dvb-caching" ); break; case DSHOW_DEVICE: fileList << "dshow://"; mrl+= " :dshow-vdev=" + colon_escape( QString("%1").arg( vdevDshowW->getValue() ) ); mrl+= " :dshow-adev=" + - colon_escape( QString("%1").arg( adevDshowW->getValue() ) ); + colon_escape( QString("%1").arg( adevDshowW->getValue() ) )+" "; if( dshowVSizeLine->isModified() ) - mrl += " :dshow-size=" + dshowVSizeLine->text(); + mrl += ":dshow-size=" + dshowVSizeLine->text(); + emit methodChanged( "dshow-caching" ); break; #else case V4L_DEVICE: - fileList << "v4l://"; - mrl += " :v4l-vdev=" + v4lVideoDevice->text(); - mrl += " :v4l-adev=" + v4lAudioDevice->text(); + fileList << "v4l://" + v4lVideoDevice->text(); + mrl += " :input-slave=alsa://" + v4lAudioDevice->text(); mrl += " :v4l-norm=" + QString::number( v4lNormBox->currentIndex() ); mrl += " :v4l-frequency=" + QString::number( v4lFreq->value() ); break; case V4L2_DEVICE: - fileList << "v4l2://"; - mrl += " :v4l2-dev=" + v4l2VideoDevice->text(); - mrl += " :v4l2-adev=" + v4l2AudioDevice->text(); + fileList << "v4l2://" + v4l2VideoDevice->text(); + mrl += " :input-slave=alsa://" + v4l2AudioDevice->text(); mrl += " :v4l2-standard=" + QString::number( v4l2StdBox->currentIndex() ); break; case JACK_DEVICE: @@ -1138,15 +1189,26 @@ void CaptureOpenPanel::updateMRL() mrl += " :pvr-bitrate=" + QString::number( pvrBitr->value() ); break; case DVB_DEVICE: - fileList << "dvb://"; + mrl = "dvb://"; + mrl += "frequency=" + QString::number( dvbFreq->value() ); + if( dvbc->isChecked() || dvbt->isChecked() ) + mrl +="000"; + fileList << mrl; mrl= ""; + mrl += " :dvb-adapter=" + QString::number( dvbCard->value() ); - mrl += " :dvb-frequency=" + QString::number( dvbFreq->value() ); - mrl += " :dvb-srate=" + QString::number( dvbSrate->value() ); + if( dvbs->isChecked() || dvbc->isChecked() ) + mrl += " :dvb-srate=" + QString::number( dvbSrate->value() ); + else if( dvbt->isChecked() ) + mrl += " :dvb-bandwidth=" + + QString::number( dvbBandBox->itemData( + dvbBandBox->currentIndex() ).toInt() ); + break; #endif case SCREEN_DEVICE: fileList << "screen://"; - mrl = " :screen-fps=" + QString::number( screenFPS->value() ); + mrl = " :screen-fps=" + QString::number( screenFPS->value(), 'f' ); + emit methodChanged( "screen-caching" ); updateButtons(); break; } @@ -1180,18 +1242,37 @@ void CaptureOpenPanel::updateButtons() bdaBandBox->hide(); bdaBandLabel->hide(); } - else if( bdat->isChecked() ) + else if( bdat->isChecked() || bdaa->isChecked() ) { bdaSrate->hide(); bdaSrateLabel->hide(); bdaBandBox->show(); bdaBandLabel->show(); } + else if( bdaq->isChecked() ) + { + bdaSrate->hide(); + bdaSrateLabel->hide(); + bdaBandBox->hide(); + bdaBandLabel->hide(); + } break; #else case DVB_DEVICE: - if( dvbs->isChecked() ) dvbFreq->setSuffix(" kHz"); - if( dvbc->isChecked() || dvbt->isChecked() ) dvbFreq->setSuffix(" Hz"); + if( dvbs->isChecked() || dvbc->isChecked() ) + { + dvbSrate->show(); + dvbSrateLabel->show(); + dvbBandBox->hide(); + dvbBandLabel->hide(); + } + else if( dvbt->isChecked() ) + { + dvbSrate->hide(); + dvbSrateLabel->hide(); + dvbBandBox->show(); + dvbBandLabel->show(); + } break; #endif case SCREEN_DEVICE: @@ -1225,6 +1306,7 @@ void CaptureOpenPanel::advancedDialog() /* New Adv Prop dialog */ adv = new QDialog( this ); adv->setWindowTitle( qtr( "Advanced Options" ) ); + adv->setWindowRole( "vlc-advanced-options" ); /* A main Layout with a Frame */ QVBoxLayout *mainLayout = new QVBoxLayout( adv ); @@ -1244,7 +1326,8 @@ void CaptureOpenPanel::advancedDialog() module_config_t *p_item = p_config + n; ConfigControl *config = ConfigControl::createControl( VLC_OBJECT( p_intf ), p_item, advFrame, gLayout, n ); - controls.append( config ); + if ( config ) + controls.append( config ); } /* Button stuffs */ @@ -1267,11 +1350,6 @@ void CaptureOpenPanel::advancedDialog() for( int i = 0; i < controls.size(); i++ ) { ConfigControl *control = controls[i]; - if( !control ) - { - msg_Dbg( p_intf, "This shouldn't happen, please report" ); - continue; - } tempMRL += (i ? " :" : ":"); @@ -1301,6 +1379,11 @@ void CaptureOpenPanel::advancedDialog() updateMRL(); msg_Dbg( p_intf, "%s", qtu( advMRL ) ); } + for( int i = 0; i < controls.size(); i++ ) + { + ConfigControl *control = controls[i]; + delete control ; + } delete adv; module_config_free( p_config ); module_release (p_module);