]> git.sesse.net Git - vlc/commitdiff
Qt4 - Have a slider to control precisely the rate, usefull since we can here audio...
authorJean-Baptiste Kempf <jb@videolan.org>
Sun, 9 Sep 2007 17:42:50 +0000 (17:42 +0000)
committerJean-Baptiste Kempf <jb@videolan.org>
Sun, 9 Sep 2007 17:42:50 +0000 (17:42 +0000)
Patch by StFS - Stefán Freyr Stefánsson

modules/gui/qt4/components/interface_widgets.cpp
modules/gui/qt4/components/interface_widgets.hpp
modules/gui/qt4/main_interface.cpp
modules/gui/qt4/main_interface.hpp

index ae7941639c1235076292a18521f2bc374fad3e91..469249bcbba21ed7902cd2e8948f3b2ee860417a 100644 (file)
@@ -494,7 +494,6 @@ ControlsWidget::ControlsWidget( intf_thread_t *_p_i, bool b_advControls ) :
 
     /* Volume control connection */
     CONNECT( volumeSlider, valueChanged( int ), this, updateVolume( int ) );
-
 }
 ControlsWidget::~ControlsWidget()
 {
@@ -673,8 +672,8 @@ void ControlsWidget::toggleAdvanced()
 #include "components/playlist/panels.hpp"
 #include "components/playlist/selector.hpp"
 
-PlaylistWidget::PlaylistWidget( intf_thread_t *_p_intf ) :
-                                p_intf ( _p_intf )
+PlaylistWidget::PlaylistWidget( intf_thread_t *_p_i ) :
+                                p_intf ( _p_i )
 {
     /* Left Part and design */
     QWidget *leftW = new QWidget( this );
@@ -746,3 +745,129 @@ QSize PlaylistWidget::sizeHint() const
     return widgetSize;
 }
 
+/**********************************************************************
+ * Speed control widget
+ **********************************************************************/
+SpeedControlWidget::SpeedControlWidget( intf_thread_t *_p_i ) :
+                             QFrame( NULL ), p_intf( _p_i )
+{      
+       QSizePolicy sizePolicy( QSizePolicy::Maximum, QSizePolicy::Fixed );
+    sizePolicy.setHorizontalStretch( 0 );
+    sizePolicy.setVerticalStretch( 0 );
+    
+    speedSlider = new QSlider;
+    speedSlider->setSizePolicy( sizePolicy );
+    speedSlider->setMaximumSize( QSize( 80, 200 ) );
+    speedSlider->setOrientation( Qt::Vertical );
+    speedSlider->setTickPosition( QSlider::TicksRight );
+    speedSlider->setFocusPolicy( Qt::NoFocus );
+
+    speedSlider->setMinimum( -100 );
+    speedSlider->setMaximum( 100 );
+    speedSlider->setSingleStep( 10 );
+    speedSlider->setPageStep( 20 );
+    speedSlider->setTickInterval( 20 );
+    
+    CONNECT( speedSlider, valueChanged( int ), this, updateRate( int ) );
+    
+    //QWidgetAction *wa = new QWidgetAction( this );
+    //wa->setDefaultWidget( playSpeedSlider );
+    //menu.addAction( wa ); 
+       
+    normalSpeedButton = new QPushButton( "N" );
+    //BUTTON_SET_ACT( revertToNormalButton, "N", qtr( "Normal" ), slower() );
+    //controlLayout->addWidget( revertToNormalButton, 0, 0 );
+    normalSpeedButton->setMaximumSize( QSize( 26, 20 ) );
+    normalSpeedButton->setFlat(true);
+    
+    CONNECT( normalSpeedButton, clicked(), this, resetRate() );
+    
+    QLabel *volMuteLabel = new QLabel("N");
+    //volMuteLabel->setPixmap( QPixmap( ":/pixmaps/volume-low.png" ) );
+    volMuteLabel->setToolTip( qtr( "Revert to normal play speed" ) );
+    //volMuteLabel->installEventFilter( h );
+    
+    
+    QVBoxLayout *speedControlLayout = new QVBoxLayout;
+       speedControlLayout->addWidget(speedSlider);
+       speedControlLayout->addWidget(normalSpeedButton);
+       //speedControlLayout->addWidget(volMuteLabel);
+       setLayout(speedControlLayout);
+}
+
+SpeedControlWidget::~SpeedControlWidget()
+{
+}
+
+#define RATE_SLIDER_CONSTANT 3.0
+
+#define SLIDER_MIN_SPEED 1.0 / RATE_SLIDER_CONSTANT
+#define SLIDER_SLOW_RANGE 1.0 - SLIDER_MIN_SPEED
+#define SLIDER_MAX_SPEED RATE_SLIDER_CONSTANT
+#define SLIDER_FAST_RANGE 1.0 - SLIDER_MAX_SPEED
+
+void SpeedControlWidget::updateControls( int rate )
+{
+       if( speedSlider->isSliderDown() )
+       {
+               //We don't want to change anything if the user is using the slider
+               return;
+       }
+       
+       int sliderValue;
+       double speed = INPUT_RATE_DEFAULT / (double)rate;
+       
+       if( rate >= INPUT_RATE_DEFAULT )
+       {               
+               if( speed < SLIDER_MIN_SPEED )
+               {
+                       sliderValue = speedSlider->minimum();
+               }
+               else
+               {
+                       double currPos = speed / (double)(SLIDER_SLOW_RANGE);
+                       sliderValue = (int)( currPos * speedSlider->minimum() );
+               }
+       }
+       else
+       {
+               if( speed > SLIDER_MAX_SPEED )
+               {
+                       sliderValue = speedSlider->maximum();
+               }
+               else
+               {
+                       double currPos = ( 1.0 - speed ) / (double)(SLIDER_FAST_RANGE);
+                       sliderValue = (int)( currPos * speedSlider->maximum() );
+               }
+       }
+       
+       //Block signals to avoid feedback loop
+       speedSlider->blockSignals(true);
+       speedSlider->setValue(sliderValue);
+       speedSlider->blockSignals(false);
+}
+
+void SpeedControlWidget::updateRate( int sliderValue )
+{
+       int rate;
+       double var;
+       
+       if( sliderValue < 0.0 )
+       {
+               var = 1.0 + ((-sliderValue/100.0) * RATE_SLIDER_CONSTANT-1.0);
+               rate = INPUT_RATE_DEFAULT * var;
+       }
+       else
+       {
+               var = 1.0 + ((sliderValue/100.0) * RATE_SLIDER_CONSTANT-1.0);
+               rate = INPUT_RATE_DEFAULT / var;
+       }
+
+    THEMIM->getIM()->setRate(rate);    
+}
+
+void SpeedControlWidget::resetRate()
+{
+    THEMIM->getIM()->setRate(INPUT_RATE_DEFAULT);      
+}
index 2ac1b59a31067d35e9f6670966a6e93b9dd83682..a42a63a023b3ad5f279c7c30adb1868e23667afe 100644 (file)
@@ -233,4 +233,23 @@ signals:
     void artSet( QString );
 };
 
+
+/******************** Speed Control Widgets ****************/
+class SpeedControlWidget : public QFrame
+{
+    Q_OBJECT
+public:
+    SpeedControlWidget( intf_thread_t *);
+    virtual ~SpeedControlWidget();
+    void updateControls( int );
+private:
+    intf_thread_t *p_intf;
+    QSlider *speedSlider;
+    QPushButton *normalSpeedButton;
+private slots:
+    void updateRate( int );
+    void resetRate();
+};
+
+
 #endif
index bfba720fb6b2d44403c2781d9c42a15dee0f1f17..f2ea88f5b49a04576f7a81cb1e9c7ff080d91391 100644 (file)
@@ -42,6 +42,8 @@
 #include <QSize>
 #include <QMenu>
 #include <QLabel>
+#include <QSlider>
+#include <QWidgetAction>
 
 #include <assert.h>
 #include <vlc_keys.h>
@@ -302,6 +304,12 @@ void MainInterface::handleMainUi( QSettings *settings )
     /* Add the controls Widget to the main Widget */
     mainLayout->addWidget( controls );
 
+    /* Create the Speed Control Widget */
+    speedControl = new SpeedControlWidget( p_intf );
+    speedControlMenu = new QMenu( this );
+    QWidgetAction *widgetAction = new QWidgetAction( this );
+    widgetAction->setDefaultWidget( speedControl );
+    speedControlMenu->addAction( widgetAction );
 
     /* Set initial size */
     resize( PREF_W, PREF_H );
@@ -397,9 +405,7 @@ void MainInterface::resizeEvent( QResizeEvent *e )
  ****************************************************************************/
 void MainInterface::showSpeedMenu( QPoint pos )
 {
-    QMenu menu( this );
-    menu.addAction( "Not Implemented Yet" );
-    menu.exec( QCursor::pos() );
+    speedControlMenu->exec( QCursor::pos() );
 }
 
 void MainInterface::showTimeMenu( QPoint pos )
@@ -694,6 +700,7 @@ void MainInterface::setRate( int rate )
     str.setNum( ( 1000/(double)rate), 'f', 2 );
     str.append( "x" );
     speedLabel->setText( str );
+    speedControl->updateControls( rate );
 }
 
 void MainInterface::updateOnTimer()
index f7878963f6048a20ecc6be08a70e59d7acd07226..ea5c908842678b090b274ba938564725bd23031e 100644 (file)
@@ -44,6 +44,7 @@ class PlaylistWidget;
 class VisualSelector;
 class AdvControlsWidget;
 class ControlsWidget;
+class SpeedControlWidget;
 class QMenu;
 class QSize;
 
@@ -82,6 +83,8 @@ private:
     QString              input_name;
     QVBoxLayout         *mainLayout;
     ControlsWidget      *controls;
+    QMenu                              *speedControlMenu;
+    SpeedControlWidget  *speedControl;
 
     bool                 need_components_update;