|
|
|
/****************************************************************************
|
|
|
|
**
|
|
|
|
** Definition of TQThumbWheel class
|
|
|
|
**
|
|
|
|
** Created : 010205
|
|
|
|
**
|
|
|
|
** Copyright (C) 1992-2008 Trolltech ASA. All rights reserved.
|
|
|
|
**
|
|
|
|
** This file is part of the widgets module of the TQt GUI Toolkit.
|
|
|
|
**
|
|
|
|
** This file may be used under the terms of the GNU General
|
|
|
|
** Public License versions 2.0 or 3.0 as published by the Free
|
|
|
|
** Software Foundation and appearing in the files LICENSE.GPL2
|
|
|
|
** and LICENSE.GPL3 included in the packaging of this file.
|
|
|
|
** Alternatively you may (at your option) use any later version
|
|
|
|
** of the GNU General Public License if such license has been
|
|
|
|
** publicly approved by Trolltech ASA (or its successors, if any)
|
|
|
|
** and the KDE Free TQt Foundation.
|
|
|
|
**
|
|
|
|
** Please review the following information to ensure GNU General
|
|
|
|
** Public Licensing requirements will be met:
|
|
|
|
** http://trolltech.com/products/qt/licenses/licensing/opensource/.
|
|
|
|
** If you are unsure which license is appropriate for your use, please
|
|
|
|
** review the following information:
|
|
|
|
** http://trolltech.com/products/qt/licenses/licensing/licensingoverview
|
|
|
|
** or contact the sales department at sales@trolltech.com.
|
|
|
|
**
|
|
|
|
** This file may be used under the terms of the Q Public License as
|
|
|
|
** defined by Trolltech ASA and appearing in the file LICENSE.TQPL
|
|
|
|
** included in the packaging of this file. Licensees holding valid TQt
|
|
|
|
** Commercial licenses may use this file in accordance with the TQt
|
|
|
|
** Commercial License Agreement provided with the Software.
|
|
|
|
**
|
|
|
|
** This file is provided "AS IS" with NO WARRANTY OF ANY KIND,
|
|
|
|
** INCLUDING THE WARRANTIES OF DESIGN, MERCHANTABILITY AND FITNESS FOR
|
|
|
|
** A PARTICULAR PURPOSE. Trolltech reserves all rights not granted
|
|
|
|
** herein.
|
|
|
|
**
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#include "qthumbwheel.h"
|
|
|
|
|
|
|
|
#ifndef TQT_NO_THUMBWHEEL
|
|
|
|
#include <tqpainter.h>
|
|
|
|
#include <tqdrawutil.h>
|
|
|
|
#include <tqpixmap.h>
|
|
|
|
#include <math.h>
|
|
|
|
|
|
|
|
static const double m_pi = 3.14159265358979323846;
|
|
|
|
static const double rad_factor = 180.0 / m_pi;
|
|
|
|
|
|
|
|
TQThumbWheel::TQThumbWheel( TQWidget *parent, const char *name )
|
|
|
|
: TQFrame( parent, name )
|
|
|
|
{
|
|
|
|
orient = Vertical;
|
|
|
|
init();
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Destructs the wheel.
|
|
|
|
*/
|
|
|
|
|
|
|
|
TQThumbWheel::~TQThumbWheel()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\internal
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::init()
|
|
|
|
{
|
|
|
|
track = TRUE;
|
|
|
|
mousePressed = FALSE;
|
|
|
|
pressedAt = -1;
|
|
|
|
rat = 1.0;
|
|
|
|
setFrameStyle( WinPanel | Sunken );
|
|
|
|
setMargin( 2 );
|
|
|
|
setFocusPolicy( WheelFocus );
|
|
|
|
}
|
|
|
|
|
|
|
|
void TQThumbWheel::setOrientation( Orientation orientation )
|
|
|
|
{
|
|
|
|
orient = orientation;
|
|
|
|
update();
|
|
|
|
}
|
|
|
|
|
|
|
|
void TQThumbWheel::setTracking( bool enable )
|
|
|
|
{
|
|
|
|
track = enable;
|
|
|
|
}
|
|
|
|
|
|
|
|
void TQThumbWheel::setTransmissionRatio( double r )
|
|
|
|
{
|
|
|
|
rat = r;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
Makes TQRangeControl::setValue() available as a slot.
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::setValue( int value )
|
|
|
|
{
|
|
|
|
TQRangeControl::setValue( value );
|
|
|
|
}
|
|
|
|
|
|
|
|
void TQThumbWheel::valueChange()
|
|
|
|
{
|
|
|
|
repaint( FALSE );
|
|
|
|
emit valueChanged(value());
|
|
|
|
}
|
|
|
|
|
|
|
|
void TQThumbWheel::rangeChange()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void TQThumbWheel::stepChange()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\reimp
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::keyPressEvent( TQKeyEvent *e )
|
|
|
|
{
|
|
|
|
switch ( e->key() ) {
|
|
|
|
case Key_Left:
|
|
|
|
if ( orient == Horizontal )
|
|
|
|
subtractLine();
|
|
|
|
break;
|
|
|
|
case Key_Right:
|
|
|
|
if ( orient == Horizontal )
|
|
|
|
addLine();
|
|
|
|
break;
|
|
|
|
case Key_Up:
|
|
|
|
if ( orient == Vertical )
|
|
|
|
subtractLine();
|
|
|
|
break;
|
|
|
|
case Key_Down:
|
|
|
|
if ( orient == Vertical )
|
|
|
|
addLine();
|
|
|
|
break;
|
|
|
|
case Key_PageUp:
|
|
|
|
subtractPage();
|
|
|
|
break;
|
|
|
|
case Key_PageDown:
|
|
|
|
addPage();
|
|
|
|
break;
|
|
|
|
case Key_Home:
|
|
|
|
setValue( minValue() );
|
|
|
|
break;
|
|
|
|
case Key_End:
|
|
|
|
setValue( maxValue() );
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
e->ignore();
|
|
|
|
return;
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\reimp
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::mousePressEvent( TQMouseEvent *e )
|
|
|
|
{
|
|
|
|
if ( e->button() == LeftButton ) {
|
|
|
|
mousePressed = TRUE;
|
|
|
|
pressedAt = valueFromPosition( e->pos() );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\reimp
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::mouseReleaseEvent( TQMouseEvent *e )
|
|
|
|
{
|
|
|
|
int movedTo = valueFromPosition( e->pos() );
|
|
|
|
setValue( value() + movedTo - pressedAt );
|
|
|
|
pressedAt = movedTo;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\reimp
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::mouseMoveEvent( TQMouseEvent *e )
|
|
|
|
{
|
|
|
|
if ( !mousePressed )
|
|
|
|
return;
|
|
|
|
if ( track ) {
|
|
|
|
int movedTo = valueFromPosition( e->pos() );
|
|
|
|
setValue( value() + movedTo - pressedAt );
|
|
|
|
pressedAt = movedTo;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\reimp
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::wheelEvent( TQWheelEvent *e )
|
|
|
|
{
|
|
|
|
int step = ( e->state() & ControlButton ) ? lineStep() : pageStep();
|
|
|
|
setValue( value() - e->delta()*step/120 );
|
|
|
|
e->accept();
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!\reimp
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::focusInEvent( TQFocusEvent *e )
|
|
|
|
{
|
|
|
|
TQWidget::focusInEvent( e );
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!\reimp
|
|
|
|
*/
|
|
|
|
|
|
|
|
void TQThumbWheel::focusOutEvent( TQFocusEvent *e )
|
|
|
|
{
|
|
|
|
TQWidget::focusOutEvent( e );
|
|
|
|
}
|
|
|
|
|
|
|
|
void TQThumbWheel::drawContents( TQPainter *p )
|
|
|
|
{
|
|
|
|
TQRect cr = contentsRect();
|
|
|
|
// double buffer
|
|
|
|
TQPixmap pix( width(), height() );
|
|
|
|
TQPainter pt( &pix );
|
|
|
|
TQBrush brush = backgroundPixmap() ?
|
|
|
|
TQBrush( backgroundColor(), *backgroundPixmap() ) : TQBrush( backgroundColor() );
|
|
|
|
pt.fillRect( cr, brush );
|
|
|
|
|
|
|
|
const int n = 17;
|
|
|
|
const double delta = m_pi / double(n);
|
|
|
|
// ### use positionFromValue() with rad*16 or similar
|
|
|
|
double alpha = 2*m_pi*double(value()-minValue())/
|
|
|
|
double(maxValue()-minValue())*transmissionRatio();
|
|
|
|
alpha = fmod(alpha, delta);
|
|
|
|
TQPen pen0( colorGroup().midlight() );
|
|
|
|
TQPen pen1( colorGroup().dark() );
|
|
|
|
|
|
|
|
if ( orient == Horizontal ) {
|
|
|
|
double r = 0.5*cr.width();
|
|
|
|
int y0 = cr.y()+1;
|
|
|
|
int y1 = cr.bottom()-1;
|
|
|
|
for ( int i = 0; i < n; i++ ) {
|
|
|
|
int x = cr.x() + int((1-cos(delta*double(i)+alpha))*r);
|
|
|
|
pt.setPen( pen0 );
|
|
|
|
pt.drawLine( x, y0, x, y1 );
|
|
|
|
pt.setPen( pen1 );
|
|
|
|
pt.drawLine( x+1, y0, x+1, y1 );
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// vertical orientation
|
|
|
|
double r = 0.5*cr.height();
|
|
|
|
int x0 = cr.x()+1;
|
|
|
|
int x1 = cr.right()-1;
|
|
|
|
for ( int i = 0; i < n; i++ ) {
|
|
|
|
int y = cr.y() + int((1-cos(delta*double(i)+alpha))*r);
|
|
|
|
pt.setPen( pen0 );
|
|
|
|
pt.drawLine( x0, y, x1, y );
|
|
|
|
pt.setPen( pen1 );
|
|
|
|
pt.drawLine( x0, y+1, x1, y+1 );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
qDrawShadePanel( &pt, cr, colorGroup());
|
|
|
|
|
|
|
|
pt.end();
|
|
|
|
p->drawPixmap( 0, 0, pix );
|
|
|
|
}
|
|
|
|
|
|
|
|
int TQThumbWheel::valueFromPosition( const TQPoint &p )
|
|
|
|
{
|
|
|
|
TQRect wrec = contentsRect();
|
|
|
|
int pos, min, max;
|
|
|
|
if ( orient == Horizontal ) {
|
|
|
|
pos = p.x();
|
|
|
|
min = wrec.left();
|
|
|
|
max = wrec.right();
|
|
|
|
} else {
|
|
|
|
pos = p.y();
|
|
|
|
min = wrec.top();
|
|
|
|
max = wrec.bottom();
|
|
|
|
}
|
|
|
|
double alpha;
|
|
|
|
if ( pos < min )
|
|
|
|
alpha = 0;
|
|
|
|
else if ( pos > max )
|
|
|
|
alpha = m_pi;
|
|
|
|
else
|
|
|
|
alpha = acos( 1.0 - 2.0*double(pos-min)/double(max-min) );// ### taylor
|
|
|
|
double deg = alpha*rad_factor/transmissionRatio();
|
|
|
|
// ### use valueFromPosition()
|
|
|
|
return minValue() + int((maxValue()-minValue())*deg/360.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|