Update TileMap to use Vector2i instead of two ints

This commit is contained in:
Aaron Franke 2020-06-30 02:34:15 -04:00
parent ee44982c45
commit 75e3f6b732
No known key found for this signature in database
GPG Key ID: 40A1750B977E56BF
4 changed files with 11 additions and 5 deletions

View File

@ -90,9 +90,10 @@
<method name="map_to_world" qualifiers="const"> <method name="map_to_world" qualifiers="const">
<return type="Vector2"> <return type="Vector2">
</return> </return>
<argument index="0" name="map_position" type="Vector2"> <argument index="0" name="map_position" type="Vector2i">
</argument> </argument>
<description> <description>
Returns the local position corresponding to the given tilemap (grid-based) coordinates.
</description> </description>
</method> </method>
<method name="set_cell"> <method name="set_cell">
@ -107,6 +108,7 @@
<argument index="3" name="alternative_tile" type="int" default="-1"> <argument index="3" name="alternative_tile" type="int" default="-1">
</argument> </argument>
<description> <description>
Sets the tile index for the cell given by a Vector2i.
</description> </description>
</method> </method>
<method name="update_dirty_quadrants"> <method name="update_dirty_quadrants">
@ -137,6 +139,7 @@
<signals> <signals>
<signal name="changed"> <signal name="changed">
<description> <description>
Emitted when the [TileSet] of this TileMap changes.
</description> </description>
</signal> </signal>
</signals> </signals>

View File

@ -298,12 +298,15 @@
</members> </members>
<constants> <constants>
<constant name="TILE_SHAPE_SQUARE" value="0" enum="TileShape"> <constant name="TILE_SHAPE_SQUARE" value="0" enum="TileShape">
Orthogonal orientation mode.
</constant> </constant>
<constant name="TILE_SHAPE_ISOMETRIC" value="1" enum="TileShape"> <constant name="TILE_SHAPE_ISOMETRIC" value="1" enum="TileShape">
Isometric orientation mode.
</constant> </constant>
<constant name="TILE_SHAPE_HALF_OFFSET_SQUARE" value="2" enum="TileShape"> <constant name="TILE_SHAPE_HALF_OFFSET_SQUARE" value="2" enum="TileShape">
</constant> </constant>
<constant name="TILE_SHAPE_HEXAGON" value="3" enum="TileShape"> <constant name="TILE_SHAPE_HEXAGON" value="3" enum="TileShape">
Hexagon orientation mode.
</constant> </constant>
<constant name="TILE_LAYOUT_STACKED" value="0" enum="TileLayout"> <constant name="TILE_LAYOUT_STACKED" value="0" enum="TileLayout">
</constant> </constant>

View File

@ -902,7 +902,7 @@ void TileMap::_get_property_list(List<PropertyInfo> *p_list) const {
p_list->push_back(p); p_list->push_back(p);
} }
Vector2 TileMap::map_to_world(const Vector2 &p_pos) const { Vector2 TileMap::map_to_world(const Vector2i &p_pos) const {
// SHOULD RETURN THE CENTER OF THE TILE // SHOULD RETURN THE CENTER OF THE TILE
ERR_FAIL_COND_V(!tile_set.is_valid(), Vector2()); ERR_FAIL_COND_V(!tile_set.is_valid(), Vector2());
@ -980,7 +980,7 @@ Vector2 TileMap::map_to_world(const Vector2 &p_pos) const {
} }
Vector2i TileMap::world_to_map(const Vector2 &p_pos) const { Vector2i TileMap::world_to_map(const Vector2 &p_pos) const {
ERR_FAIL_COND_V(!tile_set.is_valid(), Vector2()); ERR_FAIL_COND_V(!tile_set.is_valid(), Vector2i());
Vector2 ret = p_pos; Vector2 ret = p_pos;
ret /= tile_set->get_tile_size(); ret /= tile_set->get_tile_size();
@ -1143,7 +1143,7 @@ Vector2i TileMap::world_to_map(const Vector2 &p_pos) const {
} else { } else {
ret = (ret + Vector2(0.00005, 0.00005)).floor(); ret = (ret + Vector2(0.00005, 0.00005)).floor();
} }
return ret; return Vector2i(ret);
} }
bool TileMap::is_existing_neighbor(TileSet::CellNeighbor p_cell_neighbor) const { bool TileMap::is_existing_neighbor(TileSet::CellNeighbor p_cell_neighbor) const {

View File

@ -264,7 +264,7 @@ public:
void update_dirty_quadrants(); void update_dirty_quadrants();
Vector2 map_to_world(const Vector2 &p_pos) const; Vector2 map_to_world(const Vector2i &p_pos) const;
Vector2i world_to_map(const Vector2 &p_pos) const; Vector2i world_to_map(const Vector2 &p_pos) const;
bool is_existing_neighbor(TileSet::CellNeighbor p_cell_neighbor) const; bool is_existing_neighbor(TileSet::CellNeighbor p_cell_neighbor) const;