Render Baking#

Cycles shaders and lighting can be baked to image textures. This has a few different purposes, most commonly:

  • Baking textures like base color or normal maps for export to game engines.

  • Baking ambient occlusion or procedural textures, as a base for texture painting or further edits.

  • Creating light maps to provide global illumination or speed up rendering in games.

Setup#

Baking requires a mesh to have a UV map, and either a Color Attribute or an Image Texture node with an image to be baked to. The Active Image Texture node or Color Attribute is used as the baking target.

Use Render Bake in intensive light/shadow solutions, such as AO or soft shadows from area lights. If you bake AO for the main objects, you will not have to enable it for the full render, saving render time. Cycles uses the render settings (samples, bounces, ...) for baking. This way the quality of the baked textures should match the result you get from the rendered scene.

Settings#

Reference

Panel:

Render ‣ Bake

Bake

Perform the baking operation.

Bake from Multires

Bake directly from multires object.

Bake Type

Type of pass to bake.

Combined:

Bakes all materials, textures, and lighting except specularity. The passes that contribute to the combined pass can be toggled individually to form the final map.

Ambient Occlusion:

Bakes ambient occlusion as specified in the World panels. Ignores all lights in the scene.

Shadow:

Bakes shadows and lighting.

Normal:

Bakes normals to an RGB image.

UV:

Mapped UV coordinates, used to represent where on a mesh a texture gets mapped too. This is represented through the red and green channels of the image, the blue channel is encoded with a constant value of 1 but does not hold any information.

Roughness:

Bakes the roughness pass of a material.

Emit:

Bakes Emission, or the Glow color of a material.

Environment:

Bakes the environment (i.e. the world surface shader defined for the scene) onto the selected object(s) as seen by rays cast from the world origin.

Diffuse:

Bakes the diffuse pass of a material.

Glossy:

Bakes the glossiness pass of a material.

Transmission:

Bakes the transmission pass of a material.

View From

Source of reflection ray directions.

Above Surface:

Cast rays from above the surface.

Active Camera:

Use the active camera's position to cast rays.

Influence#

Combined

Lighting
Direct

Add direct lighting contribution.

Indirect

Add indirect lighting contribution.

Contributions
Diffuse

Add diffuse contribution.

Glossy

Add glossy contribution.

Transmission

Add transmission contribution.

Ambient Occlusion

Add ambient occlusion contribution.

Emit

Add emission contribution.

Diffuse, Glossy, Transmission

Contributions
Direct

See above.

Indirect

See above.

Color

Colorize the pass.

  • If only Color is selected you get the pass color, which is a property of the surface and independent of sampling refinement.

  • If Color is not selected, you get the direct and/or indirect contributions in gray-scale.

  • If Color and either Direct or Indirect are selected, you get the direct and/or indirect contributions colored.

Normal

Space

Normals can be baked in different spaces:

For materials, the same spaces can be chosen in the image texture options next to the existing Normal Map setting. For correct results, the setting here should match the setting used for baking.

Object:

Normals in object coordinates, independent of object transformation, but dependent on deformation.

Tangent:

Normals in tangent space coordinates, independent of object transformation and deformation. This is the default, and the right choice in most cases, since then the normal map can be used for animated objects too.

Swizzle R, G, B

Axis to bake into the red, green and blue channel.

Selected to Active#

Bake shading on the surface of selected objects to the active object. The rays are cast from the low-poly object inwards towards the high-poly object. If the high-poly object is not entirely involved by the low-poly object, you can tweak the rays start point with Max Ray Distance or Extrusion (depending on whether or not you are using cage). For even more control you can use a Cage Object.

Catatan

There is a CPU fixed memory footprint for every object used to bake from. In order to avoid crashes due to lack of memory, the high-poly objects can be joined before the baking process.

Cage

Cast rays to active object from a cage. A cage is a ballooned-out version of the low-poly mesh created either automatically (by adjusting the ray distance) or manually (by specifying an object to use). When not using a cage the rays will conform to the mesh normals. This produces glitches on the edges, but it is a preferable method when baking into planes to avoid the need of adding extra loops around the edges.

Cage Object

Object to use as cage instead of calculating the cage from the active object with the Cage Extrusion.

Cage Extrusion

Distance to use for the inward ray cast when using Selected to Active and Cage. The inward rays are cast from a version of the active object with disabled Edge Split Modifiers. Hard splits (e.g. when the Edge Split Modifier is applied) should be avoided because they will lead to non-smooth normals around the edges.

Catatan

When the base mesh extruded does not give good results, you can create a copy of the base mesh and modify it to use as a Cage. Both meshes need to have the same Topology (number of faces and face order).

Max Ray Distance

Distance to use for the inward ray cast when using Selected to Active. Ray distance is only available when not using Cage.

Output#

Target

Where to output the baked map.

Image Textures:

Bake to the image data-block associated with the Active Image Texture node.

Clear Image

If selected, clears the image before baking render.

Color Attributes:

Bake to the Active Color Attributes layer on the active mesh. Note, the active object must be a mesh as other object types do not have Color Attributes.

Margin#

When baking to images, by default a margin is generated around UV "islands". This is important to avoid discontinuities at UV seams, due to texture filtering and mip-mapping.

Type

Method to generate the margin.

Extend:

Extend border pixels outwards.

Adjacent Faces:

Fill margin using pixels from adjacent faces across UV seams.

Size

Size of the margin in pixels.