Sample Render using the custom Voronoi 3D Texture Node.
The following package contains all the material described in this tutorial: Custom_Hypershade_Nodes.zip.
This tutorial explains how to create your own HyperShade node. Shader development in 3Delight for Maya is very easy. As examples, we explain how to develop a simple voronoi noise as a Maya 3D Texture and a simple Lambert shader.
Main Components
To create a single node only compiled OSL shader is needed. Optionally, it is possible to add icons to have a better visual representation of the node inside Hyerpshade and the Outliner.
The following table shows where each component should be installed for a Maya 2015 package.
Component | Installation Environment Variable | Default Location |
---|---|---|
Compiled OSL shader path | _3DFM_USER_OSL_PATH | |
Icons | XBMLANGPATH | C:\Program Files\3Delight\maya\2015\icons |
Creating a Custom 3D Texture Node
After correctly providing the compiled OSL shader path, you will be able to render using the new texture as with any other Maya 3D Texture.
The Voronoi node viewed in the Create menu of the HyperShade
The Voronoi node viewed in the Node Editor. Note how place3dTexture
node is automatically supported.
Voronoi noise connected to the 3Delight Material.
The OSL Source Code
The Voronoi texture looks like a standard Open Shading Language function but with some optional metadata:
string maya_name
string maya_label
string maya_type
string maya_group
float maya_min
float maya_max
int maya_hidden
The source code for our voronoi texture follows. To use it as Maya HyperShade node, the shader should be compiled using oslc utility from the OSL package.
Adding Icons for the Outliner and Hypershade
You can add icons to both the Outliner and Hypershade (this applies to both texture nodes and shader nodes). The table below details the convention for creating the icons for our Voronoi Noise.
Outliner | HyperShade - Node Lister | HyperShade - Work Area | |
---|---|---|---|
Icon Resolution | 20 x 20 pixels | 32 x 32 pixels | 128 x 128 pixels (up to 512 x 512 pixels) |
Format | Transparent 24 bits PNG | Transparent 24 bits PNG | Transparent 24 bits PNG |
Naming Convention | "out_" + <node_type> + ".png" | "render_" + <node_type> + ".png" | <node_type> + ".png" |
Example | Note the transparent corners of the icon matching Maya |