When creating textures for use in a 3D application or game, sometimes it’s necessary to add finer detail, such as a bump map or normal map. Normal maps fake the lighting on textures to create additional detail, without adding more polygons.
For normals, I figured you had to always rely on a 3rd party application such as CrazyBump. While CrazyBump is a great piece of software, I hadn’t realized it was already possible using the popular photo-editing software, Photoshop. You will need at least Photoshop version CC 2014.1 for this to work.
Open Texture in Photoshop
For this example, I’m going to be using a leather texture I found on textures.com:
Fire up Photoshop and switch to the 3D Workspace:
Open the texture you want to create a bump map for. In the 3D panel, select Mesh From Preset, and choose a shape:
I like to use a Sphere, but it doesn’t really matter. Click Create. Some kind of magic happens inside Photoshop and it creates a scene with your texture loaded onto an object.
In the 3D panel, you’ll see an object name with _Material. Click that:
Create the Normal Map
The Properties panel changes to reflect options corresponding to the material properties. Right now our texture is loaded into the Diffuse channel. There’s a nice little button at the bottom labeled Normal. Click that and select Generate Normals From Diffuse…
There’s a nice little preview of your shape, and you can adjust Contrast Details and all that fun stuff. Click OK. Your normal map is created and applied to the shape.
Note: If Photoshop freezes up, you can also try this method:
1) Open texture in Photoshop as you would normally any image. Make sure the image mode is set to RGB. (Having tried with Greyscale, it would freeze up again.)
2) Choose Filter → 3D → Generate Normal Map…
3) Adjust your map as necessary (I left my to default). Click OK.
4) Save your file as PNG (not sure if it really matters). You’re done!
To save the map out of Photoshop, click on the Normal button again in the Properties panel, and this time select Edit Texture…