// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen // SPDX-FileCopyrightText: Copyright 2008 Sandia Corporation // SPDX-License-Identifier: LicenseRef-BSD-3-Clause-Sandia-USGov /** * @class vtkTreeRingToPolyData * @brief converts a tree to a polygonal data * representing radial space filling tree. * * * This algorithm requires that the vtkTreeRingLayout filter has already * been applied to the data in order to create the quadruple array * (start angle, end angle, inner radius, outer radius) of bounds * for each vertex of the tree. */ #ifndef vtkTreeRingToPolyData_h #define vtkTreeRingToPolyData_h #include "vtkInfovisLayoutModule.h" // For export macro #include "vtkPolyDataAlgorithm.h" VTK_ABI_NAMESPACE_BEGIN class VTKINFOVISLAYOUT_EXPORT vtkTreeRingToPolyData : public vtkPolyDataAlgorithm { public: static vtkTreeRingToPolyData* New(); vtkTypeMacro(vtkTreeRingToPolyData, vtkPolyDataAlgorithm); void PrintSelf(ostream& os, vtkIndent indent) override; /** * The field containing quadruples of the form (start angle, end angle, * inner radius, outer radius) * representing the bounds of the rectangles for each vertex. * This field may be added to the tree using vtkTreeRingLayout. * This array must be set. */ virtual void SetSectorsArrayName(const char* name) { this->SetInputArrayToProcess(0, 0, 0, vtkDataObject::FIELD_ASSOCIATION_VERTICES, name); } ///@{ /** * Define a shrink percentage for each of the sectors. */ vtkSetMacro(ShrinkPercentage, double); vtkGetMacro(ShrinkPercentage, double); ///@} int FillInputPortInformation(int port, vtkInformation* info) override; protected: vtkTreeRingToPolyData(); ~vtkTreeRingToPolyData() override; double ShrinkPercentage; int RequestData(vtkInformation*, vtkInformationVector**, vtkInformationVector*) override; private: vtkTreeRingToPolyData(const vtkTreeRingToPolyData&) = delete; void operator=(const vtkTreeRingToPolyData&) = delete; }; VTK_ABI_NAMESPACE_END #endif