Signed Distance Fields 1.0
SDFHeart2 Class Reference

Euclidean signed distance field for a convex polygon. More...

#include <sdf.h>

Inheritance diagram for SDFHeart2:
SDFEuclidean2 SDFPrimitive2 SDFNode2

Public Member Functions

 SDFHeart2 (const Vector2 &, const double &)
 Create a convex primitive.
 
virtual ~SDFHeart2 ()
 Destructor.
 
double Signed (const Vector2 &) const
 Compute the signed Euclidean distance function.
 
virtual int Memory () const
 Return the size of a sub-tree.
 
virtual SDFNode2Copy () const
 Deep copy.
 
- Public Member Functions inherited from SDFEuclidean2
 SDFEuclidean2 ()
 Create an Euclidean primitive.
 
virtual ~SDFEuclidean2 ()
 Destructor.
 
- Public Member Functions inherited from SDFPrimitive2
 SDFPrimitive2 ()
 Create a primitive.
 
virtual ~SDFPrimitive2 ()
 Destructor.
 
virtual QString GetCostShader (PrimitiveManager *, std::list< QString > *, bool *) const
 Compute the GLSL code to compute the cost of a call to sdf.
 
virtual void ComputeCostSigned (const Vector2 &)
 Compute the number of reccursive calls to Signed().
 
- Public Member Functions inherited from SDFNode2
 SDFNode2 ()
 Create a generic node.
 
virtual ~SDFNode2 ()
 Destructor.
 
virtual Vector2 Gradient (const Vector2 &) const
 Compute the gradient of the field.
 
virtual bool Inside (const Vector2 &) const
 Check if a point is inside or outside.
 
virtual QString GetShader (PrimitiveManager *, std::list< QString > *, bool *=nullptr) const
 Compute the GLSL code to render the node.
 
virtual QString GetGradientShader (PrimitiveManager *, std::list< QString > *, bool *=nullptr) const
 Compute the GLSL code to compute the gradient the sdf.
 
virtual double K () const
 Return the Lipschitz constant of the node.
 
Box2 GetBox () const
 Return the bounding box of the node.
 
virtual int Nodes () const
 Compute the number of nodes in the sub-tree.
 

Protected Attributes

Vector2 c
 Center.
 
double r
 Radius.
 
- Protected Attributes inherited from SDFNode2
Box2 box = Box2::Infinity
 Box bounding the surface.
 
double k = 1.0
 Lipschitz constant.
 
int cost = 1
 Cost of the node.
 

Additional Inherited Members

- Static Protected Attributes inherited from SDFNode2
static constexpr double Epsilon = 0.01
 Small constant used for bounding volumes.
 

Detailed Description

Euclidean signed distance field for a convex polygon.

Constructor & Destructor Documentation

◆ SDFHeart2()

SDFHeart2::SDFHeart2 ( const Vector2 & c,
const double & r )
explicit

Create a convex primitive.

Parameters
cCenter.
rRadius.

Member Function Documentation

◆ Memory()

int SDFHeart2::Memory ( ) const
virtual

Return the size of a sub-tree.

Reimplemented from SDFNode2.

◆ Signed()

double SDFHeart2::Signed ( const Vector2 & p) const
virtual

Compute the signed Euclidean distance function.

By default compute the signed distance to the bounding box of the primitive.

Parameters
pPoint.

Reimplemented from SDFEuclidean2.