1
0
Fork 0
mirror of https://github.com/Ellpeck/TinyLifeWeb.git synced 2025-01-05 04:27:42 +01:00
TinyLifeWeb/docs/articles/creating_textures.md

43 lines
3.8 KiB
Markdown
Raw Normal View History

2021-09-08 20:49:32 +02:00
# Creating Textures
2023-06-28 19:16:26 +02:00
When creating textures, either for custom mods or to change the game's default textures, there are several things that you will have to look out for. This article provides some guidelines and explanations. Note that this article is not exhaustive, so don't hesitate to [let us know](https://link.tinylifegame.com/discordweb) if there's anything you're confused by!
2021-09-08 20:49:32 +02:00
2024-11-19 23:13:34 +01:00
## Composition and Colors
### General Notes
2022-10-27 12:06:28 +02:00
- Items that should be able to have color schemes applied to them in games should use a grayscale texture. The individual colors will then be applied to the grayscale texture when drawing.
- When making a mod, the layout, size or positioning of custom texture regions generally doesn't matter. There are some exceptions to this, which will be noted in this article.
- Items that should be able to have multiple distinct color schemes applied (like a table with a stone surface but wooden legs) need to be split up into multiple layers, with each layer being colored by its corresponding color scheme. These layers need to be laid out **horizontally**, with the `n`th layer of the item being placed `n * width` pixels to the right of the base layer's position.
2021-09-08 20:49:32 +02:00
2024-11-19 23:13:34 +01:00
### Furniture
2022-10-27 12:06:28 +02:00
- Furniture items generally have four distinct directions they can be placed in if they're more complex, or just one or two if they have symmetry in one or both axes.
- Layers (see general notes) can also be used to determine which parts of a furniture item will be occluded by Tinies and which won't. This is useful, for example, for the backrests of chairs, which should be drawn above a Tiny when looking at them from behind.
![](../media/beds.png)
![](../media/counters.png)
2024-11-19 23:13:34 +01:00
### Clothes
2022-10-27 12:06:28 +02:00
- Clothes have multiple poses that they have to be compatible with, some of which have multiple animation frames. The ordering and positioning of these frames cannot be changed, so it's best to use the reference textures below for creating news clothes and hairstyles.
- Clothes have four rotations, which are laid out in a Right-Down-Left-Up fashion.
- When layers are laid out for clothes, each layer should contain the Right-Down-Left-Up ordering before the next layer is started.
- Different clothing types and age groups use different sets of poses, since some of them can be reused in different cases. For example, since all working poses use the same arm animations, tops only need one working animation.
2022-10-27 12:06:28 +02:00
- Hair, facial hair, accessories, head accessories and face accessories only use the four walking frames as well as the laying pose.
- Tops and arm accessories only use the four walking frames, the laying pose, the two working frames, and the four walking with arms out frames. Tops for babies additionally include a frame for sitting.
- Pants and shoes only use the four walking frames, the sitting pose, and the sitting on ground pose. Pants and shoes for babies additionally include frames for sleeping and standing.
- Babies don't use the walking with arms out frames at all.
2022-10-27 12:06:28 +02:00
![](../media/person.png)
## Color Schemes
- A color scheme is essentially a set of colors, one of which can be chosen by the player to be assigned to a grayscale layer.
- The game stores all of its color schemes in a texture where each row is a set of colors, one pixel for each color, which can be selected for an object or layer.
- The most up-to-date version of the game's color schemes can be found in the [ColorScheme class](xref:TinyLife.Utilities.ColorScheme).
![](../media/color_schemes.png)
2024-11-19 23:13:34 +01:00
## Isometric Layout
2024-11-19 23:15:59 +01:00
Community member [Gindew](https://linktr.ee/redgindew) has created a template that gives guidance on the isometric style that the game uses. You can download it as [an image](../media/iso_layout.png) or as [an Aseprite file](../media/iso_layout.aseprite).
2024-11-19 23:13:34 +01:00
Here is an enlarged version of the template so you can get a better look:
![](../media/iso_layout_large.png)