vtkCompositePainter.h 4.14 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*=========================================================================

  Program:   Visualization Toolkit
  Module:    vtkCompositePainter.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.

=========================================================================*/
// .NAME vtkCompositePainter - painter that can be inserted before any
// vtkDataSet painting chain to handle composite datasets.
// .SECTION Description
// vtkCompositePainter iterates over the leaves in a composite datasets.
// This painter can also handle the case when the dataset is not a composite
// dataset.

22 23
#ifndef vtkCompositePainter_h
#define vtkCompositePainter_h
24

25
#include "vtkRenderingOpenGLModule.h" // For export macro
26
#include "vtkPainter.h"
27 28
#include "vtkColor.h" // needed for vtkColor3d
#include <stack> //  needed for RenderBlockState.
29

30 31 32 33
class vtkCompositeDataDisplayAttributes;
class vtkInformationObjectBaseKey;
class vtkProperty;
class vtkRenderWindow;
34

35
class VTKRENDERINGOPENGL_EXPORT vtkCompositePainter : public vtkPainter
36 37 38
{
public:
  static vtkCompositePainter* New();
39
  vtkTypeMacro(vtkCompositePainter, vtkPainter);
40 41 42 43 44 45 46
  void PrintSelf(ostream& os, vtkIndent indent);

  // Description:
  // Get the output data object from this painter. The default implementation
  // simply forwards the input data object as the output.
  virtual vtkDataObject* GetOutput();

47 48 49 50 51 52 53 54 55 56 57 58
  // Description:
  // Key used to pass a vtkCompositeDataDisplayAttributes instance doing the
  // painter pipeline.
  static vtkInformationObjectBaseKey* DISPLAY_ATTRIBUTES();

  // Description:
  // Set/get the composite data set display attributes. If set, these attributes
  // can be used by the painter to control specific rendering attributes on a
  // per-block basis for a multi-block dataset.
  void SetCompositeDataDisplayAttributes(vtkCompositeDataDisplayAttributes *attributes);
  vtkGetObjectMacro(CompositeDataDisplayAttributes, vtkCompositeDataDisplayAttributes)

59 60 61 62 63 64 65 66 67
//BTX
protected:
  vtkCompositePainter();
  ~vtkCompositePainter();

  // Description:
  // Take part in garbage collection.
  virtual void ReportReferences(vtkGarbageCollector *collector);

68 69 70 71 72
  // Description:
  // Called before RenderInternal() if the Information has been changed
  // since the last time this method was called.
  virtual void ProcessInformation(vtkInformation* information);

73 74 75
  // Description:
  // Performs the actual rendering. Subclasses may override this method.
  // default implementation merely call a Render on the DelegatePainter,
76
  // if any. When RenderInternal() is called, it is assured that the
77 78
  // DelegatePainter is in sync with this painter i.e. UpdateDelegatePainter()
  // has been called.
79 80
  virtual void RenderInternal(vtkRenderer* renderer, vtkActor* actor,
    unsigned long typeflags, bool forceCompileOnly);
81

82 83 84 85 86 87 88 89 90 91 92 93 94 95 96
  class RenderBlockState
    {
  public:
    std::stack<bool> Visibility;
    std::stack<double> Opacity;
    std::stack<vtkColor3d> AmbientColor;
    std::stack<vtkColor3d> DiffuseColor;
    std::stack<vtkColor3d> SpecularColor;

    double RenderedOpacity;
    vtkColor3d RenderedAmbientColor;
    vtkColor3d RenderedDiffuseColor;
    vtkColor3d RenderedSpecularColor;
    };

97 98 99 100 101 102
  void RenderBlock(vtkRenderer *renderer,
                   vtkActor *actor,
                   unsigned long typeflags,
                   bool forceCompileOnly,
                   vtkDataObject *dobj,
                   unsigned int &flat_index,
103 104 105 106 107 108
                   RenderBlockState &state);

  // Description:
  // Overridden in vtkOpenGLCompositePainter to pass attributes to OpenGL.
  virtual void UpdateRenderingState(
    vtkRenderWindow*, vtkProperty*, RenderBlockState&) {}
109

110
  vtkDataObject* OutputData;
111
  vtkCompositeDataDisplayAttributes *CompositeDataDisplayAttributes;
112 113 114 115 116 117 118
private:
  vtkCompositePainter(const vtkCompositePainter&); // Not implemented.
  void operator=(const vtkCompositePainter&); // Not implemented.
//ETX
};

#endif