X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=src%2FHeroine.cc;h=e2b69b296198dc03e207b35b427c08ec6b29af1a;hp=314f2c984090c013ca697916079f731750dfc81e;hb=d11d8c63ab52c7f6eca2815e47cd6401e72f2c8c;hpb=a4debfe4a5f5d339410788971b698ba00cb7f09c diff --git a/src/Heroine.cc b/src/Heroine.cc index 314f2c9..e2b69b2 100644 --- a/src/Heroine.cc +++ b/src/Heroine.cc @@ -26,8 +26,6 @@ *******************************************************************************/ -#include - #include "Heroine.hh" #include "Log.hh" @@ -36,60 +34,57 @@ Heroine::Heroine() : Character("Heroine") {} -void Heroine::handleEvent(const Mf::Event& event) +bool Heroine::handleEvent(const Mf::Event& event) { - // really just for heroine... - - Mf::Scalar force = 4000.0; + Mf::Scalar force = 40.0; - Mf::Vector2 left = Mf::Vector2(-force, 0.0); - Mf::Vector2 right = Mf::Vector2(force, 0.0); - Mf::Vector2 down = Mf::Vector2(0.0, -force); - Mf::Vector2 up = Mf::Vector2(0.0, force); - switch (event.type) { case SDL_KEYDOWN: if (event.key.keysym.sym == SDLK_a) { - userForce += left; + mState.force += Mf::Vector2(-force, 0.0); + return true; } else if (event.key.keysym.sym == SDLK_d) { - userForce += right; + mState.force += Mf::Vector2(force, 0.0); + return true; } else if (event.key.keysym.sym == SDLK_s) { - userForce += down; + mState.force += Mf::Vector2(0.0, -force); + return true; } else if (event.key.keysym.sym == SDLK_w) { - userForce += up; + mState.force += Mf::Vector2(0.0, force); + return true; } - break; case SDL_KEYUP: if (event.key.keysym.sym == SDLK_a) { - userForce -= left; + mState.force += Mf::Vector2(force, 0.0); + return true; } else if (event.key.keysym.sym == SDLK_d) { - userForce -= right; + mState.force += Mf::Vector2(-force, 0.0); + return true; } else if (event.key.keysym.sym == SDLK_s) { - userForce -= down; + mState.force += Mf::Vector2(0.0, force); + return true; } else if (event.key.keysym.sym == SDLK_w) { - userForce -= up; + mState.force += Mf::Vector2(0.0, -force); + return true; } - break; } - - //Mf::logInfo("current force [%f %f]", current.force[0], current.force[1]); - //std::cerr << "current force: " << current.force << std::endl; + return false; }