diff options
author | Bertram <bertram@cegetel.net> | 2009-10-29 14:31:41 +0100 |
---|---|---|
committer | Bertram <bertram@cegetel.net> | 2009-10-29 14:31:41 +0100 |
commit | 168673240a70dcb551ac2b1ba8188c559537c8b7 (patch) | |
tree | 757e79f04c6ff633e8bdc9bdb2a5e402636d58d7 /src/gui | |
parent | 6d2a6ee01523bbec105cd2e6ce9a24ab7c1094f2 (diff) | |
download | mana-168673240a70dcb551ac2b1ba8188c559537c8b7.tar.gz mana-168673240a70dcb551ac2b1ba8188c559537c8b7.tar.bz2 mana-168673240a70dcb551ac2b1ba8188c559537c8b7.tar.xz mana-168673240a70dcb551ac2b1ba8188c559537c8b7.zip |
Cleaned up the viewport code, when dealing with mouse movement.
Now, both eAthena and ManaServ clients follow the mouse correctly
when it is dragged.
Diffstat (limited to 'src/gui')
-rw-r--r-- | src/gui/viewport.cpp | 97 | ||||
-rw-r--r-- | src/gui/viewport.h | 9 |
2 files changed, 52 insertions, 54 deletions
diff --git a/src/gui/viewport.cpp b/src/gui/viewport.cpp index 6e9720e9..ded0f061 100644 --- a/src/gui/viewport.cpp +++ b/src/gui/viewport.cpp @@ -192,7 +192,7 @@ void Viewport::draw(gcn::Graphics *gcnGraphics) mMap->drawCollision(graphics, (int) mPixelViewX, (int) mPixelViewY); - drawDebugPath(graphics); + _drawDebugPath(graphics); } } @@ -228,34 +228,35 @@ void Viewport::logic() { WindowContainer::logic(); - if (!mMap || !player_node) - return; + // Make the player follow the mouse position + // if the mouse is dragged elsewhere than in a window. + _followMouse(); +} +void Viewport::_followMouse() +{ Uint8 button = SDL_GetMouseState(&mMouseX, &mMouseY); -#ifdef EATHENA_SUPPORT - - if (mPlayerFollowMouse && button & SDL_BUTTON(1) && - mWalkTime != player_node->mWalkTime) + // If the left button is dragged + if (mPlayerFollowMouse && button & SDL_BUTTON(1)) { - player_node->setDestination(mMouseX / 32 + mTileViewX, - mMouseY / 32 + mTileViewY); - mWalkTime = player_node->mWalkTime; + // We create a mouse event and send it to mouseDragged. + Uint8 *keys = SDL_GetKeyState(NULL); + gcn::MouseEvent mouseEvent(NULL, + (keys[SDLK_LSHIFT] || keys[SDLK_RSHIFT]), + false, + false, + false, + gcn::MouseEvent::DRAGGED, + gcn::MouseEvent::LEFT, + mMouseX, + mMouseY, + 0); + + mouseDragged(mouseEvent); } -#else // MANASERV_SUPPORT - Uint8 *keys = SDL_GetKeyState(NULL); - if (mPlayerFollowMouse && button & SDL_BUTTON(1) && - !(keys[SDLK_LSHIFT] || keys[SDLK_RSHIFT]) && - get_elapsed_time(mLocalWalkTime) >= walkingMouseDelay) - { - mLocalWalkTime = tick_time; - player_node->setDestination(mMouseX + (int) mPixelViewX, - mMouseY + (int) mPixelViewY); - player_node->pathSetByMouse(); - } -#endif } -void Viewport::drawDebugPath(Graphics *graphics) +void Viewport::_drawDebugPath(Graphics *graphics) { // Get the current mouse position SDL_GetMouseState(&mMouseX, &mMouseY); @@ -269,10 +270,10 @@ void Viewport::drawDebugPath(Graphics *graphics) (int) (playerPos.y - 32) / 32, mouseTileX, mouseTileY, 0xFF); - drawPath(graphics, debugPath); + _drawPath(graphics, debugPath); } -void Viewport::drawPath(Graphics *graphics, const Path &path) +void Viewport::_drawPath(Graphics *graphics, const Path &path) { graphics->setColor(gcn::Color(255, 0, 0)); for (Path::const_iterator i = path.begin(); i != path.end(); ++i) @@ -380,22 +381,11 @@ void Viewport::mousePressed(gcn::MouseEvent &event) // Just walk around else { -#ifdef MANASERV_SUPPORT - // FIXME: REALLY UGLY! - Uint8 *keys = SDL_GetKeyState(NULL); - if (!(keys[SDLK_LSHIFT] || keys[SDLK_RSHIFT]) && - get_elapsed_time(mLocalWalkTime) >= walkingMouseDelay) - { - mLocalWalkTime = tick_time; - player_node->setDestination(event.getX() + (int) mPixelViewX, - event.getY() + (int) mPixelViewY); - player_node->pathSetByMouse(); - } -#else - player_node->setDestination(tilex, tiley); -#endif player_node->stopAttack(); mPlayerFollowMouse = true; + + // Make the player go to the mouse position + _followMouse(); } } else if (event.getButton() == gcn::MouseEvent::MIDDLE) @@ -415,22 +405,25 @@ void Viewport::mouseDragged(gcn::MouseEvent &event) if (!mMap || !player_node) return; -#ifdef MANASERV_SUPPORT - if (mPlayerFollowMouse - && get_elapsed_time(mLocalWalkTime) >= walkingMouseDelay) + if (mPlayerFollowMouse && !event.isShiftPressed()) { - mLocalWalkTime = tick_time; - player_node->setDestination(event.getX() + (int) mPixelViewX, - event.getY() + (int) mPixelViewY); - } +#ifdef MANASERV_SUPPORT + if (get_elapsed_time(mLocalWalkTime) >= walkingMouseDelay) + { + mLocalWalkTime = tick_time; + player_node->setDestination(event.getX() + (int) mPixelViewX, + event.getY() + (int) mPixelViewY); + player_node->pathSetByMouse(); + } #else - if (mPlayerFollowMouse && mWalkTime == player_node->mWalkTime) - { - int destX = event.getX() / 32 + mTileViewX; - int destY = event.getY() / 32 + mTileViewY; - player_node->setDestination(destX, destY); - } + if (mWalkTime != player_node->mWalkTime) + { + int destX = event.getX() / 32 + mTileViewX; + int destY = event.getY() / 32 + mTileViewY; + player_node->setDestination(destX, destY); + } #endif + } } void Viewport::mouseReleased(gcn::MouseEvent &event) diff --git a/src/gui/viewport.h b/src/gui/viewport.h index 39dfaa33..e4311222 100644 --- a/src/gui/viewport.h +++ b/src/gui/viewport.h @@ -149,12 +149,17 @@ class Viewport : public WindowContainer, public gcn::MouseListener, * Finds a path from the player to the mouse, and draws it. This is for * debug purposes. */ - void drawDebugPath(Graphics *graphics); + void _drawDebugPath(Graphics *graphics); /** * Draws the given path. */ - void drawPath(Graphics *graphics, const Path &path); + void _drawPath(Graphics *graphics, const Path &path); + + /** + * Make the player go to the mouse position. + */ + void _followMouse(); Map *mMap; /**< The current map. */ |