Commit 76cee1b9 authored by Jean-Baptiste Kempf's avatar Jean-Baptiste Kempf

Qt4 - Stop the stupidity of the input Slider:

- Click on a point on the timeline goes to that point directly
- Draging the timeline makes the position follow your draging
- Hovering a point on the timeline gives you the time of the position under your cursor.

This make break your neck, and kill your favourite ant, but I think this is not that wrong.
parent e2efbd62
...@@ -21,7 +21,6 @@ ...@@ -21,7 +21,6 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
*****************************************************************************/ *****************************************************************************/
#include "qt4.hpp"
#include "util/input_slider.hpp" #include "util/input_slider.hpp"
#include <QPaintEvent> #include <QPaintEvent>
...@@ -37,13 +36,14 @@ InputSlider::InputSlider( QWidget *_parent ) : QSlider( _parent ) ...@@ -37,13 +36,14 @@ InputSlider::InputSlider( QWidget *_parent ) : QSlider( _parent )
InputSlider::InputSlider( Qt::Orientation q,QWidget *_parent ) : InputSlider::InputSlider( Qt::Orientation q,QWidget *_parent ) :
QSlider( q, _parent ) QSlider( q, _parent )
{ {
mymove = false; b_sliding = false;
setMinimum( 0 ); setMinimum( 0 );
setMouseTracking(true); setMouseTracking(true);
setMaximum( 1000 ); setMaximum( 1000 );
setSingleStep( 2 ); setSingleStep( 2 );
setPageStep( 10 ); setPageStep( 10 );
setTracking( true ); setTracking( true );
secstotimestr( psz_length, 0 );
CONNECT( this, valueChanged(int), this, userDrag( int ) ); CONNECT( this, valueChanged(int), this, userDrag( int ) );
} }
...@@ -53,24 +53,31 @@ void InputSlider::setPosition( float pos, int a, int b ) ...@@ -53,24 +53,31 @@ void InputSlider::setPosition( float pos, int a, int b )
setEnabled( false ); setEnabled( false );
else else
setEnabled( true ); setEnabled( true );
mymove = true;
if( !b_sliding )
setValue( (int)(pos * 1000.0 ) ); setValue( (int)(pos * 1000.0 ) );
mymove = false;
inputLength = b; inputLength = b;
} }
void InputSlider::userDrag( int new_value ) void InputSlider::userDrag( int new_value )
{ {
float f_pos = (float)(new_value)/1000.0; if( b_sliding )
if( !mymove )
{ {
float f_pos = (float)(new_value)/1000.0;
emit sliderDragged( f_pos ); emit sliderDragged( f_pos );
} }
} }
void InputSlider::mouseReleaseEvent( QMouseEvent *event )
{
b_sliding = false;
}
void InputSlider::mousePressEvent(QMouseEvent* event) void InputSlider::mousePressEvent(QMouseEvent* event)
{ {
if( event->button() != Qt::LeftButton && event->button() != Qt::MidButton ) b_sliding = true ;
if( event->button() != Qt::LeftButton &&
event->button() != Qt::MidButton )
{ {
QSlider::mousePressEvent( event ); QSlider::mousePressEvent( event );
return; return;
...@@ -85,7 +92,11 @@ void InputSlider::mousePressEvent(QMouseEvent* event) ...@@ -85,7 +92,11 @@ void InputSlider::mousePressEvent(QMouseEvent* event)
void InputSlider::mouseMoveEvent(QMouseEvent *event) void InputSlider::mouseMoveEvent(QMouseEvent *event)
{ {
char psz_length[MSTRTIME_MAX_SIZE]; if( b_sliding )
{
QSlider::mouseMoveEvent( event );
}
secstotimestr( psz_length, ( event->x() * inputLength) / size().width() ); secstotimestr( psz_length, ( event->x() * inputLength) / size().width() );
setToolTip( psz_length ); setToolTip( psz_length );
} }
......
...@@ -24,6 +24,8 @@ ...@@ -24,6 +24,8 @@
#ifndef _INPUTSLIDER_H_ #ifndef _INPUTSLIDER_H_
#define _INPUTSLIDER_H_ #define _INPUTSLIDER_H_
#include "qt4.hpp"
#include <QSlider> #include <QSlider>
#include <QMouseEvent> #include <QMouseEvent>
...@@ -37,9 +39,11 @@ public: ...@@ -37,9 +39,11 @@ public:
protected: protected:
virtual void mouseMoveEvent(QMouseEvent *event); virtual void mouseMoveEvent(QMouseEvent *event);
virtual void mousePressEvent(QMouseEvent* event); virtual void mousePressEvent(QMouseEvent* event);
virtual void mouseReleaseEvent(QMouseEvent* event);
private: private:
bool mymove; bool b_sliding;
int inputLength; int inputLength;
char psz_length[MSTRTIME_MAX_SIZE];
public slots: public slots:
void setPosition( float, int, int ); void setPosition( float, int, int );
private slots: private slots:
......
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