X-Git-Url: https://git.dogcows.com/gitweb?p=chaz%2Fyoink;a=blobdiff_plain;f=src%2FCharacter.cc;h=c6ad2a049874d821befa4e90da831703ce2ec653;hp=1b184fa2d0160ad353ef3645823d25626397b3cf;hb=7e898e8ec0ff716e2fc722b883a626a6c346f107;hpb=57b78ebe21b1b48acd337daa5a1cb8c383959cfa diff --git a/src/Character.cc b/src/Character.cc index 1b184fa..c6ad2a0 100644 --- a/src/Character.cc +++ b/src/Character.cc @@ -39,8 +39,10 @@ Character::Character(const std::string& name) : current.mass = 1.0; current.inverseMass = 1.0 / current.mass; + // gravity current.force = Mf::Vector2(0.0, -120.0); + // starting position current.position = Mf::Vector2(64.0, 64.0); current.momentum = Mf::Vector2(0.0, 0.0); current.recalculate(); @@ -50,16 +52,22 @@ Character::Character(const std::string& name) : updateContainers(); } -Character::~Character() -{ - //delete texture; - //delete anim; -} - void Character::update(Mf::Scalar t, Mf::Scalar dt) { previous = current; + + Mf::Vector2 x = current.position - Mf::Vector2(500.0, 200.0); + Mf::Scalar mag = x.length(); + Mf::Scalar d = 50.0; + + current.force = Mf::Vector2(0.0, -2000.0); + //current.force += -15.0 * x - 1.5 * current.velocity; + current.force += -20.0 * (mag - d) * (x / mag) - 2.0 * current.velocity; + current.force += userForce; + current.recalculate(); + //std::cout << "force: " << current.momentum << std::endl; + Mf::integrate(current, t, dt); animation_.update(t, dt); @@ -79,7 +87,7 @@ void Character::handleEvent(const Mf::Event& event) { // really just for heroine... - Mf::Scalar force = 500.0; + Mf::Scalar force = 4000.0; Mf::Vector2 left = Mf::Vector2(-force, 0.0); Mf::Vector2 right = Mf::Vector2(force, 0.0); @@ -91,38 +99,38 @@ void Character::handleEvent(const Mf::Event& event) case SDL_KEYDOWN: if (event.key.keysym.sym == SDLK_a) { - current.force += left; + userForce += left; } else if (event.key.keysym.sym == SDLK_d) { - current.force += right; + userForce += right; } else if (event.key.keysym.sym == SDLK_s) { - current.force += down; + userForce += down; } else if (event.key.keysym.sym == SDLK_w) { - current.force += up; + userForce += up; } break; case SDL_KEYUP: if (event.key.keysym.sym == SDLK_a) { - current.force -= left; + userForce -= left; } else if (event.key.keysym.sym == SDLK_d) { - current.force -= right; + userForce -= right; } else if (event.key.keysym.sym == SDLK_s) { - current.force -= down; + userForce -= down; } else if (event.key.keysym.sym == SDLK_w) { - current.force -= up; + userForce -= up; } break; } @@ -156,6 +164,17 @@ void Character::draw(Mf::Scalar alpha) const glTexCoord2f(coords[6], coords[7]); glVertex3(state.position[0]-s, state.position[1]+s, z); glEnd(); + + glColor3f(0.0f, 0.0f, 0.0f); + Mf::Texture::resetBind(); + + glBegin(GL_TRIANGLES); + glVertex3(480.0, 190.0, 64.0); + glVertex3(520.0, 190.0, 64.0); + glVertex3(500.0, 210.0, 64.0); + glEnd(); + + glColor3f(1.0f, 1.0f, 1.0f); }