2
0

TileSet.xml 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <class name="TileSet" inherits="Resource" version="4.0">
  3. <brief_description>
  4. Tile library for tilemaps.
  5. </brief_description>
  6. <description>
  7. A TileSet is a library of tiles for a [TileMap]. A TileSet handles a list of [TileSetSource], each of them storing a set of tiles.
  8. Tiles can either be from a [TileSetAtlasSource], that render tiles out of a texture with support for physics, navigation, etc... or from a [TileSetScenesCollectionSource] which exposes scene-based tiles.
  9. Tiles are referenced by using three IDs: their source ID, their atlas coordinates ID and their alternative tile ID.
  10. A TileSet can be configured so that its tiles expose more or less properties. To do so, the TileSet resources uses property layers, that you can add or remove depending on your needs.
  11. For example, adding a physics layer allows giving collision shapes to your tiles. Each layer having dedicated properties (physics layer an mask), you may add several TileSet physics layers for each type of collision you need.
  12. See the functions to add new layers for more information.
  13. </description>
  14. <tutorials>
  15. <link title="Using Tilemaps">https://docs.godotengine.org/en/latest/tutorials/2d/using_tilemaps.html</link>
  16. <link title="2D Platformer Demo">https://godotengine.org/asset-library/asset/120</link>
  17. <link title="2D Isometric Demo">https://godotengine.org/asset-library/asset/112</link>
  18. <link title="2D Hexagonal Demo">https://godotengine.org/asset-library/asset/111</link>
  19. <link title="2D Navigation Astar Demo">https://godotengine.org/asset-library/asset/519</link>
  20. <link title="2D Role Playing Game Demo">https://godotengine.org/asset-library/asset/520</link>
  21. <link title="2D Kinematic Character Demo">https://godotengine.org/asset-library/asset/113</link>
  22. </tutorials>
  23. <methods>
  24. <method name="add_custom_data_layer">
  25. <return type="void" />
  26. <argument index="0" name="to_position" type="int" default="-1" />
  27. <description>
  28. Adds a custom data layer to the TileSet at the given position [code]to_position[/code] in the array. If [code]to_position[/code] is -1, adds it at the end of the array.
  29. Custom data layers allow assigning custom properties to atlas tiles.
  30. </description>
  31. </method>
  32. <method name="add_navigation_layer">
  33. <return type="void" />
  34. <argument index="0" name="to_position" type="int" default="-1" />
  35. <description>
  36. Adds a navigation layer to the TileSet at the given position [code]to_position[/code] in the array. If [code]to_position[/code] is -1, adds it at the end of the array.
  37. Navigation layers allow assigning a navigable area to atlas tiles.
  38. </description>
  39. </method>
  40. <method name="add_occlusion_layer">
  41. <return type="void" />
  42. <argument index="0" name="to_position" type="int" default="-1" />
  43. <description>
  44. Adds an occlusion layer to the TileSet at the given position [code]to_position[/code] in the array. If [code]to_position[/code] is -1, adds it at the end of the array.
  45. Occlusion layers allow assigning occlusion polygons to atlas tiles.
  46. </description>
  47. </method>
  48. <method name="add_pattern">
  49. <return type="int" />
  50. <argument index="0" name="pattern" type="TileMapPattern" />
  51. <argument index="1" name="index" type="int" default="-1" />
  52. <description>
  53. Adds a [TileMapPattern] to be stored in the TileSet resouce. If provided, insert it at the given [code]index[/code].
  54. </description>
  55. </method>
  56. <method name="add_physics_layer">
  57. <return type="void" />
  58. <argument index="0" name="to_position" type="int" default="-1" />
  59. <description>
  60. Adds a physics layer to the TileSet at the given position [code]to_position[/code] in the array. If [code]to_position[/code] is -1, adds it at the end of the array.
  61. Physics layers allow assigning collision polygons to atlas tiles.
  62. </description>
  63. </method>
  64. <method name="add_source">
  65. <return type="int" />
  66. <argument index="0" name="source" type="TileSetSource" />
  67. <argument index="1" name="atlas_source_id_override" type="int" default="-1" />
  68. <description>
  69. Adds a [TileSetSource] to the TileSet. If [code]atlas_source_id_override[/code] is not -1, also set its source ID. Otherwise, a unique identifier is automatically generated.
  70. The function returns the added source source ID or -1 if the source could not be added.
  71. </description>
  72. </method>
  73. <method name="add_terrain">
  74. <return type="void" />
  75. <argument index="0" name="terrain_set" type="int" />
  76. <argument index="1" name="to_position" type="int" default="-1" />
  77. <description>
  78. Adds a new terrain to the given terrain set [code]terrain_set[/code] at the given position [code]to_position[/code] in the array. If [code]to_position[/code] is -1, adds it at the end of the array.
  79. </description>
  80. </method>
  81. <method name="add_terrain_set">
  82. <return type="void" />
  83. <argument index="0" name="to_position" type="int" default="-1" />
  84. <description>
  85. Adds a new terrain set at the given position [code]to_position[/code] in the array. If [code]to_position[/code] is -1, adds it at the end of the array.
  86. </description>
  87. </method>
  88. <method name="cleanup_invalid_tile_proxies">
  89. <return type="void" />
  90. <description>
  91. Clears tile proxies pointing to invalid tiles.
  92. </description>
  93. </method>
  94. <method name="clear_tile_proxies">
  95. <return type="void" />
  96. <description>
  97. Clears all tile proxies.
  98. </description>
  99. </method>
  100. <method name="get_alternative_level_tile_proxy">
  101. <return type="Array" />
  102. <argument index="0" name="source_from" type="int" />
  103. <argument index="1" name="coords_from" type="Vector2i" />
  104. <argument index="2" name="alternative_from" type="int" />
  105. <description>
  106. Returns the alternative-level proxy for the given identifiers. The returned array contains the three proxie's target identifiers (source ID, atlas coords ID and alternative tile ID).
  107. If the TileSet has no proxy for the given identifiers, returns an empty Array.
  108. </description>
  109. </method>
  110. <method name="get_coords_level_tile_proxy">
  111. <return type="Array" />
  112. <argument index="0" name="source_from" type="int" />
  113. <argument index="1" name="coords_from" type="Vector2i" />
  114. <description>
  115. Returns the coodinate-level proxy for the given identifiers. The returned array contains the two proxie's target identifiers (source ID and atlas coords ID).
  116. If the TileSet has no proxy for the given identifiers, returns an empty Array.
  117. </description>
  118. </method>
  119. <method name="get_custom_data_layers_count" qualifiers="const">
  120. <return type="int" />
  121. <description>
  122. Returns the custom data layers count.
  123. </description>
  124. </method>
  125. <method name="get_navigation_layer_layers" qualifiers="const">
  126. <return type="int" />
  127. <argument index="0" name="layer_index" type="int" />
  128. <description>
  129. Returns the navigation layers (as in the Navigation server) of the gives TileSet navigation layer.
  130. </description>
  131. </method>
  132. <method name="get_navigation_layers_count" qualifiers="const">
  133. <return type="int" />
  134. <description>
  135. Returns the navigation layers count.
  136. </description>
  137. </method>
  138. <method name="get_next_source_id" qualifiers="const">
  139. <return type="int" />
  140. <description>
  141. Returns a new unused source ID. This generated ID is the same that a call to [code]add_source[/code] would return.
  142. </description>
  143. </method>
  144. <method name="get_occlusion_layer_light_mask" qualifiers="const">
  145. <return type="int" />
  146. <argument index="0" name="layer_index" type="int" />
  147. <description>
  148. Returns the light mask of the occlusion layer.
  149. </description>
  150. </method>
  151. <method name="get_occlusion_layer_sdf_collision" qualifiers="const">
  152. <return type="bool" />
  153. <argument index="0" name="layer_index" type="int" />
  154. <description>
  155. Returns if the occluders from this layer use [code]sdf_collision[/code].
  156. </description>
  157. </method>
  158. <method name="get_occlusion_layers_count" qualifiers="const">
  159. <return type="int" />
  160. <description>
  161. Returns the occlusion layers count.
  162. </description>
  163. </method>
  164. <method name="get_pattern">
  165. <return type="TileMapPattern" />
  166. <argument index="0" name="index" type="int" default="-1" />
  167. <description>
  168. Returns the [TileMapPattern] at the given [code]index[/code].
  169. </description>
  170. </method>
  171. <method name="get_patterns_count">
  172. <return type="int" />
  173. <description>
  174. Returns the number of [TileMapPattern] this tile set handles.
  175. </description>
  176. </method>
  177. <method name="get_physics_layer_collision_layer" qualifiers="const">
  178. <return type="int" />
  179. <argument index="0" name="layer_index" type="int" />
  180. <description>
  181. Returns the collision layer (as in the physics server) bodies on the given TileSet's physics layer are in.
  182. </description>
  183. </method>
  184. <method name="get_physics_layer_collision_mask" qualifiers="const">
  185. <return type="int" />
  186. <argument index="0" name="layer_index" type="int" />
  187. <description>
  188. Returns the collision mask of bodies on the given TileSet's physics layer.
  189. </description>
  190. </method>
  191. <method name="get_physics_layer_physics_material" qualifiers="const">
  192. <return type="PhysicsMaterial" />
  193. <argument index="0" name="layer_index" type="int" />
  194. <description>
  195. Returns the physics material of bodies on the given TileSet's physics layer.
  196. </description>
  197. </method>
  198. <method name="get_physics_layers_count" qualifiers="const">
  199. <return type="int" />
  200. <description>
  201. Returns the physics layers count.
  202. </description>
  203. </method>
  204. <method name="get_source" qualifiers="const">
  205. <return type="TileSetSource" />
  206. <argument index="0" name="source_id" type="int" />
  207. <description>
  208. Returns the [TileSetSource] with ID [code]source_id[/code].
  209. </description>
  210. </method>
  211. <method name="get_source_count" qualifiers="const">
  212. <return type="int" />
  213. <description>
  214. Returns the number of [TileSetSource] in this TileSet.
  215. </description>
  216. </method>
  217. <method name="get_source_id" qualifiers="const">
  218. <return type="int" />
  219. <argument index="0" name="index" type="int" />
  220. <description>
  221. Returns the source ID for source with index [code]index[/code].
  222. </description>
  223. </method>
  224. <method name="get_source_level_tile_proxy">
  225. <return type="int" />
  226. <argument index="0" name="source_from" type="int" />
  227. <description>
  228. Returns the source-level proxy for the given source identifier.
  229. If the TileSet has no proxy for the given identifier, returns -1.
  230. </description>
  231. </method>
  232. <method name="get_terrain_color" qualifiers="const">
  233. <return type="Color" />
  234. <argument index="0" name="terrain_set" type="int" />
  235. <argument index="1" name="terrain_index" type="int" />
  236. <description>
  237. Returns a terrain's color.
  238. </description>
  239. </method>
  240. <method name="get_terrain_name" qualifiers="const">
  241. <return type="String" />
  242. <argument index="0" name="terrain_set" type="int" />
  243. <argument index="1" name="terrain_index" type="int" />
  244. <description>
  245. Returns a terrain's name.
  246. </description>
  247. </method>
  248. <method name="get_terrain_set_mode" qualifiers="const">
  249. <return type="int" enum="TileSet.TerrainMode" />
  250. <argument index="0" name="terrain_set" type="int" />
  251. <description>
  252. Returns a terrain set mode.
  253. </description>
  254. </method>
  255. <method name="get_terrain_sets_count" qualifiers="const">
  256. <return type="int" />
  257. <description>
  258. Returns the terrain sets count.
  259. </description>
  260. </method>
  261. <method name="get_terrains_count" qualifiers="const">
  262. <return type="int" />
  263. <argument index="0" name="terrain_set" type="int" />
  264. <description>
  265. Returns the number of terrains in the given terrain set.
  266. </description>
  267. </method>
  268. <method name="has_alternative_level_tile_proxy">
  269. <return type="bool" />
  270. <argument index="0" name="source_from" type="int" />
  271. <argument index="1" name="coords_from" type="Vector2i" />
  272. <argument index="2" name="alternative_from" type="int" />
  273. <description>
  274. Returns if there is and alternative-level proxy for the given identifiers.
  275. </description>
  276. </method>
  277. <method name="has_coords_level_tile_proxy">
  278. <return type="bool" />
  279. <argument index="0" name="source_from" type="int" />
  280. <argument index="1" name="coords_from" type="Vector2i" />
  281. <description>
  282. Returns if there is a coodinates-level proxy for the given identifiers.
  283. </description>
  284. </method>
  285. <method name="has_source" qualifiers="const">
  286. <return type="bool" />
  287. <argument index="0" name="source_id" type="int" />
  288. <description>
  289. Returns if this TileSet has a source for the given source ID.
  290. </description>
  291. </method>
  292. <method name="has_source_level_tile_proxy">
  293. <return type="bool" />
  294. <argument index="0" name="source_from" type="int" />
  295. <description>
  296. Returns if there is a source-level proxy for the given source ID.
  297. </description>
  298. </method>
  299. <method name="map_tile_proxy" qualifiers="const">
  300. <return type="Array" />
  301. <argument index="0" name="source_from" type="int" />
  302. <argument index="1" name="coords_from" type="Vector2i" />
  303. <argument index="2" name="alternative_from" type="int" />
  304. <description>
  305. According to the configured proxies, maps the provided indentifiers to a new set of identifiers. The source ID, atlas coordinates ID and alternative tile ID are returned as a 3 elements Array.
  306. This function first look for matching alternative-level proxies, then coordinates-level proxies, then source-level proxies.
  307. If no proxy corresponding to provided identifiers are found, returns the same values the ones used as arguments.
  308. </description>
  309. </method>
  310. <method name="move_custom_data_layer">
  311. <return type="void" />
  312. <argument index="0" name="layer_index" type="int" />
  313. <argument index="1" name="to_position" type="int" />
  314. <description>
  315. Moves the custom data layer at index [code]layer_index[/code] to the given position [code]to_position[/code] in the array. Also updates the atlas tiles accordingly.
  316. </description>
  317. </method>
  318. <method name="move_navigation_layer">
  319. <return type="void" />
  320. <argument index="0" name="layer_index" type="int" />
  321. <argument index="1" name="to_position" type="int" />
  322. <description>
  323. Moves the navigation layer at index [code]layer_index[/code] to the given position [code]to_position[/code] in the array. Also updates the atlas tiles accordingly.
  324. </description>
  325. </method>
  326. <method name="move_occlusion_layer">
  327. <return type="void" />
  328. <argument index="0" name="layer_index" type="int" />
  329. <argument index="1" name="to_position" type="int" />
  330. <description>
  331. Moves the occlusion layer at index [code]layer_index[/code] to the given position [code]to_position[/code] in the array. Also updates the atlas tiles accordingly.
  332. </description>
  333. </method>
  334. <method name="move_physics_layer">
  335. <return type="void" />
  336. <argument index="0" name="layer_index" type="int" />
  337. <argument index="1" name="to_position" type="int" />
  338. <description>
  339. Moves the physics layer at index [code]layer_index[/code] to the given position [code]to_position[/code] in the array. Also updates the atlas tiles accordingly.
  340. </description>
  341. </method>
  342. <method name="move_terrain">
  343. <return type="void" />
  344. <argument index="0" name="terrain_set" type="int" />
  345. <argument index="1" name="terrain_index" type="int" />
  346. <argument index="2" name="to_position" type="int" />
  347. <description>
  348. Moves the terrain at index [code]terrain_index[/code] for terrain set [code]terrain_set[/code] to the given position [code]to_position[/code] in the array. Also updates the atlas tiles accordingly.
  349. </description>
  350. </method>
  351. <method name="move_terrain_set">
  352. <return type="void" />
  353. <argument index="0" name="terrain_set" type="int" />
  354. <argument index="1" name="to_position" type="int" />
  355. <description>
  356. Moves the terrain set at index [code]terrain_set[/code] to the given position [code]to_position[/code] in the array. Also updates the atlas tiles accordingly.
  357. </description>
  358. </method>
  359. <method name="remove_alternative_level_tile_proxy">
  360. <return type="void" />
  361. <argument index="0" name="source_from" type="int" />
  362. <argument index="1" name="coords_from" type="Vector2i" />
  363. <argument index="2" name="alternative_from" type="int" />
  364. <description>
  365. Removes an alternative-level proxy for the given identifiers.
  366. </description>
  367. </method>
  368. <method name="remove_coords_level_tile_proxy">
  369. <return type="void" />
  370. <argument index="0" name="source_from" type="int" />
  371. <argument index="1" name="coords_from" type="Vector2i" />
  372. <description>
  373. Removes a coordinates-level proxy for the given identifiers.
  374. </description>
  375. </method>
  376. <method name="remove_custom_data_layer">
  377. <return type="void" />
  378. <argument index="0" name="layer_index" type="int" />
  379. <description>
  380. Removes the custom data layer at index [code]layer_index[/code]. Also updates the atlas tiles accordingly.
  381. </description>
  382. </method>
  383. <method name="remove_navigation_layer">
  384. <return type="void" />
  385. <argument index="0" name="layer_index" type="int" />
  386. <description>
  387. Removes the navigation layer at index [code]layer_index[/code]. Also updates the atlas tiles accordingly.
  388. </description>
  389. </method>
  390. <method name="remove_occlusion_layer">
  391. <return type="void" />
  392. <argument index="0" name="layer_index" type="int" />
  393. <description>
  394. Removes the occlusion layer at index [code]layer_index[/code]. Also updates the atlas tiles accordingly.
  395. </description>
  396. </method>
  397. <method name="remove_pattern">
  398. <return type="void" />
  399. <argument index="0" name="index" type="int" />
  400. <description>
  401. Remove the [TileMapPattern] at the given index.
  402. </description>
  403. </method>
  404. <method name="remove_physics_layer">
  405. <return type="void" />
  406. <argument index="0" name="layer_index" type="int" />
  407. <description>
  408. Removes the physics layer at index [code]layer_index[/code]. Also updates the atlas tiles accordingly.
  409. </description>
  410. </method>
  411. <method name="remove_source">
  412. <return type="void" />
  413. <argument index="0" name="source_id" type="int" />
  414. <description>
  415. Removes the source with the given source ID.
  416. </description>
  417. </method>
  418. <method name="remove_source_level_tile_proxy">
  419. <return type="void" />
  420. <argument index="0" name="source_from" type="int" />
  421. <description>
  422. Removes a source-level tile proxy.
  423. </description>
  424. </method>
  425. <method name="remove_terrain">
  426. <return type="void" />
  427. <argument index="0" name="terrain_set" type="int" />
  428. <argument index="1" name="terrain_index" type="int" />
  429. <description>
  430. Removes the terrain at index [code]terrain_index[/code] in the given terrain set [code]terrain_set[/code]. Also updates the atlas tiles accordingly.
  431. </description>
  432. </method>
  433. <method name="remove_terrain_set">
  434. <return type="void" />
  435. <argument index="0" name="terrain_set" type="int" />
  436. <description>
  437. Removes the terrain set at index [code]terrain_set[/code]. Also updates the atlas tiles accordingly.
  438. </description>
  439. </method>
  440. <method name="set_alternative_level_tile_proxy">
  441. <return type="void" />
  442. <argument index="0" name="source_from" type="int" />
  443. <argument index="1" name="coords_from" type="Vector2i" />
  444. <argument index="2" name="alternative_from" type="int" />
  445. <argument index="3" name="source_to" type="int" />
  446. <argument index="4" name="coords_to" type="Vector2i" />
  447. <argument index="5" name="alternative_to" type="int" />
  448. <description>
  449. Create an alternative-level proxy for the given identifiers. A proxy will map set of tile identifiers to another set of identifiers.
  450. This can be used to replace a tile in all TileMaps using this TileSet, as TileMap nodes will find and use the proxy's target tile when one is available.
  451. Proxied tiles can be automatically replaced in TileMap nodes using the editor.
  452. </description>
  453. </method>
  454. <method name="set_coords_level_tile_proxy">
  455. <return type="void" />
  456. <argument index="0" name="p_source_from" type="int" />
  457. <argument index="1" name="coords_from" type="Vector2i" />
  458. <argument index="2" name="source_to" type="int" />
  459. <argument index="3" name="coords_to" type="Vector2i" />
  460. <description>
  461. Creates a coordinates-level proxy for the given identifiers. A proxy will map set of tile identifiers to another set of identifiers. The alternative tile ID is kept the same when using coordinates-level proxies.
  462. This can be used to replace a tile in all TileMaps using this TileSet, as TileMap nodes will find and use the proxy's target tile when one is available.
  463. Proxied tiles can be automatically replaced in TileMap nodes using the editor.
  464. </description>
  465. </method>
  466. <method name="set_navigation_layer_layers">
  467. <return type="void" />
  468. <argument index="0" name="layer_index" type="int" />
  469. <argument index="1" name="layers" type="int" />
  470. <description>
  471. Sets the navigation layers (as in the navigation server) for navigation regions is the given TileSet navigation layer.
  472. </description>
  473. </method>
  474. <method name="set_occlusion_layer_light_mask">
  475. <return type="void" />
  476. <argument index="0" name="layer_index" type="int" />
  477. <argument index="1" name="light_mask" type="int" />
  478. <description>
  479. Sets the occlusion layer (as in the rendering server) for occluders in the given TileSet occlusion layer.
  480. </description>
  481. </method>
  482. <method name="set_occlusion_layer_sdf_collision">
  483. <return type="void" />
  484. <argument index="0" name="layer_index" type="int" />
  485. <argument index="1" name="sdf_collision" type="bool" />
  486. <description>
  487. Enables or disables sdf collision for occluders in the given TileSet occlusion layer.
  488. </description>
  489. </method>
  490. <method name="set_physics_layer_collision_layer">
  491. <return type="void" />
  492. <argument index="0" name="layer_index" type="int" />
  493. <argument index="1" name="layer" type="int" />
  494. <description>
  495. Sets the physics layer (as in the physics server) for bodies in the given TileSet physics layer.
  496. </description>
  497. </method>
  498. <method name="set_physics_layer_collision_mask">
  499. <return type="void" />
  500. <argument index="0" name="layer_index" type="int" />
  501. <argument index="1" name="mask" type="int" />
  502. <description>
  503. Sets the physics layer (as in the physics server) for bodies in the given TileSet physics layer.
  504. </description>
  505. </method>
  506. <method name="set_physics_layer_physics_material">
  507. <return type="void" />
  508. <argument index="0" name="layer_index" type="int" />
  509. <argument index="1" name="physics_material" type="PhysicsMaterial" />
  510. <description>
  511. Sets the physics material for bodies in the given TileSet physics layer.
  512. </description>
  513. </method>
  514. <method name="set_source_id">
  515. <return type="void" />
  516. <argument index="0" name="source_id" type="int" />
  517. <argument index="1" name="new_source_id" type="int" />
  518. <description>
  519. Changes a source's ID.
  520. </description>
  521. </method>
  522. <method name="set_source_level_tile_proxy">
  523. <return type="void" />
  524. <argument index="0" name="source_from" type="int" />
  525. <argument index="1" name="source_to" type="int" />
  526. <description>
  527. Creates a source-level proxy for the given source ID. A proxy will map set of tile identifiers to another set of identifiers. Both the atlac coordinates ID and the alternative tile ID are kept the same when using source-level proxies.
  528. This can be used to replace a source in all TileMaps using this TileSet, as TileMap nodes will find and use the proxy's target source when one is available.
  529. Proxied tiles can be automatically replaced in TileMap nodes using the editor.
  530. </description>
  531. </method>
  532. <method name="set_terrain_color">
  533. <return type="void" />
  534. <argument index="0" name="terrain_set" type="int" />
  535. <argument index="1" name="terrain_index" type="int" />
  536. <argument index="2" name="color" type="Color" />
  537. <description>
  538. Sets a terrain's color. This color is used for identifying the different terrains in the TileSet editor.
  539. </description>
  540. </method>
  541. <method name="set_terrain_name">
  542. <return type="void" />
  543. <argument index="0" name="terrain_set" type="int" />
  544. <argument index="1" name="terrain_index" type="int" />
  545. <argument index="2" name="name" type="String" />
  546. <description>
  547. Sets a terrain's name.
  548. </description>
  549. </method>
  550. <method name="set_terrain_set_mode">
  551. <return type="void" />
  552. <argument index="0" name="terrain_set" type="int" />
  553. <argument index="1" name="mode" type="int" enum="TileSet.TerrainMode" />
  554. <description>
  555. Sets a terrain mode. Each mode determines which bits of a tile shape is used to match the neighbouring tiles' terrains.
  556. </description>
  557. </method>
  558. </methods>
  559. <members>
  560. <member name="tile_layout" type="int" setter="set_tile_layout" getter="get_tile_layout" enum="TileSet.TileLayout" default="0">
  561. For all half-offset shapes (Isometric, Hexagonal and Half-Offset square), changes the way tiles are indexed in the TileMap grid.
  562. </member>
  563. <member name="tile_offset_axis" type="int" setter="set_tile_offset_axis" getter="get_tile_offset_axis" enum="TileSet.TileOffsetAxis" default="0">
  564. For all half-offset shapes (Isometric, Hexagonal and Half-Offset square), determines the offset axis.
  565. </member>
  566. <member name="tile_shape" type="int" setter="set_tile_shape" getter="get_tile_shape" enum="TileSet.TileShape" default="0">
  567. The tile shape.
  568. </member>
  569. <member name="tile_size" type="Vector2i" setter="set_tile_size" getter="get_tile_size" default="Vector2i(16, 16)">
  570. The tile size, in pixels. For all tile shapes, this size corresponds to the encompassing rectangle of the tile shape. This is thus the minimal cell size required in an atlas.
  571. </member>
  572. <member name="uv_clipping" type="bool" setter="set_uv_clipping" getter="is_uv_clipping" default="false">
  573. Enables/Disable uv clipping when rendering the tiles.
  574. </member>
  575. </members>
  576. <constants>
  577. <constant name="TILE_SHAPE_SQUARE" value="0" enum="TileShape">
  578. Rectangular tile shape.
  579. </constant>
  580. <constant name="TILE_SHAPE_ISOMETRIC" value="1" enum="TileShape">
  581. Diamond tile shape (for isometric look).
  582. </constant>
  583. <constant name="TILE_SHAPE_HALF_OFFSET_SQUARE" value="2" enum="TileShape">
  584. Rectangular tile shape with one row/colum out of two offset by half a tile.
  585. </constant>
  586. <constant name="TILE_SHAPE_HEXAGON" value="3" enum="TileShape">
  587. Hexagonal tile shape.
  588. </constant>
  589. <constant name="TILE_LAYOUT_STACKED" value="0" enum="TileLayout">
  590. Tile coordinates layout where both axis stay consistent with their respective local horizontal and vertical axis.
  591. </constant>
  592. <constant name="TILE_LAYOUT_STACKED_OFFSET" value="1" enum="TileLayout">
  593. Same as [code]TILE_LAYOUT_STAKED[/code], but the first half-offset is negative instead of positive.
  594. </constant>
  595. <constant name="TILE_LAYOUT_STAIRS_RIGHT" value="2" enum="TileLayout">
  596. Tile coordinates layout where the horizontal axis stay horizontal, and the vertical one goes down-right.
  597. </constant>
  598. <constant name="TILE_LAYOUT_STAIRS_DOWN" value="3" enum="TileLayout">
  599. Tile coordinates layout where the vertical axis stay vertical, and the horizontal one goes down-right.
  600. </constant>
  601. <constant name="TILE_LAYOUT_DIAMOND_RIGHT" value="4" enum="TileLayout">
  602. Tile coordinates layout where the horizontal axis goes up-right, and the vertical one goes down-right.
  603. </constant>
  604. <constant name="TILE_LAYOUT_DIAMOND_DOWN" value="5" enum="TileLayout">
  605. Tile coordinates layout where the horizontal axis goes down-right, and the vertical one goes down-left.
  606. </constant>
  607. <constant name="TILE_OFFSET_AXIS_HORIZONTAL" value="0" enum="TileOffsetAxis">
  608. Horizontal half-offset.
  609. </constant>
  610. <constant name="TILE_OFFSET_AXIS_VERTICAL" value="1" enum="TileOffsetAxis">
  611. Vertical half-offset.
  612. </constant>
  613. <constant name="CELL_NEIGHBOR_RIGHT_SIDE" value="0" enum="CellNeighbor">
  614. Neighbor on the right side.
  615. </constant>
  616. <constant name="CELL_NEIGHBOR_RIGHT_CORNER" value="1" enum="CellNeighbor">
  617. Neighbor in the right corner.
  618. </constant>
  619. <constant name="CELL_NEIGHBOR_BOTTOM_RIGHT_SIDE" value="2" enum="CellNeighbor">
  620. Neighbor on the bottom right side.
  621. </constant>
  622. <constant name="CELL_NEIGHBOR_BOTTOM_RIGHT_CORNER" value="3" enum="CellNeighbor">
  623. Neighbor in the bottom right corner.
  624. </constant>
  625. <constant name="CELL_NEIGHBOR_BOTTOM_SIDE" value="4" enum="CellNeighbor">
  626. Neighbor on the bottom side.
  627. </constant>
  628. <constant name="CELL_NEIGHBOR_BOTTOM_CORNER" value="5" enum="CellNeighbor">
  629. Neighbor in the bottom corner.
  630. </constant>
  631. <constant name="CELL_NEIGHBOR_BOTTOM_LEFT_SIDE" value="6" enum="CellNeighbor">
  632. Neighbor on the bottom left side.
  633. </constant>
  634. <constant name="CELL_NEIGHBOR_BOTTOM_LEFT_CORNER" value="7" enum="CellNeighbor">
  635. Neighbor in the bottom left corner.
  636. </constant>
  637. <constant name="CELL_NEIGHBOR_LEFT_SIDE" value="8" enum="CellNeighbor">
  638. Neighbor on the left side.
  639. </constant>
  640. <constant name="CELL_NEIGHBOR_LEFT_CORNER" value="9" enum="CellNeighbor">
  641. Neighbor in the left corner.
  642. </constant>
  643. <constant name="CELL_NEIGHBOR_TOP_LEFT_SIDE" value="10" enum="CellNeighbor">
  644. Neighbor on the top left side.
  645. </constant>
  646. <constant name="CELL_NEIGHBOR_TOP_LEFT_CORNER" value="11" enum="CellNeighbor">
  647. Neighbor in the top left corner.
  648. </constant>
  649. <constant name="CELL_NEIGHBOR_TOP_SIDE" value="12" enum="CellNeighbor">
  650. Neighbor on the top side.
  651. </constant>
  652. <constant name="CELL_NEIGHBOR_TOP_CORNER" value="13" enum="CellNeighbor">
  653. Neighbor in the top corner.
  654. </constant>
  655. <constant name="CELL_NEIGHBOR_TOP_RIGHT_SIDE" value="14" enum="CellNeighbor">
  656. Neighbor on the top right side.
  657. </constant>
  658. <constant name="CELL_NEIGHBOR_TOP_RIGHT_CORNER" value="15" enum="CellNeighbor">
  659. Neighbor in the top right corner.
  660. </constant>
  661. <constant name="TERRAIN_MODE_MATCH_CORNERS_AND_SIDES" value="0" enum="TerrainMode">
  662. Requires both corners and side to match with neighboring tiles' terrains.
  663. </constant>
  664. <constant name="TERRAIN_MODE_MATCH_CORNERS" value="1" enum="TerrainMode">
  665. Requires corners to match with neighboring tiles' terrains.
  666. </constant>
  667. <constant name="TERRAIN_MODE_MATCH_SIDES" value="2" enum="TerrainMode">
  668. Requires sides to match with neighboring tiles' terrains.
  669. </constant>
  670. </constants>
  671. </class>