VRayGLSLTex

This page provides information on the GLSL Map.


Overview

The VRayGLSLTex texture map can be used to load OpenGL Shading Language GLSL shaders (.frag, .glsl files), as well as V-Ray precompiled fragment shaders (.pfrag files), and render them directly with V-Ray. If the shader file describes a material (rather than a texture), the shader definition can be rendered by either assigning the texture map to the color slot of a VRayLightMtl material, or just by using the VRayGLSLMtl material.

Note that both VRayGLSLMtl and VRayGLSLTex share the same user interface. See the V-Ray GLSL page for more detailed description of the language and examples.

This texture map and material is the first stage of the V-Ray implementation of GLSL support. In this version, the shaders are compiled to byte code for a software virtual machine, which is then interpreted. Due to this run-time interpretation, GLSL shaders can be somewhat slower to render than V-Ray shaders written in C++. In future builds of V-Ray, shaders will be directly compiled to machine code for faster rendering. In the example shown here an example GLSL file has been used.

images/download/attachments/38571706/VRayGLSLMtl_out.png

UI Path

||Material Editor window|| > Material/Map Browser > Maps > V-Ray > VRayGLSLTex

General

The "General" rollout holds parameters that control common shader characteristics.

images/download/attachments/38571706/max2018_GLSLShader.PNG

shader file – Specifies the .glsl, .frag , or .pfrag file which contains the shader code. This button control also supports a context menu with the following options:

Clear – Unloads the current shader and restores the plug-in as if no shaders have been loaded.
Reset – Reloads the shader and resets its parameters to the default values.
Reload – Reloads the shader but keeps the current parameter values.
Open Containing Folder – Reveals the shader location in Explorer.
Open in External Editor – Opens the shader in an appropriate external text editor.
Open in Quick Shader – Opens the shader in the built-in text editor.
Recent Files – Holds a list of the recently loaded shaders and an option to clear the list.

refraction IOR – The refraction IOR of the shader.

incident IOR – The incident IOR value for the shader.

max ray depth – Specifies the maximum reflection/refraction depth for the shader.

animation time – Specifies the animation time for the shader.

show preview – Determines whether to render a shader preview in the material editor.

clamp shader result – Determines whether to force the result in the [0, Clamping limit ] range or not.

clamping limit – Specifies the upper clamp limit if Clamp shader result is enabled.

Export shader – Allows the user to save his shader file as a binary precompiled fragment shader file ( .pfrag ).

Compiler Output

The "Compiler Output" rollout holds shader compilation and manipulation result messages.

Quick Shader

The "Quick Shader" rollout allows for fast shader sketching inside the plug-in without the use of external files.

Enable – Activates the built-in text editor. Once enabled, place the original code inside the text area. Alternatively, start writing in the blank area your own code. If you have already loaded a shader in the material parameters, right-click on it and select Open in Quick Shader option. Another way to do this is to activate the text area and drag and drop the .glsl (.frag) file in there. It will load the code instantly.

Compile – Compiles the written shader, keeping the current shader parameters. To compile the shader and reset its parameters to default, hold the Shift button and then click Compile.

Right-clicking on the Quick Shader panel opens a context menu, implementing basic text editing functions. You can also Compile the code after doing changes or Compile and Reset Parameters, which affects the values of the parameters in the shader as well.

images/download/attachments/38571706/max2018_Next_QuickShader_ContextMenu.png

Parameters

Any additional shader-specific parameters (if any) are listed in this rollout.

Notes

  • Currently the VRayGLSLTex texture and VRayGLSLMtl are only available in 3ds Max 2011 and later.

  • For details on the V-Ray GPU support of VRayGLSLTex and VRayGLSLMtl, see the GLSL Support page.

References

Randi J. Rost et al, OpenGL Shading Language, second edition, Addison-Wesley, 2006

Lighthouse3D.com - a useful site that describes the basics of GLSL and has many shader examples
http://www.lighthouse3d.com/tutorials/glsl-tutorial/communication-opengl-shaders/