MaterialX 1.39.2
|
Helper class for rendering generated OSL code to produce images. More...
#include <OslRenderer.h>
Public Member Functions | |
virtual | ~OslRenderer () |
Destructor. | |
Setup | |
void | initialize (RenderContextHandle renderContextHandle=nullptr) override |
Internal initialization required for program validation and rendering. | |
Rendering | |
void | createProgram (ShaderPtr shader) override |
Create OSL program based on an input shader. | |
void | createProgram (const StageMap &stages) override |
Create OSL program based on shader stage source code. | |
void | validateInputs () override |
Validate inputs for the compiled OSL program. | |
void | setSize (unsigned int width, unsigned int height) override |
Set the size for rendered image. | |
void | render () override |
Render OSL program to disk. | |
Utilities | |
ImagePtr | captureImage (ImagePtr image=nullptr) override |
Capture the current rendered output as an image. | |
Compilation settings | |
void | setOslCompilerExecutable (const FilePath &executableFilePath) |
Set the path to the OSL executable. | |
void | setOslIncludePath (const FileSearchPath &dirPath) |
Set the search locations for OSL include files. | |
void | setOslOutputFilePath (const FilePath &dirPath) |
Set the location where compiled OSL files will reside. | |
void | setShaderParameterOverrides (const StringVec ¶meterOverrides) |
Set shader parameter strings to be added to the scene XML file. | |
void | setEnvShaderParameterOverrides (const StringVec ¶meterOverrides) |
Set shader parameter strings to be added to the scene XML file. | |
void | setOslShaderOutput (const string &outputName, const string &outputType) |
Set the OSL shader output. | |
void | setOslTestShadeExecutable (const FilePath &executableFilePath) |
Set the path to the OSL shading tester. | |
void | setOslTestRenderExecutable (const FilePath &executableFilePath) |
Set the path to the OSL rendering tester. | |
void | setOslTestRenderSceneTemplateFile (const FilePath &templateFilePath) |
Set the XML scene file to use for testrender. | |
void | setOslShaderName (const string &shaderName) |
Set the name of the shader to be used for the input XML scene file. | |
void | setOslUtilityOSOPath (const FilePath &dirPath) |
Set the search path for dependent shaders (.oso files) which are used when rendering with testrender. | |
void | useTestRender (bool useTestRender) |
Used to toggle to either use testrender or testshade during render validation By default testshade is used. | |
void | setRaysPerPixelLit (int rays) |
Set the number of rays per pixel to be used for lit surfaces. | |
void | setRaysPerPixelUnlit (int rays) |
Set the number of rays per pixel to be used for unlit surfaces. | |
void | compileOSL (const FilePath &oslFilePath) |
Compile OSL code stored in a file. | |
Public Member Functions inherited from ShaderRenderer | |
void | setCamera (CameraPtr camera) |
Set the camera. | |
CameraPtr | getCamera () const |
Return the camera. | |
void | setImageHandler (ImageHandlerPtr imageHandler) |
Set the image handler used by this renderer for image I/O. | |
ImageHandlerPtr | getImageHandler () const |
Return the image handler. | |
void | setLightHandler (LightHandlerPtr lightHandler) |
Set the light handler used by this renderer for light bindings. | |
LightHandlerPtr | getLightHandler () const |
Return the light handler. | |
void | setGeometryHandler (GeometryHandlerPtr geometryHandler) |
Set the geometry handler. | |
GeometryHandlerPtr | getGeometryHandler () const |
Return the geometry handler. | |
virtual void | updateUniform (const string &name, ConstValuePtr value) |
Update the program with value of the uniform. | |
Static Public Member Functions | |
static OslRendererPtr | create (unsigned int width=512, unsigned int height=512, Image::BaseType baseType=Image::BaseType::UINT8) |
Create an OSL renderer instance. | |
Static Public Attributes | |
static string | OSL_CLOSURE_COLOR_STRING |
Color closure OSL string. | |
Protected Member Functions | |
void | shadeOSL (const FilePath &dirPath, const string &shaderName, const string &outputName) |
Shade using OSO input file. | |
void | renderOSL (const FilePath &dirPath, const string &shaderName, const string &outputName) |
Render using OSO input file. | |
OslRenderer (unsigned int width, unsigned int height, Image::BaseType baseType) | |
Constructor. | |
Protected Member Functions inherited from ShaderRenderer | |
ShaderRenderer (unsigned int width, unsigned int height, Image::BaseType baseType, MatrixConvention matrixConvention=MatrixConvention::OpenGL) | |
Additional Inherited Members | |
Public Types inherited from ShaderRenderer | |
enum class | MatrixConvention { OpenGL = 0 , Metal = 1 } |
Viewing API matrix conventions designation (default to OpenGL). | |
using | StageMap = StringMap |
A map with name and source code for each shader stage. | |
Protected Attributes inherited from ShaderRenderer | |
unsigned int | _width |
unsigned int | _height |
Image::BaseType | _baseType |
MatrixConvention | _matrixConvention |
CameraPtr | _camera |
ImageHandlerPtr | _imageHandler |
GeometryHandlerPtr | _geometryHandler |
LightHandlerPtr | _lightHandler |
Helper class for rendering generated OSL code to produce images.
The main services provided are:
Capture the current rendered output as an image.
Reimplemented from ShaderRenderer.
void compileOSL | ( | const FilePath & | oslFilePath | ) |
Compile OSL code stored in a file.
Will throw an exception if an error occurs.
oslFilePath | OSL file path. |
|
overridevirtual |
Create OSL program based on shader stage source code.
stages | Map of name and source code for the shader stages. |
Reimplemented from ShaderRenderer.
|
overridevirtual |
Create OSL program based on an input shader.
A valid executable and include path must be specified before calling this method. setOslCompilerExecutable(), and setOslIncludePath().
Additionally setOslOutputFilePath() should be set to allow for output of .osl and .oso files to the appropriate path location to be used as input for render validation.
If render validation is not required, then the same temporary name will be used for all shaders validated using this method.
shader | Input shader |
Reimplemented from ShaderRenderer.
|
overridevirtual |
Internal initialization required for program validation and rendering.
An exception is thrown on failure. The exception will contain a list of initialization errors.
Reimplemented from ShaderRenderer.
|
overridevirtual |
Render OSL program to disk.
This is done by using either "testshade" or "testrender". Currently only "testshade" is supported.
Usage of both executables requires compiled source (.oso) files as input. A shader output must be set before running this test via the setOslOutputName() method to ensure that the appropriate .oso files can be located.
Reimplemented from ShaderRenderer.
|
protected |
Render using OSO input file.
Will throw an exception if an error occurs.
dirPath | Path to location containing input .oso file. |
shaderName | Name of OSL shader. A corresponding .oso file is assumed to exist in the output path folder. |
outputName | Name of OSL shader output to use. |
|
inline |
Set shader parameter strings to be added to the scene XML file.
These strings will set parameter overrides for the shader.
|
inline |
Set the path to the OSL executable.
Note that it is assumed that this references the location of the oslc executable.
executableFilePath | Path to OSL compiler executable |
|
inline |
Set the search locations for OSL include files.
dirPath | Include path(s) for the OSL compiler. This should include the path to stdosl.h. |
|
inline |
Set the location where compiled OSL files will reside.
dirPath | Path to output location |
|
inline |
Set the name of the shader to be used for the input XML scene file.
The value is used to replace the shader% token in the file.
shaderName | Name of shader |
|
inline |
Set the OSL shader output.
This is used during render validation if "testshade" or "testrender" is executed. For testrender this value is used to replace the shader_output% token in the input scene file.
outputName | Name of shader output |
outputType | The MaterialX type of the output |
|
inline |
Set the path to the OSL rendering tester.
Note that it is assumed that this references the location of the "testrender" executable.
executableFilePath | Path to OSL "testrender" executable |
|
inline |
Set the XML scene file to use for testrender.
This is a template file with the following tokens for replacement:
templateFilePath | Scene file name |
|
inline |
Set the path to the OSL shading tester.
Note that it is assumed that this references the location of the "testshade" executable.
executableFilePath | Path to OSL "testshade" executable |
|
inline |
Set the search path for dependent shaders (.oso files) which are used when rendering with testrender.
dirPath | Path to location containing .oso files. |
|
inline |
Set shader parameter strings to be added to the scene XML file.
These strings will set parameter overrides for the shader.
|
overridevirtual |
Set the size for rendered image.
Reimplemented from ShaderRenderer.
|
protected |
Shade using OSO input file.
Will throw an exception if an error occurs.
dirPath | Path to location containing input .oso file. |
shaderName | Name of OSL shader. A corresponding .oso file is assumed to exist in the output path folder. |
outputName | Name of OSL shader output to use. |
|
inline |
Used to toggle to either use testrender or testshade during render validation By default testshade is used.
useTestRender | Indicate whether to use testrender. |
|
overridevirtual |
Validate inputs for the compiled OSL program.
Note: Currently no validation has been implemented.
Reimplemented from ShaderRenderer.