A downloadable aseprite extension for Windows, macOS, and Linux

Download NowName your own price

If you're a game developer or if you've ever experimented with Normal Maps,  you might've noticed that there isn't a really good way to test them directly from within Aseprite. This extension aims to solve exactly this issue!

Normal Shading allows you to create realistic lighting for your textures in  Aseprite using the Blinn-Phong Reflection Model.

The menu can be found under Edit > FX > Shading

By using a diffuse texture, a normal texture & a light direction, a new image is created on the Output Layer. Your original textures are unaffected.

Features:

  • Directional Lighting using a diffuse texture & a normal texture
  • Ambient Lighting
  • Support for seamless textures and custom sprites
  • Specular Highlighting (with & without a specular Map)
  • Works with multiple frames/cells

*All calculations are done per pixel on the CPU. Thus, performance will get a lot worse the larger your texture gets. For the future, I'd like to get Aseprite to utilize the GPU in the future, but as of now I couldn't find a way to do it

How It Works:

0. Installation

Aseprite Extensions are installed by either double-clicking the *.aseprite-extension file or via Edit > Preferences > Extensions > Add Extension

1. Creating Normal Maps

Normal Map is a special texture that tells which direction each pixel of the regular texture is facing. In Aseprite, you can select the Normal Color Wheel in the Options Menu directly above the Color Palette. Using this Color Wheel, the further you pick a color on there in 1 direction, the more the pixel is pointing in that direction. 

Now what you need to do is paint the normal map on a new layer.

Check out my Normal Toolkit Extension for auto-generating normal maps and other helpful features!

2. Using the Extension

Navigate to Edit > FX > Normal Mapping (Shading) to open the extension menu. Then enter the name of the Diffuse Layer (your texture) and your Normal Layer. The output will be generated on the Output Layer. If you don't have one yet, it will be automatically generated.  

Then, set your Light Direction to the direction you want the light to be coming from. You can enable 'Color Wheel Controls', this way you can pick the Light Direction via the Normal Map Color Wheel.

(Optional) If you want, you can add an ambient color to your texture.

Now press 'Calculate' and you should see a new version of your texture with lighting and shadows generated by using the normal map you created.

3. Specular Highlighting (Optional)

Specular Highlights are light reflected by the surface texture. The reflection is determined by the angle of the Light and the angle of the camera. Thus, the angle from which we see the texture stays the same because we can't change the angle of the Camera in Aseprite. Changing the slider values does affect the view vector of an imaginary camera the algorithm uses for specular calculation.

Enabling Specular Highlighting will make the material appear more reflective. 

A Specular Map is a grayscale texture that allows you to control the reflectiveness of your diffuse texture. The brighter the pixel is, the more light it will reflect e.g. if your texture has a mixture of wood and metal, you could pick brighter grays for the metal parts to make it shinier.

You can also use a random noise texture to create a simple wetness effect.

*Enabling Specular Highlighting will impact performance, especially when increasing the specular hardness

If you have any questions, feel free to leave a comment or send me a message on Twitter


StatusIn development
CategoryTool
PlatformsWindows, macOS, Linux
Rating
Rated 5.0 out of 5 stars
(8 total ratings)
AuthorMooosik
TagsAseprite, normal-map, Pixel Art, Shaders, tool

Download

Download NowName your own price

Click download now to get access to the following files:

Normal Shading v.1.2.1.aseprite-extension 5.1 kB
Normal Shading v.1.1.0.aseprite-extension 4.6 kB
Normal Shading v.1.0.0.aseprite-extension 4 kB

Development log

Comments

Log in with itch.io to leave a comment.

Hey, when I try to use it says "Shading.lua:143: attempt to index a nil value". how do I fix it? 

Hey, I've looked into it, 

it turns out this happens if the cell of a frame on your diffuse, normal, or specular layer is empty. 

I've uploaded an updated version that addresses this issue (v1.2.1). 

Thank you for bringing this to my attention!

This is for shading, right? Because I can't seem to generate normal maps from this. Do I generate my normals from the normal toolkit?

Hi! Yes, this extension is meant to be used for testing & using normal maps. You can generate Normal Maps using the Normal Toolkit: https://mooosik.itch.io/normal-toolkit 

Thank you!  The only setback is having to navigate within two windows, one to generate, one for shading. Despite that, very satisfied with the results I'm getting. 

(1 edit)

Well, I've been playing around with this script a bit and I can say this: Good job! But  constantly creating Normal Maps can be very tedious, is it possible to automate this somehow?

(+1)

Hey, thank you for the kind words!

There is a script by @ruccho on Twitter that can automatically generate normal maps for you https://twitter.com/ruccho_vector/status/1103488054604386305?s=20&t=Xdilx9SJhiyz...

Because said script does not feature any customizability I'm considering working on an advanced normal map creation tool next!