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:
jean-pierre charras 2021-01-19 10:26:33 +01:00
parent 1491330596
commit fed56572f8
1 changed files with 11 additions and 3 deletions

View File

@ -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 );