ddnet/src/game/collision.cpp

82 lines
1.5 KiB
C++
Raw Normal View History

2007-11-25 19:42:40 +00:00
/* copyright (c) 2007 magnus auvinen, see licence.txt for more info */
#include <base/system.h>
#include <base/math.hpp>
#include <base/vmath.hpp>
#include <math.h>
#include <engine/e_common_interface.h>
2008-08-17 08:52:24 +00:00
#include <game/mapitems.hpp>
#include <game/layers.hpp>
2008-09-23 14:10:05 +00:00
#include <game/collision.hpp>
static TILE *tiles;
static int width = 0;
static int height = 0;
int col_width() { return width; }
int col_height() { return height; }
int col_init()
{
width = layers_game_layer()->width;
height = layers_game_layer()->height;
tiles = (TILE *)map_get_data(layers_game_layer()->data);
2008-09-23 14:38:13 +00:00
for(int i = 0; i < width*height; i++)
{
int index = tiles[i].index;
if(index > 128)
continue;
if(index == TILE_DEATH)
tiles[i].index = COLFLAG_DEATH;
else if(index == TILE_SOLID)
tiles[i].index = COLFLAG_SOLID;
else if(index == TILE_NOHOOK)
tiles[i].index = COLFLAG_SOLID|COLFLAG_NOHOOK;
else
tiles[i].index = 0;
}
return 1;
}
2008-09-23 14:10:05 +00:00
int col_get(int x, int y)
{
2008-09-23 14:10:05 +00:00
int nx = clamp(x/32, 0, width-1);
int ny = clamp(y/32, 0, height-1);
2008-09-23 14:10:05 +00:00
if(tiles[ny*width+nx].index > 128)
return 0;
return tiles[ny*width+nx].index;
}
int col_is_solid(int x, int y)
{
return col_get(x,y)&COLFLAG_SOLID;
}
2008-09-23 14:10:05 +00:00
// TODO: rewrite this smarter!
2008-09-23 14:38:13 +00:00
int col_intersect_line(vec2 pos0, vec2 pos1, vec2 *out)
{
float d = distance(pos0, pos1);
for(float f = 0; f < d; f++)
{
float a = f/d;
vec2 pos = mix(pos0, pos1, a);
if(col_is_solid((int)pos.x, (int)pos.y))
{
if(out)
*out = pos;
2008-09-23 14:38:13 +00:00
return col_get((int)pos.x, (int)pos.y);
}
}
if(out)
*out = pos1;
2008-09-23 14:38:13 +00:00
return 0;
}