2016-02-09 13:59:26 +00:00
|
|
|
//============================================================================
|
|
|
|
// Copyright (c) Kitware, Inc.
|
|
|
|
// All rights reserved.
|
|
|
|
// See LICENSE.txt 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.
|
|
|
|
//
|
|
|
|
// Copyright 2015 Sandia Corporation.
|
|
|
|
// Copyright 2015 UT-Battelle, LLC.
|
|
|
|
// Copyright 2015 Los Alamos National Security.
|
|
|
|
//
|
|
|
|
// Under the terms of Contract DE-AC04-94AL85000 with Sandia Corporation,
|
|
|
|
// the U.S. Government retains certain rights in this software.
|
|
|
|
//
|
|
|
|
// Under the terms of Contract DE-AC52-06NA25396 with Los Alamos National
|
|
|
|
// Laboratory (LANL), the U.S. Government retains certain rights in
|
|
|
|
// this software.
|
|
|
|
//============================================================================
|
|
|
|
#ifndef vtk_m_rendering_Plot_h
|
|
|
|
#define vtk_m_rendering_Plot_h
|
|
|
|
|
|
|
|
#include <vtkm/rendering/SceneRenderer.h>
|
2016-04-18 20:42:59 +00:00
|
|
|
#include <vtkm/rendering/View.h>
|
2016-02-09 13:59:26 +00:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace vtkm {
|
|
|
|
namespace rendering {
|
|
|
|
|
|
|
|
class Plot
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//Plot(points, cells, field, colortable) {}
|
|
|
|
VTKM_CONT_EXPORT
|
|
|
|
Plot(const vtkm::cont::DynamicCellSet &cs,
|
|
|
|
const vtkm::cont::CoordinateSystem &c,
|
|
|
|
const vtkm::cont::Field &f,
|
|
|
|
const vtkm::rendering::ColorTable &ct) :
|
|
|
|
cellSet(cs), coords(c), scalarField(f), colorTable(ct)
|
|
|
|
{
|
|
|
|
f.GetBounds(scalarBounds,
|
|
|
|
VTKM_DEFAULT_DEVICE_ADAPTER_TAG());
|
2016-04-15 19:24:23 +00:00
|
|
|
c.GetBounds(spatialBounds,
|
|
|
|
VTKM_DEFAULT_DEVICE_ADAPTER_TAG());
|
2016-02-09 13:59:26 +00:00
|
|
|
}
|
|
|
|
|
2016-02-10 22:19:00 +00:00
|
|
|
template<typename SceneRendererType, typename SurfaceType>
|
2016-02-09 13:59:26 +00:00
|
|
|
VTKM_CONT_EXPORT
|
2016-02-10 22:19:00 +00:00
|
|
|
void Render(SceneRendererType &sr,
|
2016-04-18 20:42:59 +00:00
|
|
|
SurfaceType &, //surface
|
|
|
|
vtkm::rendering::View &view)
|
2016-02-09 13:59:26 +00:00
|
|
|
{
|
2016-02-10 22:19:00 +00:00
|
|
|
//??????
|
|
|
|
//feed surface into sr somehow??
|
2016-04-18 20:42:59 +00:00
|
|
|
//TODO: Get rid of surface.
|
|
|
|
sr.SetActiveColorTable(colorTable);
|
2016-02-09 13:59:26 +00:00
|
|
|
sr.RenderCells(cellSet, coords, scalarField,
|
2016-04-18 20:42:59 +00:00
|
|
|
colorTable, view, scalarBounds);
|
2016-02-09 13:59:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
vtkm::cont::DynamicCellSet cellSet;
|
|
|
|
vtkm::cont::CoordinateSystem coords;
|
|
|
|
vtkm::cont::Field scalarField;
|
|
|
|
vtkm::rendering::ColorTable colorTable;
|
|
|
|
|
|
|
|
vtkm::Float64 scalarBounds[2];
|
2016-04-15 19:24:23 +00:00
|
|
|
vtkm::Float64 spatialBounds[6];
|
2016-02-09 13:59:26 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}} //namespace vtkm::rendering
|
|
|
|
|
|
|
|
#endif //vtk_m_rendering_Plot_h
|