VTK-m  2.2
MapperQuad.h
Go to the documentation of this file.
1 //============================================================================
2 // Copyright (c) Kitware, Inc.
3 // All rights reserved.
4 // See LICENSE.txt for details.
5 //
6 // This software is distributed WITHOUT ANY WARRANTY; without even
7 // the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
8 // PURPOSE. See the above copyright notice for more information.
9 //============================================================================
10 #ifndef vtk_m_rendering_MapperQuad_h
11 #define vtk_m_rendering_MapperQuad_h
12 
13 #include <vtkm/cont/ColorTable.h>
14 #include <vtkm/rendering/Camera.h>
15 #include <vtkm/rendering/Mapper.h>
16 
17 #include <memory>
18 
19 namespace vtkm
20 {
21 namespace rendering
22 {
23 
32 {
33 public:
34  MapperQuad();
35 
36  ~MapperQuad();
37 
38  void SetCanvas(vtkm::rendering::Canvas* canvas) override;
39  virtual vtkm::rendering::Canvas* GetCanvas() const override;
40 
41  void SetCompositeBackground(bool on);
42  vtkm::rendering::Mapper* NewCopy() const override;
43 
44 private:
45  struct InternalsType;
46  std::shared_ptr<InternalsType> Internals;
47 
48  struct RenderFunctor;
49 
50  void RenderCellsImpl(const vtkm::cont::UnknownCellSet& cellset,
51  const vtkm::cont::CoordinateSystem& coords,
52  const vtkm::cont::Field& scalarField,
53  const vtkm::cont::ColorTable& colorTable,
54  const vtkm::rendering::Camera& camera,
55  const vtkm::Range& scalarRange,
56  const vtkm::cont::Field& ghostField) override;
57 };
58 }
59 } //namespace vtkm::rendering
60 
61 #endif //vtk_m_rendering_MapperQuad_h
vtkm
Groups connected points that have the same field value.
Definition: Atomic.h:19
vtkm::cont::ColorTable
Color Table for coloring arbitrary fields.
Definition: cont/ColorTable.h:89
VTKM_RENDERING_EXPORT
#define VTKM_RENDERING_EXPORT
Definition: vtkm_rendering_export.h:44
vtkm::cont::UnknownCellSet
A CellSet of an unknown type.
Definition: UnknownCellSet.h:48
ColorTable.h
vtkm::cont::CoordinateSystem
Manages a coordinate system for a DataSet.
Definition: CoordinateSystem.h:30
vtkm::rendering::Mapper
Converts data into commands to a rendering system.
Definition: Mapper.h:29
vtkm::rendering::Canvas
Represents the image space that is the target of rendering.
Definition: Canvas.h:35
vtkm::cont::Field
A Field encapsulates an array on some piece of the mesh, such as the points, a cell set,...
Definition: Field.h:31
vtkm::rendering::MapperQuad
A mapper that renderers quad faces from a cell set via ray tracing.
Definition: MapperQuad.h:31
vtkm::rendering::MapperQuad::Internals
std::shared_ptr< InternalsType > Internals
Definition: MapperQuad.h:45
Camera.h
vtkm::rendering::Camera
Specifies the viewport for a rendering.
Definition: Camera.h:37
Mapper.h
vtkm::Range
Represent a continuous scalar range of values.
Definition: Range.h:31