X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=src%2FHeroine.cc;h=4ca4ce8702006cd46bd55c79ec5465d71f947fda;hp=2071a7bba6d4595a390d2c1c0f0635e3163cc5ce;hb=574af38ed616d1adfa5e6ce35f67cda1f707f89d;hpb=a31d65a998121df0651c57bfb68782e2a07d2e2f diff --git a/src/Heroine.cc b/src/Heroine.cc index 2071a7b..4ca4ce8 100644 --- a/src/Heroine.cc +++ b/src/Heroine.cc @@ -1,92 +1,88 @@ -/******************************************************************************* +/*] Copyright (c) 2009-2011, Charles McGarvey [***************************** +**] All rights reserved. +* +* Distributable under the terms and conditions of the 2-clause BSD license; +* see the file COPYING for a complete text of the license. +* +*****************************************************************************/ - Copyright (c) 2009, Charles McGarvey - All rights reserved. - - Redistribution and use in source and binary forms, with or without - modification, are permitted provided that the following conditions are met: - - * Redistributions of source code must retain the above copyright notice, - this list of conditions and the following disclaimer. - * Redistributions in binary form must reproduce the above copyright notice, - this list of conditions and the following disclaimer in the documentation - and/or other materials provided with the distribution. - - THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" - AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE - DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE - FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR - SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER - CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, - OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE - OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. - -*******************************************************************************/ +#include +#include #include "Heroine.hh" -#include "Log.hh" - + Heroine::Heroine() : Character("Heroine") {} +void Heroine::update(moof::scalar t, moof::scalar dt) +{ + Character::update(t, dt); + + moof::vector3 at(0.0, 0.0, 0.0); + const moof::vector3 up(0.0, 1.0, 0.0); -bool Heroine::handleEvent(const Mf::Event& event) + if (state_.velocity[0] < 0.0) at[0] = -1.0; + else at[0] = 1.0; + + moof::sound::listener_position(moof::promote(state_.position)); + moof::sound::listener_velocity(moof::promote(state_.velocity)); + moof::sound::listener_orientation(at, up); +} + +bool Heroine::handle_event(const moof::event& event) { - Mf::Scalar force = 4000.0; + moof::scalar force = 40.0; switch (event.type) { - case SDL_KEYDOWN: - if (event.key.keysym.sym == SDLK_a) - { - mState.force += Mf::Vector2(-force, 0.0); - return true; - } - else if (event.key.keysym.sym == SDLK_d) - { - mState.force += Mf::Vector2(force, 0.0); - return true; - } - else if (event.key.keysym.sym == SDLK_s) - { - mState.force += Mf::Vector2(0.0, -force); - return true; - } - else if (event.key.keysym.sym == SDLK_w) - { - mState.force += Mf::Vector2(0.0, force); - return true; - } + case SDL_KEYDOWN: + if (event.key.keysym.sym == SDLK_a) + { + state_.force += moof::vector2(-force, 0.0); + return true; + } + else if (event.key.keysym.sym == SDLK_d) + { + state_.force += moof::vector2(force, 0.0); + return true; + } + else if (event.key.keysym.sym == SDLK_s) + { + state_.force += moof::vector2(0.0, -force); + return true; + } + else if (event.key.keysym.sym == SDLK_w) + { + state_.force += moof::vector2(0.0, force); + return true; + } + break; - case SDL_KEYUP: - if (event.key.keysym.sym == SDLK_a) - { - mState.force += Mf::Vector2(force, 0.0); - return true; - } - else if (event.key.keysym.sym == SDLK_d) - { - mState.force += Mf::Vector2(-force, 0.0); - return true; - } - else if (event.key.keysym.sym == SDLK_s) - { - mState.force += Mf::Vector2(0.0, force); - return true; - } - else if (event.key.keysym.sym == SDLK_w) - { - mState.force += Mf::Vector2(0.0, -force); - return true; - } + case SDL_KEYUP: + if (event.key.keysym.sym == SDLK_a) + { + state_.force += moof::vector2(force, 0.0); + return true; + } + else if (event.key.keysym.sym == SDLK_d) + { + state_.force += moof::vector2(-force, 0.0); + return true; + } + else if (event.key.keysym.sym == SDLK_s) + { + state_.force += moof::vector2(0.0, force); + return true; + } + else if (event.key.keysym.sym == SDLK_w) + { + state_.force += moof::vector2(0.0, -force); + return true; + } + break; } return false; } - -/** vim: set ts=4 sw=4 tw=80: *************************************************/ -