So far we've looked at how to create tile maps and have them display in game. We've also used these tile maps to create collision. This guide shows how to instantiate entities by placing tiles in a tile map (no code required).
Entity instances can be created through Tiled or in the Live Edit system. Each has its own benefit so which you choose depends on the type of entity instances you are creating.
If you are placing entities which are uniform (all instances are the same, except for their position), then Tiled entities can be convenient and easier to work with.
If you are palcing entities which must be customized per-instance, or if the appearance of the entity is important when it is being positioned, then placing entities in Live Edit can be easier than working in Tiled.
For information about working in the Live Edit system, see the Live Edit page.
Any type of entity can be created through tile maps, which provides lots of flexibility. For this example, we'll create a simple entity which displays a yellow rectangle called Monster:
-
Select the Quick Actions tab in the FRB editor and click Add Entity
-
Name the entity Monster
-
Check the AxisAlignedRectangle check box
-
Leave the other options default and click OK
We need to modify the rectangle so it stands out relative to the collision rectangles:
-
Select the newly-created rectangle (named AxisAlignedRectangleInstance)
-
Change Width to 12
-
Change Height to 12
-
Change Color to Yellow
We will be using the Type property to set the entity type. For a deeper dive on how this property works, see the Type documentation here: http://flatredball.com/documentation/tools/tiled-plugin/using-tiled-object-types/ The documentation linked above shows how to import an XML file created using the FRB editor so that variables defined on Monster (or any other entity) automatically appear in Tiled. For simplicity we'll skip this step, but you may want to perform that additional step for larger projects. To set the Type property:
-
Open whichever level is currently being loaded in your game in Tiled (such as Level2Map.tmx)
-
Select the TiledIcons. We should always use TiledIcons to create entities rather than visual tilesets like dungeonTileSet
-
Click the Edit Tileset button
-
Select a tile on your map to represent the monsters. For example, select the red monster icon.
-
Enter the entity name Monster as the Type or Class for this tile. Depending on what version of Tiled that you are using, you may see Class instead of Type, but they both mean the same thing. Also, note that the name needs to match the entity name exactly, including capitalization.
Any tiles placed with the Type or Class of Monster will create Monster instances at runtime. Tiles for creating entities are placed just like any other tiles. We can place a few monster tiles in either level.
As always, don't forget to save your changes on the tile map and tile set. If we run our game, we will see the monster enemies (yellow rectangles).
If enemies aren't showing up, check the following:
- Make sure that Level2Tmx.tmx and dungeonTileSet.tsx files have both been saved
- Verify that you entered the correct name (including capitalization) in the Type or Class property.