//============================================================================ // 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. //============================================================================ #include namespace vtkm { namespace rendering { Mapper::~Mapper() {} void Mapper::SetActiveColorTable(const vtkm::cont::ColorTable& colorTable) { constexpr vtkm::Float32 conversionToFloatSpace = (1.0f / 255.0f); vtkm::cont::ArrayHandle temp; { vtkm::cont::ScopedRuntimeDeviceTracker tracker(vtkm::cont::DeviceAdapterTagSerial{}); colorTable.Sample(1024, temp); } this->ColorMap.Allocate(1024); auto portal = this->ColorMap.WritePortal(); auto colorPortal = temp.ReadPortal(); for (vtkm::Id i = 0; i < 1024; ++i) { auto color = colorPortal.Get(i); vtkm::Vec4f_32 t(color[0] * conversionToFloatSpace, color[1] * conversionToFloatSpace, color[2] * conversionToFloatSpace, color[3] * conversionToFloatSpace); portal.Set(i, t); } } void Mapper::SetLogarithmX(bool l) { this->LogarithmX = l; } void Mapper::SetLogarithmY(bool l) { this->LogarithmY = l; } } }