Packing normal maps into sprite sheets
What you are going to learn:
- Pack normal maps into sprite sheets
- Create sprite and normal map textures with identical layout
Most game engines that support dynamic lighting and sprite sheets — e.g. Unity — require the normal maps to be packed in the same way as the sprites.
The reason is simple: The OpenGL shaders are fed with one set of coordinates and 2 textures. Using a different layout would require handling additional coordinates.
There are two obvious ways to accomplish the goal:
Packing the sheets first, then generate the normal maps on the whole sprite sheet sounds like a good idea — but it is not:
- You have to re-generate the whole normal maps each time a single sprite changes.
- You can't re-distribute the sprites across your sprite sheets.
- Selecting different normal map generator parameters for each sprite is hard.
- Sprites rotated during the packing process need to be treated separately.
This way has several advantages:
- Re-distribute sprites across your sheets is no problem.
- Changes to a sprite's normal map are a local change.
- It's easy to create optimized sheets for different resolutions & target devices.
TexturePacker implements a normal map packing mode. You can download TexturePacker here:
Depending on the file organization in your project, it's just adding the normal maps and setting the check mark Normal maps/Pack with same layout:
In the sprite list on the left, the file names of normal maps are displayed in blue text color. Sprites with corresponding normal maps are marked with a blue "N". Hover your mouse cursor over it to view a tooltip with the file name of the attached normal map.
Pressing Publish creates a normal map sheet in the same directory as your sprite sheet, using the same data format and the file name suffix _n.
TexturePacker's Normal maps/Auto-detect mode should in most cases do the work. You can override the auto-detection in cases where it does not work as expected - see Overriding auto-detection.
There are two common layouts for the folder structure, TexturePacker can handle both of them:
- Sprites and normal maps in different folders
Sprites and normal maps both use the same name, but are separated by a folder. If you are working with sub-folders, you can either replicate the whole folder structure for the normal maps or keep them in the same tree using local normal map folders.
- Sprites and normal maps in the same folder using a suffix
The exact suffix does not matter - it's just important that you choose the same suffix for all normal maps.
Adding the normal maps is easy: Just drag & drop them into TexturePacker.
TexturePacker matches the normal maps and sprites based on the longest common file name part.
The simplest approach is to keep everything within the same main folder and add it as a smart folder. TexturePacker will automatically regenerate the sprite and normal map sheets whenever any of the images change.
Detecting normal maps is heuristic based. You can disable it in case it does not work with your normal maps.
Override settings are available after disabling Normal maps/Auto-detect:
Use the Path filter if you are keeping your normals in separated folders. All sprites under a folder path containing the filter expression are treated as normal maps.
Use the Normal map suffix if you are using a suffix for your normal maps.
TexturePacker's settings for Trim mode, Extrude and Padding all work with the normal maps.