Scripted Bake Map Plug-ins

NEW in 3ds Max 2023:

Scripted Common Bake Map plug-ins extend the BakeToTextureMap and are owned by it. These plug-ins provide a unified view of a bake element that from a users's point of view looks the same for all renderers. The renderer-specific logic for each supported renderer is held in a companion CommonBakeMapOperator, which sets up the bake environment and specifies the actual bake element used.

The default Common Bake Maps shipped with 3ds Max are located in $startupScripts/BTT, and they are a good place to look for examples of how to implement this type of plug-in.

A scripted Common Bake Map plug-in is declared by specifying the <superclass> as CommonBakeMap.

Common Bake Map plug-ins implement a special extended user interface, indicated by extendedUi: true in the rollout description. This UI uses Qt instead of legacy Win32 as the underlying UI framework, and provides access to extended Qt widget properties and layouts. See Bake To Texture Rollout Controls for more information.

Note:

The Extended UI is intended for use only with Common Bake Map plug-ins, and is not supported for any other type of rollout.

For an example see Scripted Bake To Texture plug-in Example

CommonBakeMap Class

The following optional keywords can be used in a CommonBakeMap declaration:

tooltTip : string

Defines a tooltip string to display when the mouse hovers over the bake map in the Bake To Texture treeview.

useGamma : bool

Indicates whether the common bake map should present gamma settings in its UI.

backgroundColor : point3

Specifies the default background color of the baked image.

CommonBakeMapOperator Class

The CommonBakeMapOperator plug-in class is a renderer-specific handler that initializes and de-initializes the bake environment for a map.

Keywords

The following are mandatory keywords in the CommonBakeMapOperator declaration:

commonMapClassID : 2 element array

The class ID of the CommonBakeMap to which this bake map operator belongs to.

rendererClassID : 2 element array

The renderer class ID for which this bake map operator does bake operations.

The following is an optional keyword:

bakeElementClassID : 2 element array

The class ID of the bake element used in the baking process. The bake element can be either be defined statically via keyword on the plugin description level, or if the bake element is depended on by some operator internal logic it can also be provided dynamically via the bakeElementClassID() callback. This gets called before the baking process if no bakeElementClassID has been defined as a plugin class keyword.

Properties

The following properties are available on the CommonBakeMapOperator class:

bttMap : BakeToTextureMap : Read only

The bake to texture map to which this bake operator refers to. It gives you access to the general bake map interface, including its parameters.

commonMap : MAXWrapperObject : Read only

The common bake map to which this bake operator belongs to. The object reference gives you access to the parameters defined by the common bake map.

Event Callbacks

preBake( bakeElem : BakeElementProperties) : void

This callback is called right before the baking process begins. This can be used to do renderer- and map- specific setup of the baking environment. The parameter bakeElement is an instance of the bake element used for baking.

postBake() : void

This callback is called when the baking process is finished. This can be used to reset the changes made in the preBake callback.

requireSceneChange() : bool

Called from BTT before the baking to group the maps following their require scene change property. If the map returns true it will still be grouped with maps of same type with same parameters.

bakeElementClassID() : 2 element array

The class ID of the bake element which is used for the baking process. If no bake element has been defined via keyword on the plugin description level, then you must implement the dynamic callback bakeElementClassID . This gets called before the baking process so that Bake To Texture knows which bake element it should create.