Velocity collision detection (2D)

Posted by ultifinitus on Game Development See other posts from Game Development or by ultifinitus
Published on 2011-03-17T17:09:51Z Indexed on 2011/03/18 0:19 UTC
Read the original article Hit count: 311

Alright, so I have made a simple game engine (see youtube)

And my current implementation of collision resolution has a slight problem, involving the velocity of a platform.

Basically I run through all of the objects necessary to detect collisions on and resolve those collisions as I find them. Part of that resolution is setting the player's velocity = the platform's velocity. Which works great! Unless I have a row of platforms moving at different velocities or a platform between a stack of tiles....

(current system)

bool player::handle_collisions() {
collisions tcol;

bool did_handle = false;
bool thisObjectHandle = false;

for (int temp = 0; temp < collideQueue.size(); temp++) {
 thisObjectHandle = false;
 tcol = get_collision(prevPos.x,y,get_img()->get_width(),get_img()->get_height(),
                collideQueue[temp]->get_position().x,collideQueue[temp]->get_position().y,
                     collideQueue[temp]->get_img()->get_width(),collideQueue[temp]->get_img()->get_height());

if (prevPos.y >= collideQueue[temp]->get_prev_pos().y + collideQueue[temp]->get_img()->get_height())
  if (tcol.top > 0) {
    add_pos(0,tcol.top);
    set_vel(get_vel().x,collideQueue[temp]->get_vel().y);
    thisObjectHandle = did_handle = true;
  }

if (prevPos.y + get_img()->get_height() <= collideQueue[temp]->get_prev_pos().y)
  if (tcol.bottom > 0) {
    add_pos(collideQueue[temp]->get_vel().x,-tcol.bottom);
    set_vel(get_vel().x/*collideQueue[temp]->get_vel().x*/,collideQueue[temp]->get_vel().y);
    ableToJump = true;
    jumpTimes = maxjumpable;
    thisObjectHandle = did_handle = true;
  }

///
/// ADD CODE FROM NEXT CODE BLOCK HERE (on forum, not in code)
///

}

for (int temp = 0; temp < collideQueue.size(); temp++) {
thisObjectHandle = false;
tcol = get_collision(x,y,get_img()->get_width(),get_img()->get_height(),
                     collideQueue[temp]->get_position().x,collideQueue[temp]->get_position().y,
                     collideQueue[temp]->get_img()->get_width(),collideQueue[temp]->get_img()->get_height());


if (prevPos.x + get_img()->get_width() <= collideQueue[temp]->get_prev_pos().x)
  if (tcol.left > 0) {
    add_pos(-tcol.left,0);
    set_vel(collideQueue[temp]->get_vel().x,get_vel().y);
    thisObjectHandle = did_handle = true;
  }
if (prevPos.x >= collideQueue[temp]->get_prev_pos().x + collideQueue[temp]->get_img()->get_width())
  if (tcol.right > 0) {
    add_pos(tcol.right,0);
    set_vel(collideQueue[temp]->get_vel().x,get_vel().y);
    thisObjectHandle = did_handle = true;
  }
}


return did_handle;
}

(if I add the following code {where the comment to do so is}, which is glitchy, the above problem doesn't happen, though it brings others)

if (!thisObjectHandle) {
  if (tcol.bottom > tcol.top) {
    add_pos(collideQueue[temp]->get_vel().x,-tcol.bottom);
    set_vel(get_vel().x,collideQueue[temp]->get_vel().y);
  }
  else if (tcol.top > tcol.bottom) {
    add_pos(0,tcol.top);
    set_vel(get_vel().x,collideQueue[temp]->get_vel().y);
  }
}

How would you change my system to prevent this?

© Game Development or respective owner

Related posts about c++

Related posts about architecture