Refinements and fixes in auto-pan.
Add comments. Fix incorrect comparison. Fix a too fast auto-pan speed when auto-pan acceleration was not set to the minimal value.
This commit is contained in:
parent
1491330596
commit
fed56572f8
|
@ -494,13 +494,21 @@ void WX_VIEW_CONTROLS::onTimer( wxTimerEvent& aEvent )
|
||||||
double borderSize = std::min( m_settings.m_autoPanMargin * m_view->GetScreenPixelSize().x,
|
double borderSize = std::min( m_settings.m_autoPanMargin * m_view->GetScreenPixelSize().x,
|
||||||
m_settings.m_autoPanMargin * m_view->GetScreenPixelSize().y );
|
m_settings.m_autoPanMargin * m_view->GetScreenPixelSize().y );
|
||||||
|
|
||||||
|
// When the mouse cursor is outside the area with no pan,
|
||||||
|
// m_panDirection is the dist to this area limit ( in pixels )
|
||||||
|
// It will be used also as pan value (the pan speed depends on this dist).
|
||||||
VECTOR2D dir( m_panDirection );
|
VECTOR2D dir( m_panDirection );
|
||||||
|
|
||||||
|
// When the mouse cursor is outside the area with no pan, the pan value
|
||||||
|
// is accelerated depending on the dist between the area and the cursor
|
||||||
float accel = 0.5f + ( m_settings.m_autoPanAcceleration / 5.0f );
|
float accel = 0.5f + ( m_settings.m_autoPanAcceleration / 5.0f );
|
||||||
|
|
||||||
if( dir.EuclideanNorm() > borderSize / 2 )
|
// For a small mouse cursor dist to area, just use the distance.
|
||||||
dir = dir.Resize( pow( borderSize, accel ) );
|
// But for a dist > borderSize / 2, use an accelerated pan value
|
||||||
else if( dir.EuclideanNorm() > borderSize )
|
|
||||||
|
if( dir.EuclideanNorm() >= borderSize ) // far from area limits
|
||||||
|
dir = dir.Resize( borderSize * accel );
|
||||||
|
else if( dir.EuclideanNorm() > borderSize / 2 ) // Near from area limits
|
||||||
dir = dir.Resize( borderSize );
|
dir = dir.Resize( borderSize );
|
||||||
|
|
||||||
dir = m_view->ToWorld( dir, false );
|
dir = m_view->ToWorld( dir, false );
|
||||||
|
|
Loading…
Reference in New Issue