Commit a1029e49 authored by Jean-Baptiste Kempf's avatar Jean-Baptiste Kempf

Qt: don't use a modal dialog for continuing the playback

Close #11705 #11703

(cherry picked from commit a3f6eeeb90422e40a2650d05be667b410aec3668)
Signed-off-by: default avatarJean-Baptiste Kempf <jb@videolan.org>
parent 4860e26f
...@@ -136,12 +136,7 @@ void InputManager::setInput( input_thread_t *_p_input ) ...@@ -136,12 +136,7 @@ void InputManager::setInput( input_thread_t *_p_input )
!var_GetFloat( p_input, "start-time" ) && !var_GetFloat( p_input, "start-time" ) &&
!var_GetFloat( p_input, "stop-time" ) ) !var_GetFloat( p_input, "stop-time" ) )
{ {
if( QMessageBox::question( NULL, emit continuePlayback( (int64_t)i_time * 1000 );
_("Continue playback?"),
_("Do you want to restart the playback where left off?"),
QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes )
== QMessageBox::Yes )
var_SetTime( p_input, "time", (int64_t)i_time * 1000 );
} }
} }
} }
......
...@@ -223,6 +223,8 @@ signals: ...@@ -223,6 +223,8 @@ signals:
void titleChanged( bool ); void titleChanged( bool );
void chapterChanged( bool ); void chapterChanged( bool );
void inputCanSeek( bool ); void inputCanSeek( bool );
/// You can continuePlayback
void continuePlayback( int64_t );
/// Statistics are updated /// Statistics are updated
void statisticsUpdated( input_item_t* ); void statisticsUpdated( input_item_t* );
void infoChanged( input_item_t* ); void infoChanged( input_item_t* );
......
...@@ -60,6 +60,8 @@ ...@@ -60,6 +60,8 @@
#include <QStackedWidget> #include <QStackedWidget>
#include <QFileInfo> #include <QFileInfo>
#include <QTimer>
#include <vlc_keys.h> /* Wheel event */ #include <vlc_keys.h> /* Wheel event */
#include <vlc_vout_display.h> /* vout_thread_t and VOUT_ events */ #include <vlc_vout_display.h> /* vout_thread_t and VOUT_ events */
...@@ -366,6 +368,56 @@ void MainInterface::reloadPrefs() ...@@ -366,6 +368,56 @@ void MainInterface::reloadPrefs()
} }
} }
void MainInterface::createContinueDialog( QWidget *w )
{
/* Create non-modal continueDialog */
continueDialog = new QWidget( w );
continueDialog->hide();
QHBoxLayout *continueDialogLayout = new QHBoxLayout( continueDialog );
continueDialogLayout->setSpacing( 0 ); continueDialogLayout->setMargin( 0 );
QLabel *continueLabel = new QLabel( qtr( "Do you want to restart the playback where left off?") );
QToolButton *cancel = new QToolButton( continueDialog );
cancel->setAutoRaise( true );
cancel->setText( "X" );
QPushButton *ok = new QPushButton( qtr("&Continue") );
continueDialogLayout->addWidget(continueLabel);
continueDialogLayout->addStretch( 1 );
continueDialogLayout->addWidget( ok );
continueDialogLayout->addWidget( cancel );
CONNECT( cancel, clicked(), continueDialog, hide() );
BUTTONACT(ok, continuePlayback() );
CONNECT( THEMIM->getIM(), continuePlayback(int64_t), this, showContinueDialog(int64_t) );
w->layout()->addWidget( continueDialog );
}
void MainInterface::showContinueDialog( int64_t _time ) {
int setting = var_InheritInteger( p_intf, "qt-continue" );
if( setting == 0 )
return;
i_continueTime = _time;
if( setting == 2)
continuePlayback();
else
{
continueDialog->setVisible(true);
QTimer::singleShot(6000, continueDialog, SLOT(hide()));
}
}
void MainInterface::continuePlayback()
{
var_SetTime( THEMIM->getInput(), "time", i_continueTime );
continueDialog->hide();
}
void MainInterface::createMainWidget( QSettings *creationSettings ) void MainInterface::createMainWidget( QSettings *creationSettings )
{ {
/* Create the main Widget and the mainLayout */ /* Create the main Widget and the mainLayout */
...@@ -375,6 +427,7 @@ void MainInterface::createMainWidget( QSettings *creationSettings ) ...@@ -375,6 +427,7 @@ void MainInterface::createMainWidget( QSettings *creationSettings )
main->setContentsMargins( 0, 0, 0, 0 ); main->setContentsMargins( 0, 0, 0, 0 );
mainLayout->setSpacing( 0 ); mainLayout->setMargin( 0 ); mainLayout->setSpacing( 0 ); mainLayout->setMargin( 0 );
createContinueDialog( main );
/* */ /* */
stackCentralW = new QVLCStackedWidget( main ); stackCentralW = new QVLCStackedWidget( main );
......
...@@ -111,6 +111,7 @@ private: ...@@ -111,6 +111,7 @@ private:
void createMainWidget( QSettings* ); void createMainWidget( QSettings* );
void createStatusBar(); void createStatusBar();
void createPlaylist(); void createPlaylist();
void createContinueDialog( QWidget *w );
/* Systray */ /* Systray */
void createSystray(); void createSystray();
...@@ -146,6 +147,10 @@ private: ...@@ -146,6 +147,10 @@ private:
PlaylistWidget *playlistWidget; PlaylistWidget *playlistWidget;
//VisualSelector *visualSelector; //VisualSelector *visualSelector;
/* continue */
QWidget *continueDialog;
int64_t i_continueTime;
/* Status Bar */ /* Status Bar */
QLabel *nameLabel; QLabel *nameLabel;
QLabel *cryptedLabel; QLabel *cryptedLabel;
...@@ -254,6 +259,9 @@ private slots: ...@@ -254,6 +259,9 @@ private slots:
void setBoss(); void setBoss();
void setRaise(); void setRaise();
void showContinueDialog( int64_t);
void continuePlayback();
signals: signals:
void askGetVideo( WId *p_id, int *pi_x, int *pi_y, void askGetVideo( WId *p_id, int *pi_x, int *pi_y,
unsigned *pi_width, unsigned *pi_height ); unsigned *pi_width, unsigned *pi_height );
......
...@@ -185,12 +185,21 @@ static void ShowDialog ( intf_thread_t *, int, int, intf_dialog_args_t * ); ...@@ -185,12 +185,21 @@ static void ShowDialog ( intf_thread_t *, int, int, intf_dialog_args_t * );
#define FULLSCREEN_CONTROL_PIXELS N_( "Fullscreen controller mouse sensitivity" ) #define FULLSCREEN_CONTROL_PIXELS N_( "Fullscreen controller mouse sensitivity" )
#define CONTINUE_PLAYBACK_TEXT N_("Continue playback?")
static const int i_notification_list[] = static const int i_notification_list[] =
{ NOTIFICATION_NEVER, NOTIFICATION_MINIMIZED, NOTIFICATION_ALWAYS }; { NOTIFICATION_NEVER, NOTIFICATION_MINIMIZED, NOTIFICATION_ALWAYS };
static const char *const psz_notification_list_text[] = static const char *const psz_notification_list_text[] =
{ N_("Never"), N_("When minimized"), N_("Always") }; { N_("Never"), N_("When minimized"), N_("Always") };
static const int i_continue_list[] =
{ 0, 1, 2 };
static const char *const psz_continue_list_text[] =
{ N_("Never"), N_("Ask"), N_("Always") };
/**********************************************************************/ /**********************************************************************/
vlc_module_begin () vlc_module_begin ()
set_shortname( "Qt" ) set_shortname( "Qt" )
...@@ -233,6 +242,8 @@ vlc_module_begin () ...@@ -233,6 +242,8 @@ vlc_module_begin ()
RECENTPLAY_TEXT, false ) RECENTPLAY_TEXT, false )
add_string( "qt-recentplay-filter", "", add_string( "qt-recentplay-filter", "",
RECENTPLAY_FILTER_TEXT, RECENTPLAY_FILTER_LONGTEXT, false ) RECENTPLAY_FILTER_TEXT, RECENTPLAY_FILTER_LONGTEXT, false )
add_integer( "qt-continue", 1, CONTINUE_PLAYBACK_TEXT, CONTINUE_PLAYBACK_TEXT, false )
change_integer_list(i_continue_list, psz_continue_list_text )
#ifdef UPDATE_CHECK #ifdef UPDATE_CHECK
add_bool( "qt-updates-notif", true, UPDATER_TEXT, add_bool( "qt-updates-notif", true, UPDATER_TEXT,
......
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