From 92b06e397e5d18b24584dfaf5869929a9579b314 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Sat, 4 May 2013 21:04:42 +0300 Subject: prevent mouse cursor moving in android in onscreen controls. --- src/gui/gui.cpp | 13 ++++++++++++- src/gui/gui.h | 5 ++++- 2 files changed, 16 insertions(+), 2 deletions(-) (limited to 'src/gui') diff --git a/src/gui/gui.cpp b/src/gui/gui.cpp index e243bfc27..13290975a 100644 --- a/src/gui/gui.cpp +++ b/src/gui/gui.cpp @@ -89,6 +89,10 @@ Gui::Gui(Graphics *const graphics) : mMouseCursorAlpha(1.0f), mMouseInactivityTimer(0), mCursorType(Cursor::CURSOR_POINTER), +#ifdef ANDROID + mLastMouseRealX(0), + mLastMouseRealY(0), +#endif mFocusListeners(), mCustomCursor(false) { @@ -687,6 +691,10 @@ void Gui::handleMouseInput() if (touchManager.processEvent(mouseInput)) { +#ifdef ANDROID + SDL_WarpMouse(mLastMouseX, mLastMouseY, + mLastMouseRealX, mLastMouseRealY); +#endif mMouseInactivityTimer = 0; continue; } @@ -695,7 +703,10 @@ void Gui::handleMouseInput() // changes or modal mouse input focus changes. mLastMouseX = mouseInput.getX(); mLastMouseY = mouseInput.getY(); - +#ifdef ANDROID + mLastMouseRealX = mouseInput.getRealX(); + mLastMouseRealY = mouseInput.getRealY(); +#endif switch (mouseInput.getType()) { case gcn::MouseInput::PRESSED: diff --git a/src/gui/gui.h b/src/gui/gui.h index 477e93d6d..d14198d97 100644 --- a/src/gui/gui.h +++ b/src/gui/gui.h @@ -173,7 +173,10 @@ class Gui final : public gcn::Gui float mMouseCursorAlpha; int mMouseInactivityTimer; int mCursorType; - +#ifdef ANDROID + uint16_t mLastMouseRealX; + uint16_t mLastMouseRealY; +#endif typedef std::list FocusListenerList; typedef FocusListenerList::iterator FocusListenerIterator; FocusListenerList mFocusListeners; -- cgit v1.2.3-70-g09d2