// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen // SPDX-License-Identifier: BSD-3-Clause /** * @class vtkImplicitHalo * @brief implicit function for an halo * * vtkImplicitHalo evaluates to 1.0 for each position in the sphere of a * given center and radius Radius*(1-FadeOut). It evaluates to 0.0 for each * position out the sphere of a given Center and radius Radius. It fades out * linearly from 1.0 to 0.0 for points in a radius from Radius*(1-FadeOut) to * Radius. * vtkImplicitHalo is a concrete implementation of vtkImplicitFunction. * It is useful as an input to * vtkSampleFunction to generate an 2D image of an halo. It is used this way by * vtkShadowMapPass. * @warning * It does not implement the gradient. */ #ifndef vtkImplicitHalo_h #define vtkImplicitHalo_h #include "vtkCommonDataModelModule.h" // For export macro #include "vtkImplicitFunction.h" VTK_ABI_NAMESPACE_BEGIN class VTKCOMMONDATAMODEL_EXPORT vtkImplicitHalo : public vtkImplicitFunction { public: /** * Center=(0.0,0.0,0.0), Radius=1.0, FadeOut=0.01 */ static vtkImplicitHalo* New(); vtkTypeMacro(vtkImplicitHalo, vtkImplicitFunction); void PrintSelf(ostream& os, vtkIndent indent) override; ///@{ /** * Evaluate the equation. */ using vtkImplicitFunction::EvaluateFunction; double EvaluateFunction(double x[3]) override; ///@} /** * Evaluate normal. Not implemented. */ void EvaluateGradient(double x[3], double g[3]) override; ///@{ /** * Radius of the sphere. */ vtkSetMacro(Radius, double); vtkGetMacro(Radius, double); ///@} ///@{ /** * Center of the sphere. */ vtkSetVector3Macro(Center, double); vtkGetVector3Macro(Center, double); ///@} ///@{ /** * FadeOut ratio. Valid values are between 0.0 and 1.0. */ vtkSetMacro(FadeOut, double); vtkGetMacro(FadeOut, double); ///@} protected: vtkImplicitHalo(); ~vtkImplicitHalo() override; double Radius; double Center[3]; double FadeOut; private: vtkImplicitHalo(const vtkImplicitHalo&) = delete; void operator=(const vtkImplicitHalo&) = delete; }; VTK_ABI_NAMESPACE_END #endif