Changed view control settings to KiCad default (panning, zooming, etc.)
This commit is contained in:
parent
ced0d8add9
commit
4868af8b62
|
@ -61,6 +61,8 @@ CAIRO_GAL::CAIRO_GAL( wxWindow* aParent, wxEvtHandler* aMouseListener,
|
||||||
Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
||||||
Connect( wxEVT_LEFT_DOWN, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
Connect( wxEVT_LEFT_DOWN, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
||||||
Connect( wxEVT_LEFT_UP, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
Connect( wxEVT_LEFT_UP, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
||||||
|
Connect( wxEVT_MIDDLE_DOWN, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
||||||
|
Connect( wxEVT_MIDDLE_UP, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
||||||
#if defined _WIN32 || defined _WIN64
|
#if defined _WIN32 || defined _WIN64
|
||||||
Connect( wxEVT_ENTER_WINDOW, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
Connect( wxEVT_ENTER_WINDOW, wxMouseEventHandler( CAIRO_GAL::skipMouseEvent ) );
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -90,6 +90,8 @@ OPENGL_GAL::OPENGL_GAL( wxWindow* aParent, wxEvtHandler* aMouseListener,
|
||||||
Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
Connect( wxEVT_RIGHT_UP, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
||||||
Connect( wxEVT_LEFT_DOWN, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
Connect( wxEVT_LEFT_DOWN, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
||||||
Connect( wxEVT_LEFT_UP, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
Connect( wxEVT_LEFT_UP, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
||||||
|
Connect( wxEVT_MIDDLE_DOWN, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
||||||
|
Connect( wxEVT_MIDDLE_UP, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
||||||
#if defined _WIN32 || defined _WIN64
|
#if defined _WIN32 || defined _WIN64
|
||||||
Connect( wxEVT_ENTER_WINDOW, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
Connect( wxEVT_ENTER_WINDOW, wxMouseEventHandler( OPENGL_GAL::skipMouseEvent ) );
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -42,9 +42,9 @@ WX_VIEW_CONTROLS::WX_VIEW_CONTROLS( VIEW* aView, wxWindow* aParentPanel ) :
|
||||||
WX_VIEW_CONTROLS::onMotion ), NULL, this );
|
WX_VIEW_CONTROLS::onMotion ), NULL, this );
|
||||||
m_parentPanel->Connect( wxEVT_MOUSEWHEEL, wxMouseEventHandler(
|
m_parentPanel->Connect( wxEVT_MOUSEWHEEL, wxMouseEventHandler(
|
||||||
WX_VIEW_CONTROLS::onWheel ), NULL, this );
|
WX_VIEW_CONTROLS::onWheel ), NULL, this );
|
||||||
m_parentPanel->Connect( wxEVT_RIGHT_UP, wxMouseEventHandler(
|
m_parentPanel->Connect( wxEVT_MIDDLE_UP, wxMouseEventHandler(
|
||||||
WX_VIEW_CONTROLS::onButton ), NULL, this );
|
WX_VIEW_CONTROLS::onButton ), NULL, this );
|
||||||
m_parentPanel->Connect( wxEVT_RIGHT_DOWN, wxMouseEventHandler(
|
m_parentPanel->Connect( wxEVT_MIDDLE_DOWN, wxMouseEventHandler(
|
||||||
WX_VIEW_CONTROLS::onButton ), NULL, this );
|
WX_VIEW_CONTROLS::onButton ), NULL, this );
|
||||||
#if defined _WIN32 || defined _WIN64
|
#if defined _WIN32 || defined _WIN64
|
||||||
m_parentPanel->Connect( wxEVT_ENTER_WINDOW, wxMouseEventHandler(
|
m_parentPanel->Connect( wxEVT_ENTER_WINDOW, wxMouseEventHandler(
|
||||||
|
@ -55,10 +55,6 @@ WX_VIEW_CONTROLS::WX_VIEW_CONTROLS( VIEW* aView, wxWindow* aParentPanel ) :
|
||||||
|
|
||||||
void WX_VIEW_CONTROLS::onMotion( wxMouseEvent& event )
|
void WX_VIEW_CONTROLS::onMotion( wxMouseEvent& event )
|
||||||
{
|
{
|
||||||
// workaround for wxmsw..
|
|
||||||
//if( event.Entering() )
|
|
||||||
//m_parentPanel->SetFocus();
|
|
||||||
|
|
||||||
if( event.Dragging() && m_isDragPanning )
|
if( event.Dragging() && m_isDragPanning )
|
||||||
{
|
{
|
||||||
VECTOR2D mousePoint( event.GetX(), event.GetY() );
|
VECTOR2D mousePoint( event.GetX(), event.GetY() );
|
||||||
|
@ -77,8 +73,28 @@ void WX_VIEW_CONTROLS::onWheel( wxMouseEvent& event )
|
||||||
{
|
{
|
||||||
const double wheelPanSpeed = 0.001;
|
const double wheelPanSpeed = 0.001;
|
||||||
|
|
||||||
if( event.ControlDown() )
|
if( event.ControlDown() || event.ShiftDown() )
|
||||||
{
|
{
|
||||||
|
// Scrolling
|
||||||
|
VECTOR2D scrollVec = m_view->ToWorld( m_view->GetScreenPixelSize() *
|
||||||
|
( (double) event.GetWheelRotation() * wheelPanSpeed ), false );
|
||||||
|
double scrollSpeed;
|
||||||
|
|
||||||
|
if( abs( scrollVec.x ) > abs( scrollVec.y ) )
|
||||||
|
scrollSpeed = scrollVec.x;
|
||||||
|
else
|
||||||
|
scrollSpeed = scrollVec.y;
|
||||||
|
|
||||||
|
VECTOR2D t = m_view->GetScreenPixelSize();
|
||||||
|
VECTOR2D delta( event.ControlDown() ? -scrollSpeed : 0.0,
|
||||||
|
event.ShiftDown() ? -scrollSpeed : 0.0 );
|
||||||
|
|
||||||
|
m_view->SetCenter( m_view->GetCenter() + delta );
|
||||||
|
m_parentPanel->Refresh();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Zooming
|
||||||
wxLongLong timeStamp = wxGetLocalTimeMillis();
|
wxLongLong timeStamp = wxGetLocalTimeMillis();
|
||||||
double timeDiff = timeStamp.ToDouble() - m_timeStamp.ToDouble();
|
double timeDiff = timeStamp.ToDouble() - m_timeStamp.ToDouble();
|
||||||
|
|
||||||
|
@ -96,29 +112,10 @@ void WX_VIEW_CONTROLS::onWheel( wxMouseEvent& event )
|
||||||
zoomScale = ( event.GetWheelRotation() > 0.0 ) ? 1.05 : 0.95;
|
zoomScale = ( event.GetWheelRotation() > 0.0 ) ? 1.05 : 0.95;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
VECTOR2D anchor = m_view->ToWorld( VECTOR2D( event.GetX(), event.GetY() ) );
|
VECTOR2D anchor = m_view->ToWorld( VECTOR2D( event.GetX(), event.GetY() ) );
|
||||||
m_view->SetScale( m_view->GetScale() * zoomScale, anchor );
|
m_view->SetScale( m_view->GetScale() * zoomScale, anchor );
|
||||||
m_parentPanel->Refresh();
|
m_parentPanel->Refresh();
|
||||||
}
|
}
|
||||||
else
|
|
||||||
{
|
|
||||||
VECTOR2D scrollVec = m_view->ToWorld( m_view->GetScreenPixelSize() *
|
|
||||||
( (double) event.GetWheelRotation() * wheelPanSpeed ), false );
|
|
||||||
double scrollSpeed;
|
|
||||||
|
|
||||||
if( abs( scrollVec.x ) > abs( scrollVec.y ) )
|
|
||||||
scrollSpeed = scrollVec.x;
|
|
||||||
else
|
|
||||||
scrollSpeed = scrollVec.y;
|
|
||||||
|
|
||||||
VECTOR2D t = m_view->GetScreenPixelSize();
|
|
||||||
VECTOR2D delta( event.ShiftDown() ? scrollSpeed : 0.0,
|
|
||||||
!event.ShiftDown() ? scrollSpeed : 0.0 );
|
|
||||||
|
|
||||||
m_view->SetCenter( m_view->GetCenter() + delta );
|
|
||||||
m_parentPanel->Refresh();
|
|
||||||
}
|
|
||||||
|
|
||||||
event.Skip();
|
event.Skip();
|
||||||
}
|
}
|
||||||
|
@ -126,13 +123,13 @@ void WX_VIEW_CONTROLS::onWheel( wxMouseEvent& event )
|
||||||
|
|
||||||
void WX_VIEW_CONTROLS::onButton( wxMouseEvent& event )
|
void WX_VIEW_CONTROLS::onButton( wxMouseEvent& event )
|
||||||
{
|
{
|
||||||
if( event.RightDown() )
|
if( event.MiddleDown() )
|
||||||
{
|
{
|
||||||
m_isDragPanning = true;
|
m_isDragPanning = true;
|
||||||
m_dragStartPoint = VECTOR2D( event.GetX(), event.GetY() );
|
m_dragStartPoint = VECTOR2D( event.GetX(), event.GetY() );
|
||||||
m_lookStartPoint = m_view->GetCenter();
|
m_lookStartPoint = m_view->GetCenter();
|
||||||
}
|
}
|
||||||
else if( event.RightUp() )
|
else if( event.MiddleUp() )
|
||||||
{
|
{
|
||||||
m_isDragPanning = false;
|
m_isDragPanning = false;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue