tile_set.h 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020
  1. /**************************************************************************/
  2. /* tile_set.h */
  3. /**************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* https://godotengine.org */
  7. /**************************************************************************/
  8. /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
  9. /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
  10. /* */
  11. /* Permission is hereby granted, free of charge, to any person obtaining */
  12. /* a copy of this software and associated documentation files (the */
  13. /* "Software"), to deal in the Software without restriction, including */
  14. /* without limitation the rights to use, copy, modify, merge, publish, */
  15. /* distribute, sublicense, and/or sell copies of the Software, and to */
  16. /* permit persons to whom the Software is furnished to do so, subject to */
  17. /* the following conditions: */
  18. /* */
  19. /* The above copyright notice and this permission notice shall be */
  20. /* included in all copies or substantial portions of the Software. */
  21. /* */
  22. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  23. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  24. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
  25. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  26. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  27. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  28. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  29. /**************************************************************************/
  30. #ifndef TILE_SET_H
  31. #define TILE_SET_H
  32. #include "core/io/resource.h"
  33. #include "core/object/object.h"
  34. #include "core/templates/local_vector.h"
  35. #include "core/templates/rb_set.h"
  36. #include "scene/2d/light_occluder_2d.h"
  37. #include "scene/main/canvas_item.h"
  38. #include "scene/resources/2d/convex_polygon_shape_2d.h"
  39. #include "scene/resources/2d/navigation_polygon.h"
  40. #include "scene/resources/image_texture.h"
  41. #include "scene/resources/packed_scene.h"
  42. #include "scene/resources/physics_material.h"
  43. #ifndef DISABLE_DEPRECATED
  44. #include "scene/resources/shader.h"
  45. #endif
  46. class TileMap;
  47. class TileSetSource;
  48. class TileSetAtlasSource;
  49. class TileData;
  50. // Forward-declare the plugins.
  51. class TileSetPlugin;
  52. class TileSetPluginAtlasRendering;
  53. class TileSetPluginAtlasPhysics;
  54. class TileSetPluginAtlasNavigation;
  55. union TileMapCell {
  56. struct {
  57. int16_t source_id;
  58. int16_t coord_x;
  59. int16_t coord_y;
  60. int16_t alternative_tile;
  61. };
  62. uint64_t _u64t;
  63. static uint32_t hash(const TileMapCell &p_hash) {
  64. return hash_one_uint64(p_hash._u64t);
  65. }
  66. TileMapCell(int p_source_id = -1, Vector2i p_atlas_coords = Vector2i(-1, -1), int p_alternative_tile = -1) { // default are INVALID_SOURCE, INVALID_ATLAS_COORDS, INVALID_TILE_ALTERNATIVE
  67. source_id = p_source_id;
  68. set_atlas_coords(p_atlas_coords);
  69. alternative_tile = p_alternative_tile;
  70. }
  71. Vector2i get_atlas_coords() const {
  72. return Vector2i(coord_x, coord_y);
  73. }
  74. void set_atlas_coords(const Vector2i &r_coords) {
  75. coord_x = r_coords.x;
  76. coord_y = r_coords.y;
  77. }
  78. bool operator<(const TileMapCell &p_other) const {
  79. if (source_id == p_other.source_id) {
  80. if (coord_x == p_other.coord_x) {
  81. if (coord_y == p_other.coord_y) {
  82. return alternative_tile < p_other.alternative_tile;
  83. } else {
  84. return coord_y < p_other.coord_y;
  85. }
  86. } else {
  87. return coord_x < p_other.coord_x;
  88. }
  89. } else {
  90. return source_id < p_other.source_id;
  91. }
  92. }
  93. bool operator!=(const TileMapCell &p_other) const {
  94. return !(source_id == p_other.source_id && coord_x == p_other.coord_x && coord_y == p_other.coord_y && alternative_tile == p_other.alternative_tile);
  95. }
  96. bool operator==(const TileMapCell &p_other) const {
  97. return source_id == p_other.source_id && coord_x == p_other.coord_x && coord_y == p_other.coord_y && alternative_tile == p_other.alternative_tile;
  98. }
  99. };
  100. class TileMapPattern : public Resource {
  101. GDCLASS(TileMapPattern, Resource);
  102. Size2i size;
  103. HashMap<Vector2i, TileMapCell> pattern;
  104. void _set_tile_data(const Vector<int> &p_data);
  105. Vector<int> _get_tile_data() const;
  106. protected:
  107. bool _set(const StringName &p_name, const Variant &p_value);
  108. bool _get(const StringName &p_name, Variant &r_ret) const;
  109. void _get_property_list(List<PropertyInfo> *p_list) const;
  110. static void _bind_methods();
  111. public:
  112. void set_cell(const Vector2i &p_coords, int p_source_id, const Vector2i p_atlas_coords, int p_alternative_tile = 0);
  113. bool has_cell(const Vector2i &p_coords) const;
  114. void remove_cell(const Vector2i &p_coords, bool p_update_size = true);
  115. int get_cell_source_id(const Vector2i &p_coords) const;
  116. Vector2i get_cell_atlas_coords(const Vector2i &p_coords) const;
  117. int get_cell_alternative_tile(const Vector2i &p_coords) const;
  118. const HashMap<Vector2i, TileMapCell> &get_pattern() const { return pattern; }
  119. TypedArray<Vector2i> get_used_cells() const;
  120. Size2i get_size() const;
  121. void set_size(const Size2i &p_size);
  122. bool is_empty() const;
  123. void clear();
  124. };
  125. class TileSet : public Resource {
  126. GDCLASS(TileSet, Resource);
  127. #ifndef DISABLE_DEPRECATED
  128. private:
  129. struct CompatibilityShapeData {
  130. Vector2i autotile_coords;
  131. bool one_way;
  132. float one_way_margin;
  133. Ref<Shape2D> shape;
  134. Transform2D transform;
  135. };
  136. struct CompatibilityTileData {
  137. String name;
  138. Ref<Texture2D> texture;
  139. Vector2 tex_offset;
  140. Ref<Material> material;
  141. Rect2 region;
  142. int tile_mode = 0;
  143. Color modulate = Color(1, 1, 1);
  144. // Atlas or autotiles data
  145. int autotile_bitmask_mode = 0;
  146. Vector2 autotile_icon_coordinate;
  147. Size2i autotile_tile_size = Size2i(16, 16);
  148. int autotile_spacing = 0;
  149. HashMap<Vector2i, int> autotile_bitmask_flags;
  150. HashMap<Vector2i, Ref<OccluderPolygon2D>> autotile_occluder_map;
  151. HashMap<Vector2i, Ref<NavigationPolygon>> autotile_navpoly_map;
  152. HashMap<Vector2i, int> autotile_priority_map;
  153. HashMap<Vector2i, int> autotile_z_index_map;
  154. Vector<CompatibilityShapeData> shapes;
  155. Ref<OccluderPolygon2D> occluder;
  156. Vector2 occluder_offset;
  157. Ref<NavigationPolygon> navigation;
  158. Vector2 navigation_offset;
  159. int z_index = 0;
  160. };
  161. enum CompatibilityTileMode {
  162. COMPATIBILITY_TILE_MODE_SINGLE_TILE = 0,
  163. COMPATIBILITY_TILE_MODE_AUTO_TILE,
  164. COMPATIBILITY_TILE_MODE_ATLAS_TILE,
  165. };
  166. HashMap<int, CompatibilityTileData *> compatibility_data;
  167. HashMap<int, int> compatibility_tilemap_mapping_tile_modes;
  168. HashMap<int, RBMap<Array, Array>> compatibility_tilemap_mapping;
  169. HashMap<Vector2i, int> compatibility_size_count;
  170. void _compatibility_conversion();
  171. public:
  172. // Format of output array [source_id, atlas_coords, alternative]
  173. Array compatibility_tilemap_map(int p_tile_id, Vector2i p_coords, bool p_flip_h, bool p_flip_v, bool p_transpose);
  174. #endif // DISABLE_DEPRECATED
  175. public:
  176. static const int INVALID_SOURCE; // -1;
  177. enum CellNeighbor {
  178. CELL_NEIGHBOR_RIGHT_SIDE = 0,
  179. CELL_NEIGHBOR_RIGHT_CORNER,
  180. CELL_NEIGHBOR_BOTTOM_RIGHT_SIDE,
  181. CELL_NEIGHBOR_BOTTOM_RIGHT_CORNER,
  182. CELL_NEIGHBOR_BOTTOM_SIDE,
  183. CELL_NEIGHBOR_BOTTOM_CORNER,
  184. CELL_NEIGHBOR_BOTTOM_LEFT_SIDE,
  185. CELL_NEIGHBOR_BOTTOM_LEFT_CORNER,
  186. CELL_NEIGHBOR_LEFT_SIDE,
  187. CELL_NEIGHBOR_LEFT_CORNER,
  188. CELL_NEIGHBOR_TOP_LEFT_SIDE,
  189. CELL_NEIGHBOR_TOP_LEFT_CORNER,
  190. CELL_NEIGHBOR_TOP_SIDE,
  191. CELL_NEIGHBOR_TOP_CORNER,
  192. CELL_NEIGHBOR_TOP_RIGHT_SIDE,
  193. CELL_NEIGHBOR_TOP_RIGHT_CORNER,
  194. CELL_NEIGHBOR_MAX,
  195. };
  196. static const char *CELL_NEIGHBOR_ENUM_TO_TEXT[];
  197. enum TerrainMode {
  198. TERRAIN_MODE_MATCH_CORNERS_AND_SIDES = 0,
  199. TERRAIN_MODE_MATCH_CORNERS,
  200. TERRAIN_MODE_MATCH_SIDES,
  201. };
  202. enum TileShape {
  203. TILE_SHAPE_SQUARE,
  204. TILE_SHAPE_ISOMETRIC,
  205. TILE_SHAPE_HALF_OFFSET_SQUARE,
  206. TILE_SHAPE_HEXAGON,
  207. };
  208. enum TileLayout {
  209. TILE_LAYOUT_STACKED,
  210. TILE_LAYOUT_STACKED_OFFSET,
  211. TILE_LAYOUT_STAIRS_RIGHT,
  212. TILE_LAYOUT_STAIRS_DOWN,
  213. TILE_LAYOUT_DIAMOND_RIGHT,
  214. TILE_LAYOUT_DIAMOND_DOWN,
  215. };
  216. enum TileOffsetAxis {
  217. TILE_OFFSET_AXIS_HORIZONTAL,
  218. TILE_OFFSET_AXIS_VERTICAL,
  219. };
  220. struct PackedSceneSource {
  221. Ref<PackedScene> scene;
  222. Vector2 offset;
  223. };
  224. class TerrainsPattern {
  225. bool valid = false;
  226. int terrain = -1;
  227. int bits[TileSet::CELL_NEIGHBOR_MAX] = {};
  228. bool is_valid_bit[TileSet::CELL_NEIGHBOR_MAX] = {};
  229. int not_empty_terrains_count = 0;
  230. public:
  231. bool is_valid() const;
  232. bool is_erase_pattern() const;
  233. bool operator<(const TerrainsPattern &p_terrains_pattern) const;
  234. bool operator==(const TerrainsPattern &p_terrains_pattern) const;
  235. bool operator!=(const TerrainsPattern &p_terrains_pattern) const {
  236. return !operator==(p_terrains_pattern);
  237. }
  238. void set_terrain(int p_terrain);
  239. int get_terrain() const;
  240. void set_terrain_peering_bit(TileSet::CellNeighbor p_peering_bit, int p_terrain);
  241. int get_terrain_peering_bit(TileSet::CellNeighbor p_peering_bit) const;
  242. void from_array(Array p_terrains);
  243. Array as_array() const;
  244. TerrainsPattern(const TileSet *p_tile_set, int p_terrain_set);
  245. TerrainsPattern() {}
  246. };
  247. protected:
  248. bool _set(const StringName &p_name, const Variant &p_value);
  249. bool _get(const StringName &p_name, Variant &r_ret) const;
  250. void _get_property_list(List<PropertyInfo> *p_list) const;
  251. void _validate_property(PropertyInfo &p_property) const;
  252. #ifdef TOOLS_ENABLED
  253. virtual uint32_t hash_edited_version_for_preview() const override { return 0; } // Not using preview, so disable it for performance.
  254. #endif
  255. private:
  256. // --- TileSet data ---
  257. // Basic shape and layout.
  258. TileShape tile_shape = TILE_SHAPE_SQUARE;
  259. TileLayout tile_layout = TILE_LAYOUT_STACKED;
  260. TileOffsetAxis tile_offset_axis = TILE_OFFSET_AXIS_HORIZONTAL;
  261. Size2i tile_size = Size2i(16, 16); //Size2(64, 64);
  262. // Rendering.
  263. bool uv_clipping = false;
  264. struct OcclusionLayer {
  265. uint32_t light_mask = 1;
  266. bool sdf_collision = false;
  267. };
  268. Vector<OcclusionLayer> occlusion_layers;
  269. Ref<ArrayMesh> tile_lines_mesh;
  270. Ref<ArrayMesh> tile_filled_mesh;
  271. mutable bool tile_meshes_dirty = true;
  272. // Physics
  273. struct PhysicsLayer {
  274. uint32_t collision_layer = 1;
  275. uint32_t collision_mask = 1;
  276. real_t collision_priority = 1.0;
  277. Ref<PhysicsMaterial> physics_material;
  278. };
  279. Vector<PhysicsLayer> physics_layers;
  280. // Terrains
  281. struct Terrain {
  282. String name;
  283. Color color;
  284. };
  285. struct TerrainSet {
  286. TerrainMode mode = TERRAIN_MODE_MATCH_CORNERS_AND_SIDES;
  287. Vector<Terrain> terrains;
  288. };
  289. Vector<TerrainSet> terrain_sets;
  290. HashMap<TerrainMode, Ref<ArrayMesh>> terrain_meshes;
  291. HashMap<TerrainMode, HashMap<CellNeighbor, Ref<ArrayMesh>>> terrain_peering_bits_meshes;
  292. bool terrain_bits_meshes_dirty = true;
  293. LocalVector<RBMap<TileSet::TerrainsPattern, RBSet<TileMapCell>>> per_terrain_pattern_tiles; // Cached data.
  294. bool terrains_cache_dirty = true;
  295. void _update_terrains_cache();
  296. // Navigation
  297. struct NavigationLayer {
  298. uint32_t layers = 1;
  299. };
  300. Vector<NavigationLayer> navigation_layers;
  301. // CustomData
  302. struct CustomDataLayer {
  303. String name;
  304. Variant::Type type = Variant::NIL;
  305. };
  306. Vector<CustomDataLayer> custom_data_layers;
  307. HashMap<String, int> custom_data_layers_by_name;
  308. // Per Atlas source data.
  309. HashMap<int, Ref<TileSetSource>> sources;
  310. Vector<int> source_ids;
  311. int next_source_id = 0;
  312. // ---------------------
  313. LocalVector<Ref<TileMapPattern>> patterns;
  314. void _compute_next_source_id();
  315. void _source_changed();
  316. // Tile proxies
  317. RBMap<int, int> source_level_proxies;
  318. RBMap<Array, Array> coords_level_proxies;
  319. RBMap<Array, Array> alternative_level_proxies;
  320. // Helpers
  321. Vector<Point2> _get_square_terrain_polygon(Vector2i p_size);
  322. Vector<Point2> _get_square_corner_or_side_terrain_peering_bit_polygon(Vector2i p_size, TileSet::CellNeighbor p_bit);
  323. Vector<Point2> _get_square_corner_terrain_peering_bit_polygon(Vector2i p_size, TileSet::CellNeighbor p_bit);
  324. Vector<Point2> _get_square_side_terrain_peering_bit_polygon(Vector2i p_size, TileSet::CellNeighbor p_bit);
  325. Vector<Point2> _get_isometric_terrain_polygon(Vector2i p_size);
  326. Vector<Point2> _get_isometric_corner_or_side_terrain_peering_bit_polygon(Vector2i p_size, TileSet::CellNeighbor p_bit);
  327. Vector<Point2> _get_isometric_corner_terrain_peering_bit_polygon(Vector2i p_size, TileSet::CellNeighbor p_bit);
  328. Vector<Point2> _get_isometric_side_terrain_peering_bit_polygon(Vector2i p_size, TileSet::CellNeighbor p_bit);
  329. Vector<Point2> _get_half_offset_terrain_polygon(Vector2i p_size, float p_overlap, TileSet::TileOffsetAxis p_offset_axis);
  330. Vector<Point2> _get_half_offset_corner_or_side_terrain_peering_bit_polygon(Vector2i p_size, float p_overlap, TileSet::TileOffsetAxis p_offset_axis, TileSet::CellNeighbor p_bit);
  331. Vector<Point2> _get_half_offset_corner_terrain_peering_bit_polygon(Vector2i p_size, float p_overlap, TileSet::TileOffsetAxis p_offset_axis, TileSet::CellNeighbor p_bit);
  332. Vector<Point2> _get_half_offset_side_terrain_peering_bit_polygon(Vector2i p_size, float p_overlap, TileSet::TileOffsetAxis p_offset_axis, TileSet::CellNeighbor p_bit);
  333. protected:
  334. static void _bind_methods();
  335. public:
  336. // --- Plugins ---
  337. Vector<TileSetPlugin *> get_tile_set_atlas_plugins() const;
  338. // --- Accessors for TileSet data ---
  339. // -- Shape and layout --
  340. void set_tile_shape(TileShape p_shape);
  341. TileShape get_tile_shape() const;
  342. void set_tile_layout(TileLayout p_layout);
  343. TileLayout get_tile_layout() const;
  344. void set_tile_offset_axis(TileOffsetAxis p_alignment);
  345. TileOffsetAxis get_tile_offset_axis() const;
  346. void set_tile_size(Size2i p_size);
  347. Size2i get_tile_size() const;
  348. // -- Sources management --
  349. int get_next_source_id() const;
  350. int get_source_count() const;
  351. int get_source_id(int p_index) const;
  352. int add_source(Ref<TileSetSource> p_tile_set_source, int p_source_id_override = -1);
  353. void set_source_id(int p_source_id, int p_new_id);
  354. void remove_source(int p_source_id);
  355. void remove_source_ptr(TileSetSource *p_tile_set_source); // Not exposed
  356. bool has_source(int p_source_id) const;
  357. Ref<TileSetSource> get_source(int p_source_id) const;
  358. // Rendering
  359. void set_uv_clipping(bool p_uv_clipping);
  360. bool is_uv_clipping() const;
  361. int get_occlusion_layers_count() const;
  362. void add_occlusion_layer(int p_index = -1);
  363. void move_occlusion_layer(int p_from_index, int p_to_pos);
  364. void remove_occlusion_layer(int p_index);
  365. void set_occlusion_layer_light_mask(int p_layer_index, int p_light_mask);
  366. int get_occlusion_layer_light_mask(int p_layer_index) const;
  367. void set_occlusion_layer_sdf_collision(int p_layer_index, bool p_sdf_collision);
  368. bool get_occlusion_layer_sdf_collision(int p_layer_index) const;
  369. // Physics
  370. int get_physics_layers_count() const;
  371. void add_physics_layer(int p_index = -1);
  372. void move_physics_layer(int p_from_index, int p_to_pos);
  373. void remove_physics_layer(int p_index);
  374. void set_physics_layer_collision_layer(int p_layer_index, uint32_t p_layer);
  375. uint32_t get_physics_layer_collision_layer(int p_layer_index) const;
  376. void set_physics_layer_collision_mask(int p_layer_index, uint32_t p_mask);
  377. uint32_t get_physics_layer_collision_mask(int p_layer_index) const;
  378. void set_physics_layer_collision_priority(int p_layer_index, real_t p_priority);
  379. real_t get_physics_layer_collision_priority(int p_layer_index) const;
  380. void set_physics_layer_physics_material(int p_layer_index, Ref<PhysicsMaterial> p_physics_material);
  381. Ref<PhysicsMaterial> get_physics_layer_physics_material(int p_layer_index) const;
  382. // Terrain sets
  383. int get_terrain_sets_count() const;
  384. void add_terrain_set(int p_index = -1);
  385. void move_terrain_set(int p_from_index, int p_to_pos);
  386. void remove_terrain_set(int p_index);
  387. void set_terrain_set_mode(int p_terrain_set, TerrainMode p_terrain_mode);
  388. TerrainMode get_terrain_set_mode(int p_terrain_set) const;
  389. // Terrains
  390. int get_terrains_count(int p_terrain_set) const;
  391. void add_terrain(int p_terrain_set, int p_index = -1);
  392. void move_terrain(int p_terrain_set, int p_from_index, int p_to_pos);
  393. void remove_terrain(int p_terrain_set, int p_index);
  394. void set_terrain_name(int p_terrain_set, int p_terrain_index, String p_name);
  395. String get_terrain_name(int p_terrain_set, int p_terrain_index) const;
  396. void set_terrain_color(int p_terrain_set, int p_terrain_index, Color p_color);
  397. Color get_terrain_color(int p_terrain_set, int p_terrain_index) const;
  398. bool is_valid_terrain_peering_bit_for_mode(TileSet::TerrainMode p_terrain_mode, TileSet::CellNeighbor p_peering_bit) const;
  399. bool is_valid_terrain_peering_bit(int p_terrain_set, TileSet::CellNeighbor p_peering_bit) const;
  400. // Navigation
  401. int get_navigation_layers_count() const;
  402. void add_navigation_layer(int p_index = -1);
  403. void move_navigation_layer(int p_from_index, int p_to_pos);
  404. void remove_navigation_layer(int p_index);
  405. void set_navigation_layer_layers(int p_layer_index, uint32_t p_layers);
  406. uint32_t get_navigation_layer_layers(int p_layer_index) const;
  407. void set_navigation_layer_layer_value(int p_layer_index, int p_layer_number, bool p_value);
  408. bool get_navigation_layer_layer_value(int p_layer_index, int p_layer_number) const;
  409. // Custom data
  410. int get_custom_data_layers_count() const;
  411. void add_custom_data_layer(int p_index = -1);
  412. void move_custom_data_layer(int p_from_index, int p_to_pos);
  413. void remove_custom_data_layer(int p_index);
  414. int get_custom_data_layer_by_name(String p_value) const;
  415. void set_custom_data_layer_name(int p_layer_id, String p_value);
  416. bool has_custom_data_layer_by_name(const String &p_value) const;
  417. String get_custom_data_layer_name(int p_layer_id) const;
  418. void set_custom_data_layer_type(int p_layer_id, Variant::Type p_value);
  419. Variant::Type get_custom_data_layer_type(int p_layer_id) const;
  420. // Tiles proxies.
  421. void set_source_level_tile_proxy(int p_source_from, int p_source_to);
  422. int get_source_level_tile_proxy(int p_source_from);
  423. bool has_source_level_tile_proxy(int p_source_from);
  424. void remove_source_level_tile_proxy(int p_source_from);
  425. void set_coords_level_tile_proxy(int p_source_from, Vector2i p_coords_from, int p_source_to, Vector2i p_coords_to);
  426. Array get_coords_level_tile_proxy(int p_source_from, Vector2i p_coords_from);
  427. bool has_coords_level_tile_proxy(int p_source_from, Vector2i p_coords_from);
  428. void remove_coords_level_tile_proxy(int p_source_from, Vector2i p_coords_from);
  429. void set_alternative_level_tile_proxy(int p_source_from, Vector2i p_coords_from, int p_alternative_from, int p_source_to, Vector2i p_coords_to, int p_alternative_to);
  430. Array get_alternative_level_tile_proxy(int p_source_from, Vector2i p_coords_from, int p_alternative_from);
  431. bool has_alternative_level_tile_proxy(int p_source_from, Vector2i p_coords_from, int p_alternative_from);
  432. void remove_alternative_level_tile_proxy(int p_source_from, Vector2i p_coords_from, int p_alternative_from);
  433. Array get_source_level_tile_proxies() const;
  434. Array get_coords_level_tile_proxies() const;
  435. Array get_alternative_level_tile_proxies() const;
  436. Array map_tile_proxy(int p_source_from, Vector2i p_coords_from, int p_alternative_from) const;
  437. void cleanup_invalid_tile_proxies();
  438. void clear_tile_proxies();
  439. // Patterns.
  440. int add_pattern(Ref<TileMapPattern> p_pattern, int p_index = -1);
  441. Ref<TileMapPattern> get_pattern(int p_index);
  442. void remove_pattern(int p_index);
  443. int get_patterns_count();
  444. // Terrains.
  445. RBSet<TerrainsPattern> get_terrains_pattern_set(int p_terrain_set);
  446. RBSet<TileMapCell> get_tiles_for_terrains_pattern(int p_terrain_set, TerrainsPattern p_terrain_tile_pattern);
  447. TileMapCell get_random_tile_from_terrains_pattern(int p_terrain_set, TerrainsPattern p_terrain_tile_pattern);
  448. // Helpers
  449. Vector<Vector2> get_tile_shape_polygon() const;
  450. void draw_tile_shape(CanvasItem *p_canvas_item, Transform2D p_transform, Color p_color, bool p_filled = false, Ref<Texture2D> p_texture = Ref<Texture2D>()) const;
  451. // Used by TileMap/TileMapLayer
  452. Vector2 map_to_local(const Vector2i &p_pos) const;
  453. Vector2i local_to_map(const Vector2 &p_pos) const;
  454. bool is_existing_neighbor(TileSet::CellNeighbor p_cell_neighbor) const;
  455. Vector2i get_neighbor_cell(const Vector2i &p_coords, TileSet::CellNeighbor p_cell_neighbor) const;
  456. TypedArray<Vector2i> get_surrounding_cells(const Vector2i &p_coords) const;
  457. Vector2i map_pattern(const Vector2i &p_position_in_tilemap, const Vector2i &p_coords_in_pattern, Ref<TileMapPattern> p_pattern) const;
  458. void draw_cells_outline(CanvasItem *p_canvas_item, const RBSet<Vector2i> &p_cells, Color p_color, Transform2D p_transform = Transform2D()) const;
  459. Vector<Point2> get_terrain_polygon(int p_terrain_set);
  460. Vector<Point2> get_terrain_peering_bit_polygon(int p_terrain_set, TileSet::CellNeighbor p_bit);
  461. void draw_terrains(CanvasItem *p_canvas_item, Transform2D p_transform, const TileData *p_tile_data);
  462. Vector<Vector<Ref<Texture2D>>> generate_terrains_icons(Size2i p_size);
  463. // Resource management
  464. virtual void reset_state() override;
  465. // Helpers.
  466. static Vector2i transform_coords_layout(const Vector2i &p_coords, TileSet::TileOffsetAxis p_offset_axis, TileSet::TileLayout p_from_layout, TileSet::TileLayout p_to_layout);
  467. TileSet();
  468. ~TileSet();
  469. };
  470. class TileSetSource : public Resource {
  471. GDCLASS(TileSetSource, Resource);
  472. protected:
  473. const TileSet *tile_set = nullptr;
  474. static void _bind_methods();
  475. public:
  476. static const Vector2i INVALID_ATLAS_COORDS; // Vector2i(-1, -1);
  477. static const int INVALID_TILE_ALTERNATIVE; // -1;
  478. // Not exposed.
  479. virtual void set_tile_set(const TileSet *p_tile_set);
  480. TileSet *get_tile_set() const;
  481. virtual void notify_tile_data_properties_should_change() {}
  482. virtual void add_occlusion_layer(int p_index) {}
  483. virtual void move_occlusion_layer(int p_from_index, int p_to_pos) {}
  484. virtual void remove_occlusion_layer(int p_index) {}
  485. virtual void add_physics_layer(int p_index) {}
  486. virtual void move_physics_layer(int p_from_index, int p_to_pos) {}
  487. virtual void remove_physics_layer(int p_index) {}
  488. virtual void add_terrain_set(int p_index) {}
  489. virtual void move_terrain_set(int p_from_index, int p_to_pos) {}
  490. virtual void remove_terrain_set(int p_index) {}
  491. virtual void add_terrain(int p_terrain_set, int p_index) {}
  492. virtual void move_terrain(int p_terrain_set, int p_from_index, int p_to_pos) {}
  493. virtual void remove_terrain(int p_terrain_set, int p_index) {}
  494. virtual void add_navigation_layer(int p_index) {}
  495. virtual void move_navigation_layer(int p_from_index, int p_to_pos) {}
  496. virtual void remove_navigation_layer(int p_index) {}
  497. virtual void add_custom_data_layer(int p_index) {}
  498. virtual void move_custom_data_layer(int p_from_index, int p_to_pos) {}
  499. virtual void remove_custom_data_layer(int p_index) {}
  500. virtual void reset_state() override;
  501. // Tiles.
  502. virtual int get_tiles_count() const = 0;
  503. virtual Vector2i get_tile_id(int tile_index) const = 0;
  504. virtual bool has_tile(Vector2i p_atlas_coords) const = 0;
  505. // Alternative tiles.
  506. virtual int get_alternative_tiles_count(const Vector2i p_atlas_coords) const = 0;
  507. virtual int get_alternative_tile_id(const Vector2i p_atlas_coords, int p_index) const = 0;
  508. virtual bool has_alternative_tile(const Vector2i p_atlas_coords, int p_alternative_tile) const = 0;
  509. };
  510. class TileSetAtlasSource : public TileSetSource {
  511. GDCLASS(TileSetAtlasSource, TileSetSource);
  512. public:
  513. enum TileAnimationMode {
  514. TILE_ANIMATION_MODE_DEFAULT,
  515. TILE_ANIMATION_MODE_RANDOM_START_TIMES,
  516. TILE_ANIMATION_MODE_MAX,
  517. };
  518. enum TransformBits {
  519. TRANSFORM_FLIP_H = 1 << 12,
  520. TRANSFORM_FLIP_V = 1 << 13,
  521. TRANSFORM_TRANSPOSE = 1 << 14,
  522. };
  523. static const int16_t UNTRANSFORM_MASK = ~(TileSetAtlasSource::TRANSFORM_FLIP_H + TileSetAtlasSource::TRANSFORM_FLIP_V + TileSetAtlasSource::TRANSFORM_TRANSPOSE);
  524. private:
  525. struct TileAlternativesData {
  526. Vector2i size_in_atlas = Vector2i(1, 1);
  527. Vector2i texture_offset;
  528. // Animation
  529. int animation_columns = 0;
  530. Vector2i animation_separation;
  531. real_t animation_speed = 1.0;
  532. TileSetAtlasSource::TileAnimationMode animation_mode = TILE_ANIMATION_MODE_DEFAULT;
  533. LocalVector<real_t> animation_frames_durations;
  534. // Alternatives
  535. HashMap<int, TileData *> alternatives;
  536. Vector<int> alternatives_ids;
  537. int next_alternative_id = 1;
  538. };
  539. bool initializing = true;
  540. Ref<Texture2D> texture;
  541. Vector2i margins;
  542. Vector2i separation;
  543. Size2i texture_region_size = Size2i(16, 16);
  544. HashMap<Vector2i, TileAlternativesData> tiles;
  545. Vector<Vector2i> tiles_ids;
  546. HashMap<Vector2i, Vector2i> _coords_mapping_cache; // Maps any coordinate to the including tile
  547. TileData *_get_atlas_tile_data(Vector2i p_atlas_coords, int p_alternative_tile);
  548. const TileData *_get_atlas_tile_data(Vector2i p_atlas_coords, int p_alternative_tile) const;
  549. void _compute_next_alternative_id(const Vector2i p_atlas_coords);
  550. void _clear_coords_mapping_cache(Vector2i p_atlas_coords);
  551. void _create_coords_mapping_cache(Vector2i p_atlas_coords);
  552. bool use_texture_padding = true;
  553. Ref<CanvasTexture> padded_texture;
  554. bool padded_texture_needs_update = false;
  555. void _queue_update_padded_texture();
  556. Ref<ImageTexture> _create_padded_image_texture(const Ref<Texture2D> &p_source);
  557. void _update_padded_texture();
  558. void _try_emit_changed();
  559. protected:
  560. bool _set(const StringName &p_name, const Variant &p_value);
  561. bool _get(const StringName &p_name, Variant &r_ret) const;
  562. void _get_property_list(List<PropertyInfo> *p_list) const;
  563. void _notification(int p_notification);
  564. static void _bind_methods();
  565. public:
  566. // Not exposed.
  567. virtual void set_tile_set(const TileSet *p_tile_set) override;
  568. const TileSet *get_tile_set() const;
  569. virtual void notify_tile_data_properties_should_change() override;
  570. virtual void add_occlusion_layer(int p_index) override;
  571. virtual void move_occlusion_layer(int p_from_index, int p_to_pos) override;
  572. virtual void remove_occlusion_layer(int p_index) override;
  573. virtual void add_physics_layer(int p_index) override;
  574. virtual void move_physics_layer(int p_from_index, int p_to_pos) override;
  575. virtual void remove_physics_layer(int p_index) override;
  576. virtual void add_terrain_set(int p_index) override;
  577. virtual void move_terrain_set(int p_from_index, int p_to_pos) override;
  578. virtual void remove_terrain_set(int p_index) override;
  579. virtual void add_terrain(int p_terrain_set, int p_index) override;
  580. virtual void move_terrain(int p_terrain_set, int p_from_index, int p_to_pos) override;
  581. virtual void remove_terrain(int p_terrain_set, int p_index) override;
  582. virtual void add_navigation_layer(int p_index) override;
  583. virtual void move_navigation_layer(int p_from_index, int p_to_pos) override;
  584. virtual void remove_navigation_layer(int p_index) override;
  585. virtual void add_custom_data_layer(int p_index) override;
  586. virtual void move_custom_data_layer(int p_from_index, int p_to_pos) override;
  587. virtual void remove_custom_data_layer(int p_index) override;
  588. virtual void reset_state() override;
  589. // Base properties.
  590. void set_texture(Ref<Texture2D> p_texture);
  591. Ref<Texture2D> get_texture() const;
  592. void set_margins(Vector2i p_margins);
  593. Vector2i get_margins() const;
  594. void set_separation(Vector2i p_separation);
  595. Vector2i get_separation() const;
  596. void set_texture_region_size(Vector2i p_tile_size);
  597. Vector2i get_texture_region_size() const;
  598. // Padding.
  599. void set_use_texture_padding(bool p_use_padding);
  600. bool get_use_texture_padding() const;
  601. // Base tiles.
  602. void create_tile(const Vector2i p_atlas_coords, const Vector2i p_size = Vector2i(1, 1));
  603. void remove_tile(Vector2i p_atlas_coords);
  604. virtual bool has_tile(Vector2i p_atlas_coords) const override;
  605. void move_tile_in_atlas(Vector2i p_atlas_coords, Vector2i p_new_atlas_coords = INVALID_ATLAS_COORDS, Vector2i p_new_size = Vector2i(-1, -1));
  606. Vector2i get_tile_size_in_atlas(Vector2i p_atlas_coords) const;
  607. virtual int get_tiles_count() const override;
  608. virtual Vector2i get_tile_id(int p_index) const override;
  609. bool has_room_for_tile(Vector2i p_atlas_coords, Vector2i p_size, int p_animation_columns, Vector2i p_animation_separation, int p_frames_count, Vector2i p_ignored_tile = INVALID_ATLAS_COORDS) const;
  610. PackedVector2Array get_tiles_to_be_removed_on_change(Ref<Texture2D> p_texture, Vector2i p_margins, Vector2i p_separation, Vector2i p_texture_region_size);
  611. Vector2i get_tile_at_coords(Vector2i p_atlas_coords) const;
  612. bool has_tiles_outside_texture() const;
  613. Vector<Vector2i> get_tiles_outside_texture() const;
  614. void clear_tiles_outside_texture();
  615. // Animation.
  616. void set_tile_animation_columns(const Vector2i p_atlas_coords, int p_frame_columns);
  617. int get_tile_animation_columns(const Vector2i p_atlas_coords) const;
  618. void set_tile_animation_separation(const Vector2i p_atlas_coords, const Vector2i p_separation);
  619. Vector2i get_tile_animation_separation(const Vector2i p_atlas_coords) const;
  620. void set_tile_animation_speed(const Vector2i p_atlas_coords, real_t p_speed);
  621. real_t get_tile_animation_speed(const Vector2i p_atlas_coords) const;
  622. void set_tile_animation_mode(const Vector2i p_atlas_coords, const TileSetAtlasSource::TileAnimationMode p_mode);
  623. TileSetAtlasSource::TileAnimationMode get_tile_animation_mode(const Vector2i p_atlas_coords) const;
  624. void set_tile_animation_frames_count(const Vector2i p_atlas_coords, int p_frames_count);
  625. int get_tile_animation_frames_count(const Vector2i p_atlas_coords) const;
  626. void set_tile_animation_frame_duration(const Vector2i p_atlas_coords, int p_frame_index, real_t p_duration);
  627. real_t get_tile_animation_frame_duration(const Vector2i p_atlas_coords, int p_frame_index) const;
  628. real_t get_tile_animation_total_duration(const Vector2i p_atlas_coords) const;
  629. // Alternative tiles.
  630. int create_alternative_tile(const Vector2i p_atlas_coords, int p_alternative_id_override = -1);
  631. void remove_alternative_tile(const Vector2i p_atlas_coords, int p_alternative_tile);
  632. void set_alternative_tile_id(const Vector2i p_atlas_coords, int p_alternative_tile, int p_new_id);
  633. virtual bool has_alternative_tile(const Vector2i p_atlas_coords, int p_alternative_tile) const override;
  634. int get_next_alternative_tile_id(const Vector2i p_atlas_coords) const;
  635. virtual int get_alternative_tiles_count(const Vector2i p_atlas_coords) const override;
  636. virtual int get_alternative_tile_id(const Vector2i p_atlas_coords, int p_index) const override;
  637. // Get data associated to a tile.
  638. TileData *get_tile_data(const Vector2i p_atlas_coords, int p_alternative_tile) const;
  639. // Helpers.
  640. Vector2i get_atlas_grid_size() const;
  641. Rect2i get_tile_texture_region(Vector2i p_atlas_coords, int p_frame = 0) const;
  642. bool is_position_in_tile_texture_region(const Vector2i p_atlas_coords, int p_alternative_tile, Vector2 p_position) const;
  643. bool is_rect_in_tile_texture_region(const Vector2i p_atlas_coords, int p_alternative_tile, Rect2 p_rect) const;
  644. static int alternative_no_transform(int p_alternative_id);
  645. // Getters for texture and tile region (padded or not)
  646. Ref<Texture2D> get_runtime_texture() const;
  647. Rect2i get_runtime_tile_texture_region(Vector2i p_atlas_coords, int p_frame = 0) const;
  648. ~TileSetAtlasSource();
  649. };
  650. class TileSetScenesCollectionSource : public TileSetSource {
  651. GDCLASS(TileSetScenesCollectionSource, TileSetSource);
  652. private:
  653. struct SceneData {
  654. Ref<PackedScene> scene;
  655. bool display_placeholder = false;
  656. };
  657. Vector<int> scenes_ids;
  658. HashMap<int, SceneData> scenes;
  659. int next_scene_id = 1;
  660. bool initializing = true;
  661. void _compute_next_alternative_id();
  662. void _try_emit_changed();
  663. protected:
  664. bool _set(const StringName &p_name, const Variant &p_value);
  665. bool _get(const StringName &p_name, Variant &r_ret) const;
  666. void _get_property_list(List<PropertyInfo> *p_list) const;
  667. void _notification(int p_notification);
  668. static void _bind_methods();
  669. public:
  670. // Tiles.
  671. int get_tiles_count() const override;
  672. Vector2i get_tile_id(int p_tile_index) const override;
  673. bool has_tile(Vector2i p_atlas_coords) const override;
  674. // Alternative tiles.
  675. int get_alternative_tiles_count(const Vector2i p_atlas_coords) const override;
  676. int get_alternative_tile_id(const Vector2i p_atlas_coords, int p_index) const override;
  677. bool has_alternative_tile(const Vector2i p_atlas_coords, int p_alternative_tile) const override;
  678. // Scenes accessors. Lot are similar to "Alternative tiles".
  679. int get_scene_tiles_count() { return get_alternative_tiles_count(Vector2i()); }
  680. int get_scene_tile_id(int p_index) { return get_alternative_tile_id(Vector2i(), p_index); }
  681. bool has_scene_tile_id(int p_id) { return has_alternative_tile(Vector2i(), p_id); }
  682. int create_scene_tile(Ref<PackedScene> p_packed_scene = Ref<PackedScene>(), int p_id_override = -1);
  683. void set_scene_tile_id(int p_id, int p_new_id);
  684. void set_scene_tile_scene(int p_id, Ref<PackedScene> p_packed_scene);
  685. Ref<PackedScene> get_scene_tile_scene(int p_id) const;
  686. void set_scene_tile_display_placeholder(int p_id, bool p_packed_scene);
  687. bool get_scene_tile_display_placeholder(int p_id) const;
  688. void remove_scene_tile(int p_id);
  689. int get_next_scene_tile_id() const;
  690. };
  691. class TileData : public Object {
  692. GDCLASS(TileData, Object);
  693. private:
  694. const TileSet *tile_set = nullptr;
  695. bool allow_transform = true;
  696. // Rendering
  697. bool flip_h = false;
  698. bool flip_v = false;
  699. bool transpose = false;
  700. Vector2i texture_origin;
  701. Ref<Material> material;
  702. Color modulate = Color(1.0, 1.0, 1.0, 1.0);
  703. int z_index = 0;
  704. int y_sort_origin = 0;
  705. struct OcclusionLayerTileData {
  706. struct PolygonOccluderTileData {
  707. Ref<OccluderPolygon2D> occluder_polygon;
  708. mutable HashMap<int, Ref<OccluderPolygon2D>> transformed_polygon_occluders;
  709. };
  710. Vector<PolygonOccluderTileData> polygons;
  711. };
  712. Vector<OcclusionLayerTileData> occluders;
  713. // Physics
  714. struct PhysicsLayerTileData {
  715. struct PolygonShapeTileData {
  716. LocalVector<Vector2> polygon;
  717. LocalVector<Ref<ConvexPolygonShape2D>> shapes;
  718. mutable HashMap<int, LocalVector<Ref<ConvexPolygonShape2D>>> transformed_shapes;
  719. bool one_way = false;
  720. float one_way_margin = 1.0;
  721. };
  722. Vector2 linear_velocity;
  723. double angular_velocity = 0.0;
  724. Vector<PolygonShapeTileData> polygons;
  725. };
  726. Vector<PhysicsLayerTileData> physics;
  727. // TODO add support for areas.
  728. // Terrain
  729. int terrain_set = -1;
  730. int terrain = -1;
  731. int terrain_peering_bits[16] = { -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1 };
  732. // Navigation
  733. struct NavigationLayerTileData {
  734. Ref<NavigationPolygon> navigation_polygon;
  735. mutable HashMap<int, Ref<NavigationPolygon>> transformed_navigation_polygon;
  736. };
  737. Vector<NavigationLayerTileData> navigation;
  738. // Misc
  739. double probability = 1.0;
  740. // Custom data
  741. Vector<Variant> custom_data;
  742. protected:
  743. bool _set(const StringName &p_name, const Variant &p_value);
  744. bool _get(const StringName &p_name, Variant &r_ret) const;
  745. void _get_property_list(List<PropertyInfo> *p_list) const;
  746. static void _bind_methods();
  747. #ifndef DISABLE_DEPRECATED
  748. Ref<NavigationPolygon> _get_navigation_polygon_bind_compat_84660(int p_layer_id) const;
  749. Ref<OccluderPolygon2D> _get_occluder_bind_compat_84660(int p_layer_id) const;
  750. static void _bind_compatibility_methods();
  751. #endif
  752. public:
  753. // Not exposed.
  754. void set_tile_set(const TileSet *p_tile_set);
  755. void notify_tile_data_properties_should_change();
  756. void add_occlusion_layer(int p_index);
  757. void move_occlusion_layer(int p_from_index, int p_to_pos);
  758. void remove_occlusion_layer(int p_index);
  759. void add_physics_layer(int p_index);
  760. void move_physics_layer(int p_from_index, int p_to_pos);
  761. void remove_physics_layer(int p_index);
  762. void add_terrain_set(int p_index);
  763. void move_terrain_set(int p_from_index, int p_to_pos);
  764. void remove_terrain_set(int p_index);
  765. void add_terrain(int p_terrain_set, int p_index);
  766. void move_terrain(int p_terrain_set, int p_from_index, int p_to_pos);
  767. void remove_terrain(int p_terrain_set, int p_index);
  768. void add_navigation_layer(int p_index);
  769. void move_navigation_layer(int p_from_index, int p_to_pos);
  770. void remove_navigation_layer(int p_index);
  771. void add_custom_data_layer(int p_index);
  772. void move_custom_data_layer(int p_from_index, int p_to_pos);
  773. void remove_custom_data_layer(int p_index);
  774. void set_allow_transform(bool p_allow_transform);
  775. bool is_allowing_transform() const;
  776. // To duplicate a TileData object, needed for runtiume update.
  777. TileData *duplicate();
  778. // Rendering
  779. void set_flip_h(bool p_flip_h);
  780. bool get_flip_h() const;
  781. void set_flip_v(bool p_flip_v);
  782. bool get_flip_v() const;
  783. void set_transpose(bool p_transpose);
  784. bool get_transpose() const;
  785. void set_texture_origin(Vector2i p_texture_origin);
  786. Vector2i get_texture_origin() const;
  787. void set_material(Ref<Material> p_material);
  788. Ref<Material> get_material() const;
  789. void set_modulate(Color p_modulate);
  790. Color get_modulate() const;
  791. void set_z_index(int p_z_index);
  792. int get_z_index() const;
  793. void set_y_sort_origin(int p_y_sort_origin);
  794. int get_y_sort_origin() const;
  795. #ifndef DISABLE_DEPRECATED
  796. void set_occluder(int p_layer_id, Ref<OccluderPolygon2D> p_occluder_polygon);
  797. Ref<OccluderPolygon2D> get_occluder(int p_layer_id, bool p_flip_h = false, bool p_flip_v = false, bool p_transpose = false) const;
  798. #endif // DISABLE_DEPRECATED
  799. void set_occluder_polygons_count(int p_layer_id, int p_polygons_count);
  800. int get_occluder_polygons_count(int p_layer_id) const;
  801. void add_occluder_polygon(int p_layer_id);
  802. void remove_occluder_polygon(int p_layer_id, int p_polygon_index);
  803. void set_occluder_polygon(int p_layer_id, int p_polygon_index, const Ref<OccluderPolygon2D> &p_occluder_polygon);
  804. Ref<OccluderPolygon2D> get_occluder_polygon(int p_layer_id, int p_polygon_index, bool p_flip_h = false, bool p_flip_v = false, bool p_transpose = false) const;
  805. // Physics
  806. void set_constant_linear_velocity(int p_layer_id, const Vector2 &p_velocity);
  807. Vector2 get_constant_linear_velocity(int p_layer_id) const;
  808. void set_constant_angular_velocity(int p_layer_id, real_t p_velocity);
  809. real_t get_constant_angular_velocity(int p_layer_id) const;
  810. void set_collision_polygons_count(int p_layer_id, int p_shapes_count);
  811. int get_collision_polygons_count(int p_layer_id) const;
  812. void add_collision_polygon(int p_layer_id);
  813. void remove_collision_polygon(int p_layer_id, int p_polygon_index);
  814. void set_collision_polygon_points(int p_layer_id, int p_polygon_index, Vector<Vector2> p_polygon);
  815. Vector<Vector2> get_collision_polygon_points(int p_layer_id, int p_polygon_index) const;
  816. void set_collision_polygon_one_way(int p_layer_id, int p_polygon_index, bool p_one_way);
  817. bool is_collision_polygon_one_way(int p_layer_id, int p_polygon_index) const;
  818. void set_collision_polygon_one_way_margin(int p_layer_id, int p_polygon_index, float p_one_way_margin);
  819. float get_collision_polygon_one_way_margin(int p_layer_id, int p_polygon_index) const;
  820. int get_collision_polygon_shapes_count(int p_layer_id, int p_polygon_index) const;
  821. Ref<ConvexPolygonShape2D> get_collision_polygon_shape(int p_layer_id, int p_polygon_index, int shape_index, bool p_flip_h = false, bool p_flip_v = false, bool p_transpose = false) const;
  822. // Terrain
  823. void set_terrain_set(int p_terrain_id);
  824. int get_terrain_set() const;
  825. void set_terrain(int p_terrain_id);
  826. int get_terrain() const;
  827. void set_terrain_peering_bit(TileSet::CellNeighbor p_peering_bit, int p_terrain_id);
  828. int get_terrain_peering_bit(TileSet::CellNeighbor p_peering_bit) const;
  829. bool is_valid_terrain_peering_bit(TileSet::CellNeighbor p_peering_bit) const;
  830. TileSet::TerrainsPattern get_terrains_pattern() const; // Not exposed.
  831. // Navigation
  832. void set_navigation_polygon(int p_layer_id, Ref<NavigationPolygon> p_navigation_polygon);
  833. Ref<NavigationPolygon> get_navigation_polygon(int p_layer_id, bool p_flip_h = false, bool p_flip_v = false, bool p_transpose = false) const;
  834. // Misc
  835. void set_probability(float p_probability);
  836. float get_probability() const;
  837. // Custom data.
  838. void set_custom_data(String p_layer_name, Variant p_value);
  839. Variant get_custom_data(String p_layer_name) const;
  840. bool has_custom_data(const String &p_layer_name) const;
  841. void set_custom_data_by_layer_id(int p_layer_id, Variant p_value);
  842. Variant get_custom_data_by_layer_id(int p_layer_id) const;
  843. // Polygons.
  844. static PackedVector2Array get_transformed_vertices(const PackedVector2Array &p_vertices, bool p_flip_h, bool p_flip_v, bool p_transpose);
  845. };
  846. VARIANT_ENUM_CAST(TileSet::CellNeighbor);
  847. VARIANT_ENUM_CAST(TileSet::TerrainMode);
  848. VARIANT_ENUM_CAST(TileSet::TileShape);
  849. VARIANT_ENUM_CAST(TileSet::TileLayout);
  850. VARIANT_ENUM_CAST(TileSet::TileOffsetAxis);
  851. VARIANT_ENUM_CAST(TileSetAtlasSource::TileAnimationMode);
  852. #endif // TILE_SET_H