More implementation for attacking
This commit is contained in:
parent
931ced321a
commit
e51a328641
38
gamedata.cpp
38
gamedata.cpp
|
@ -32,7 +32,7 @@ void GameData::do_vertex(int x, int y, int r)
|
|||
{
|
||||
if (current != NULL &&
|
||||
(MathUtils::distance(current->x, current->y, x, y)
|
||||
> get_move_radius()))
|
||||
> get_range()))
|
||||
{
|
||||
select_vertex(x, y);
|
||||
return;
|
||||
|
@ -122,26 +122,20 @@ float GameData::calculate_strength(Vertex* node)
|
|||
float GameData::calculate_strength_r(Vertex* node, unsigned int depth, list<Vertex*>& visited)
|
||||
{
|
||||
// Find which vertices we need to visit from here
|
||||
list<Edge> es = get_vertex_edges(node);
|
||||
list<Vertex*> neighbors = get_neighbors(node);
|
||||
list<Vertex*> to_visit;
|
||||
|
||||
visited.push_back(node);
|
||||
|
||||
for (list<Edge>::iterator cursor = es.begin(); cursor != es.end();
|
||||
cursor++)
|
||||
for (list<Vertex*>::iterator cursor = neighbors.begin();
|
||||
cursor != neighbors.end(); cursor++)
|
||||
{
|
||||
Edge e = *cursor;
|
||||
Vertex* v = *cursor;
|
||||
// if this is true, we haven't visited the vertex on the other end of
|
||||
// this edge yet
|
||||
if (e.a == node &&
|
||||
find(visited.begin(), visited.end(), e.b) == visited.end())
|
||||
if (find(visited.begin(), visited.end(), v) == visited.end())
|
||||
{
|
||||
to_visit.push_back(e.b);
|
||||
}
|
||||
else if (e.b == node &&
|
||||
find(visited.begin(), visited.end(), e.a) == visited.end())
|
||||
{
|
||||
to_visit.push_back(e.a);
|
||||
to_visit.push_back(v);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -169,8 +163,20 @@ float GameData::calculate_strength_r(Vertex* node, unsigned int depth, list<Vert
|
|||
}
|
||||
|
||||
|
||||
int GameData::get_move_radius(Vertex* node)
|
||||
int GameData::get_range(Vertex* node)
|
||||
{
|
||||
if (current == NULL) return 0;
|
||||
else return 100;
|
||||
if (node == NULL) node = current;
|
||||
|
||||
if (node == NULL) return 0;
|
||||
else if (mode == MODE_MOVE) return 100;
|
||||
else if (mode == MODE_ATTACK)
|
||||
{
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
void GameData::attack_vertex(Vertex* target)
|
||||
{
|
||||
|
||||
}
|
||||
|
|
|
@ -25,15 +25,16 @@ class GameData : public Graph
|
|||
// select or add vertex, as appropriate
|
||||
void do_vertex(int x, int y, int r);
|
||||
void select_vertex(int x, int y);
|
||||
void attack_vertex(Vertex* target);
|
||||
|
||||
bool add_vertex(int x, int y, int r, int colour);
|
||||
|
||||
Mode get_mode() const { return mode; }
|
||||
Mode set_mode(Mode m) { mode = m; }
|
||||
|
||||
// returns the move/attack radius (based on mode) for the specified node
|
||||
// returns the move/attack range for the specified node
|
||||
// (or the selected node if node == NULL)
|
||||
int get_move_radius(Vertex* node = NULL);
|
||||
int get_range(Vertex* node = NULL);
|
||||
|
||||
private:
|
||||
float calculate_strength(Vertex* node);
|
||||
|
|
18
graph.cpp
18
graph.cpp
|
@ -138,7 +138,7 @@ list<Vertex*> Graph::get_colour(int colour)
|
|||
}
|
||||
|
||||
|
||||
list<Edge> Graph::get_vertex_edges(Vertex* v)
|
||||
list<Edge> Graph::get_edges(Vertex* v)
|
||||
{
|
||||
list<Edge> answer;
|
||||
|
||||
|
@ -151,3 +151,19 @@ list<Edge> Graph::get_vertex_edges(Vertex* v)
|
|||
|
||||
return answer;
|
||||
}
|
||||
|
||||
|
||||
list<Vertex*> Graph::get_neighbors(Vertex* v)
|
||||
{
|
||||
list<Vertex*> answer;
|
||||
|
||||
for (list<Edge>::iterator cursor = edges.begin();
|
||||
cursor != edges.end(); cursor++)
|
||||
{
|
||||
Edge e = *cursor;
|
||||
if (e.a == v) answer.push_back(e.b);
|
||||
else if (e.b == v) answer.push_back(e.a);
|
||||
}
|
||||
|
||||
return answer;
|
||||
}
|
||||
|
|
3
graph.h
3
graph.h
|
@ -49,7 +49,8 @@ class Graph
|
|||
list<Vertex*> get_vertices() const { return vertices; }
|
||||
list<Edge> get_edges() const { return edges; }
|
||||
list<Vertex*> get_colour(int colour);
|
||||
list<Edge> get_vertex_edges(Vertex* v);
|
||||
list<Edge> get_edges(Vertex* v);
|
||||
list<Vertex*> get_neighbors(Vertex* v);
|
||||
|
||||
bool point_in_vertex(int x, int y, int size);
|
||||
Vertex * vertex_at(int x, int y);
|
||||
|
|
Loading…
Reference in New Issue
Block a user