You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

109 lines
3.4 KiB
C

/*=========================================================================
Program: Visualization Toolkit
Module: vtkOpenGLRenderPass.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkOpenGLRenderPass
* @brief Abstract render pass with shader modifications.
*
*
* Allows a render pass to update shader code using a new virtual API.
*/
#ifndef vtkOpenGLRenderPass_h
#define vtkOpenGLRenderPass_h
#include "vtkRenderPass.h"
#include "vtkRenderingOpenGL2Module.h" // For export macro
#include <string> // For std::string
class vtkAbstractMapper;
class vtkInformationObjectBaseVectorKey;
class vtkProp;
class vtkShaderProgram;
class vtkOpenGLVertexArrayObject;
class VTKRENDERINGOPENGL2_EXPORT vtkOpenGLRenderPass : public vtkRenderPass
{
public:
vtkTypeMacro(vtkOpenGLRenderPass, vtkRenderPass);
void PrintSelf(ostream& os, vtkIndent indent) override;
/**
* Use vtkShaderProgram::Substitute to replace //VTK::XXX:YYY declarations in
* the shader sources. Gets called before other mapper shader replacements
* Return false on error.
*/
virtual bool PreReplaceShaderValues(std::string& vertexShader, std::string& geometryShader,
std::string& fragmentShader, vtkAbstractMapper* mapper, vtkProp* prop);
/**
* Use vtkShaderProgram::Substitute to replace //VTK::XXX:YYY declarations in
* the shader sources. Gets called after other mapper shader replacements.
* Return false on error.
*/
virtual bool PostReplaceShaderValues(std::string& vertexShader, std::string& geometryShader,
std::string& fragmentShader, vtkAbstractMapper* mapper, vtkProp* prop);
/**
* Update the uniforms of the shader program.
* Return false on error.
*/
virtual bool SetShaderParameters(vtkShaderProgram* program, vtkAbstractMapper* mapper,
vtkProp* prop, vtkOpenGLVertexArrayObject* VAO = nullptr);
/**
* For multi-stage render passes that need to change shader code during a
* single pass, use this method to notify a mapper that the shader needs to be
* rebuilt (rather than reuse the last cached shader. This method should
* return the last time that the shader stage changed, or 0 if the shader
* is single-stage.
*/
virtual vtkMTimeType GetShaderStageMTime();
/**
* Key containing information about the current pass.
*/
static vtkInformationObjectBaseVectorKey* RenderPasses();
/**
* Number of active draw buffers.
*/
vtkSetMacro(ActiveDrawBuffers, unsigned int);
vtkGetMacro(ActiveDrawBuffers, unsigned int);
protected:
vtkOpenGLRenderPass();
~vtkOpenGLRenderPass() override;
/**
* Call before rendering to update the actors' information keys.
*/
void PreRender(const vtkRenderState* s);
/**
* Call after rendering to clean up the actors' information keys.
*/
void PostRender(const vtkRenderState* s);
unsigned int ActiveDrawBuffers = 0;
private:
vtkOpenGLRenderPass(const vtkOpenGLRenderPass&) = delete;
void operator=(const vtkOpenGLRenderPass&) = delete;
};
#endif // vtkOpenGLRenderPass_h