Reading time: 4 minutes
In today’s post, I’m going to show you how we can create a surface using Unity.
I’ve used this image that you can download here (it is licensed under CC0, created/distributed by Kenney (www.kenney.nl)):
data:image/s3,"s3://crabby-images/88e4c/88e4c1d8fc0f2d5db032613a5573643e5ac97d5a" alt=""
We’re going to copy this .png image into the Sprites folder (Assets > Sprites) in our Unity project. If we don’t have the folder, we create it.
data:image/s3,"s3://crabby-images/97530/97530d48cfcc17da9556efc635b019683a7106b6" alt=""
To split the tile, we can use the Unity editor. To do this, click on the tiles_packed image and in the options that appear on the right, click on Sprite Editor.
data:image/s3,"s3://crabby-images/c19de/c19dec44e60c18568a459bed4d8788cb04dea2ce" alt=""
Now, inside the editor, click on the second arrow pointing downwards next to Sprite Editor and select:
- Type: Grid by Cell Count
- Column & Row: C: 19 R: 10
And click on Slice.
data:image/s3,"s3://crabby-images/7d605/7d6054e518fc01e8412db418242bd5aad72db1ef" alt=""
Now click on Apply and exit the editor.
data:image/s3,"s3://crabby-images/d89b0/d89b0d12112ddc184ec7e1e8179c0125f70277a2" alt=""
We can verify that it has been split in the Sprites viewer (Assets > Sprites) where we had the original image.
data:image/s3,"s3://crabby-images/53122/53122e4286254e80b3d308cfa77e0abf5dea679b" alt=""
Now let’s place the surface in the scene. To do this, go to Hierarchy and right-click inside to create a new element 2D Object > Tilemap > Rectangular.
data:image/s3,"s3://crabby-images/b1295/b12956f598be7c36012b1f73e4be38ecda645185" alt=""
Now, to draw the floor on the surface, open the tab in the top options of Unity Window > 2D > Tile Palette.
data:image/s3,"s3://crabby-images/9c3c6/9c3c652afaa57f60dbe7ba27c4b778116de509ba" alt=""
The Tile Palette editor will open.
data:image/s3,"s3://crabby-images/5554f/5554f434234c1c36635007e157c79402edabfabf" alt=""
Click on Create New Palette, give it a name, and leave the rest of the fields as default.
data:image/s3,"s3://crabby-images/95599/9559954d118e2d0364f9f3cbeae37e505026fce9" alt=""
Click on Create and choose the path to save it. In this case, let’s create or choose a folder called tiles (Assets > Tiles).
data:image/s3,"s3://crabby-images/beab4/beab4fbefe819bb522ef315cdf2ac7b107edbe3f" alt=""
Now we can see our element inside this folder Assets > Tiles.
data:image/s3,"s3://crabby-images/e7cb5/e7cb5fdac6d9706106d94567a0e4a8d76235cf7f" alt=""
Now open the Assets > Sprites folder and drag tiles_packed into the right editor, Tile Palette.
data:image/s3,"s3://crabby-images/3afe1/3afe1ee29e5e4fb84047e1d6c0adf92544e2e332" alt=""
It will ask again where we want to save it, so we choose the Assets > Tiles folder again.
data:image/s3,"s3://crabby-images/5a84c/5a84c07c00f7b7ba275fb821f812721da6a437e4" alt=""
Once saved, we have created the palette generated with our floor image.
data:image/s3,"s3://crabby-images/ef3fb/ef3fb613e5f709252e96c2c09d8c77f0954e9cde" alt=""
Now go back to Hierarchy and select the element we created earlier (inside Grid). I renamed it as Suelo (Floor).
data:image/s3,"s3://crabby-images/66ef8/66ef8821fe15d400132cb7dfab5e26c1394956ab" alt=""
Once selected, we can paint it using the created palette.
data:image/s3,"s3://crabby-images/61742/617421fbfae1cb934368284a22c1989ab88b8c7e" alt=""
data:image/s3,"s3://crabby-images/3a96e/3a96eda44bad1c0b038e0b29f0379b6f00915da8" alt=""
If the elements appear too small like the ones in my image, we can make them larger. To do this, go back to Assets > Sprites and click on tiles_packed.
data:image/s3,"s3://crabby-images/2dfaf/2dfaf1e43ac2fb6eefab67b5db3f78a8ec2082fe" alt=""
Now choose Pixels Per Unit: 16.
data:image/s3,"s3://crabby-images/b97bd/b97bda85fac497befaa78f45d4ee252cd2ddfede" alt=""
This way, the elements will fit the screen size.
data:image/s3,"s3://crabby-images/9f153/9f15315f865f568dca310d5a014bdb88192e356f" alt=""
data:image/s3,"s3://crabby-images/dcda1/dcda1869d3b0ea466fe645d8fc18f277ea25d855" alt=""