author | truebrain |
Wed, 23 Apr 2008 12:05:32 +0000 | |
branch | noai |
changeset 10308 | 0c81dfce3e9b |
parent 9836 | 54afebfded49 |
permissions | -rw-r--r-- |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
1 |
/* $Id$ */ |
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
2 |
|
9829
80fbe02a4184
(svn r12491) [NoAI] -Documentation: made parts of the comments more uniform (@file header and class header)
truebrain
parents:
9737
diff
changeset
|
3 |
/** @file ai_map.hpp Everything to query and manipulate map metadata. */ |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
4 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
5 |
#ifndef AI_MAP_HPP |
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
6 |
#define AI_MAP_HPP |
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
7 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
8 |
#include "ai_object.hpp" |
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
9 |
|
9448
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
10 |
/** |
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
11 |
* Class that handles all map related functions. |
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
12 |
*/ |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
13 |
class AIMap : public AIObject { |
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
14 |
public: |
9529
5f26f4bc574b
(svn r9450) [NoAI] -Fix: don't allow static-method calls from SQ to non-static functions
truelight
parents:
9526
diff
changeset
|
15 |
static const char *GetClassName() { return "AIMap"; } |
5f26f4bc574b
(svn r9450) [NoAI] -Fix: don't allow static-method calls from SQ to non-static functions
truelight
parents:
9526
diff
changeset
|
16 |
|
5f26f4bc574b
(svn r9450) [NoAI] -Fix: don't allow static-method calls from SQ to non-static functions
truelight
parents:
9526
diff
changeset
|
17 |
/** |
9448
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
18 |
* Checks whether the given tile is valid. |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
19 |
* @param tile The tile to check. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
20 |
* @return True is the tile it within the boundaries of the map. |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
21 |
*/ |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
22 |
static bool IsValidTile(TileIndex tile); |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
23 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
24 |
/** |
9448
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
25 |
* Gets the number of tiles in the map. |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
26 |
* @return The size of the map in tiles. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
27 |
* @post Return value is always positive. |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
28 |
*/ |
9655
e8e43f333832
(svn r10557) [NoAI] -Add: added for all lists 2 valuators: DistanceManhattanToTile and DistanceSquareToTile, to get the distance from object to some tile you specify
truelight
parents:
9596
diff
changeset
|
29 |
static TileIndex GetMapSize(); |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
30 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
31 |
/** |
9448
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
32 |
* Gets the amount of tiles along the SW and NE border. |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
33 |
* @return The length along the SW and NE borders. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
34 |
* @post Return value is always positive. |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
35 |
*/ |
9655
e8e43f333832
(svn r10557) [NoAI] -Add: added for all lists 2 valuators: DistanceManhattanToTile and DistanceSquareToTile, to get the distance from object to some tile you specify
truelight
parents:
9596
diff
changeset
|
36 |
static uint32 GetMapSizeX(); |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
37 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
38 |
/** |
9448
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
39 |
* Gets the amount of tiles along the SE and NW border. |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
40 |
* @return The length along the SE and NW borders. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
41 |
* @post Return value is always positive. |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
42 |
*/ |
9655
e8e43f333832
(svn r10557) [NoAI] -Add: added for all lists 2 valuators: DistanceManhattanToTile and DistanceSquareToTile, to get the distance from object to some tile you specify
truelight
parents:
9596
diff
changeset
|
43 |
static uint32 GetMapSizeY(); |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
44 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
45 |
/** |
9448
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
46 |
* Gets the place along the SW/NE border (X-value). |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
47 |
* @param tile The tile to get the X-value of. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
48 |
* @pre IsValidTile(tile). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
49 |
* @return The X-value. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
50 |
* @post Return value is always lower than GetMapSizeX(). |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
51 |
*/ |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
52 |
static uint32 GetTileX(TileIndex tile); |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
53 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
54 |
/** |
9448
2a4c4340233d
(svn r9273) [NoAI] -Documentation: finished documenting the last few files; they should now be readable for any non-programmer.
truelight
parents:
9427
diff
changeset
|
55 |
* Gets the place along the SE/NW border (Y-value). |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
56 |
* @param tile The tile to get the Y-value of. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
57 |
* @pre IsValidTile(tile). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
58 |
* @return The Y-value. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
59 |
* @post Return value is always lower than GetMapSizeY(). |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
60 |
*/ |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
61 |
static uint32 GetTileY(TileIndex tile); |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
62 |
|
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
63 |
/** |
9502
5eb285182114
(svn r9379) [NoAI] -Add: function to get the TileIndex from an (X, Y) coordinate.
rubidium
parents:
9489
diff
changeset
|
64 |
* Gets the TileIndex given a x,y-coordinate. |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
65 |
* @param x The X coordinate. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
66 |
* @param y The Y coordinate. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
67 |
* @pre x < GetMapSizeX(). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
68 |
* @pre y < GetMapSizeY(). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
69 |
* @return The TileIndex for the given (x,y) coordinate. |
9502
5eb285182114
(svn r9379) [NoAI] -Add: function to get the TileIndex from an (X, Y) coordinate.
rubidium
parents:
9489
diff
changeset
|
70 |
*/ |
9655
e8e43f333832
(svn r10557) [NoAI] -Add: added for all lists 2 valuators: DistanceManhattanToTile and DistanceSquareToTile, to get the distance from object to some tile you specify
truelight
parents:
9596
diff
changeset
|
71 |
static TileIndex GetTileIndex(uint32 x, uint32 y); |
9502
5eb285182114
(svn r9379) [NoAI] -Add: function to get the TileIndex from an (X, Y) coordinate.
rubidium
parents:
9489
diff
changeset
|
72 |
|
5eb285182114
(svn r9379) [NoAI] -Add: function to get the TileIndex from an (X, Y) coordinate.
rubidium
parents:
9489
diff
changeset
|
73 |
/** |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
74 |
* Calculates the Manhattan distance; the difference of |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
75 |
* the X and Y added together. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
76 |
* @param tile_from The start tile. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
77 |
* @param tile_to The destination tile. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
78 |
* @pre IsValidTile(tile_from). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
79 |
* @pre IsValidTile(tile_to). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
80 |
* @return The Manhattan distance between the tiles. |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
81 |
*/ |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
82 |
static uint32 DistanceManhattan(TileIndex tile_from, TileIndex tile_to); |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
83 |
|
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
84 |
/** |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
85 |
* Calculates the distance between two tiles via 1D calculation. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
86 |
* This means the distance between X or the distance between Y, depending |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
87 |
* on which one is bigger. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
88 |
* @param tile_from The start tile. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
89 |
* @param tile_to The destination tile. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
90 |
* @pre IsValidTile(tile_from). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
91 |
* @pre IsValidTile(tile_to). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
92 |
* @return The maximum distance between the tiles. |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
93 |
*/ |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
94 |
static uint32 DistanceMax(TileIndex tile_from, TileIndex tile_to); |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
95 |
|
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
96 |
/** |
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
97 |
* The squared distance between the two tiles. |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
98 |
* This is the distance is the length of the shortest straight line |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
99 |
* between both points. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
100 |
* @param tile_from The start tile. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
101 |
* @param tile_to The destination tile. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
102 |
* @pre IsValidTile(tile_from). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
103 |
* @pre IsValidTile(tile_to). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
104 |
* @return The squared distance between the tiles. |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
105 |
*/ |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
106 |
static uint32 DistanceSquare(TileIndex tile_from, TileIndex tile_to); |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
107 |
|
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
108 |
/** |
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
109 |
* Calculates the shortest distance to the edge. |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
110 |
* @param tile From where the distance has to be calculated. |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
111 |
* @pre IsValidTile(tile). |
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
112 |
* @return The distances to the closest edge. |
9489
d7ee0a65ead9
(svn r9359) [NoAI] -Add: function to determine distance and clear tiles.
rubidium
parents:
9448
diff
changeset
|
113 |
*/ |
9836
54afebfded49
(svn r12502) [NoAI] -Documentation: even more comment consistancy
truebrain
parents:
9834
diff
changeset
|
114 |
static uint32 DistanceFromEdge(TileIndex tile); |
9379
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
115 |
}; |
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
116 |
|
6e89b780c2c9
(svn r9168) [NoAI] -Add: AI wrapper functions for some map related queries.
rubidium
parents:
diff
changeset
|
117 |
#endif /* AI_MAP_HPP */ |