eu.mihosoft.vrl.v3d.Tetrahedron Maven / Gradle / Ivy
/*
* Tetrahedron.java
*/
package eu.mihosoft.vrl.v3d;
import java.util.ArrayList;
import java.util.List;
import eu.mihosoft.vrl.v3d.ext.quickhull3d.HullUtil;
import eu.mihosoft.vrl.v3d.parametrics.LengthParameter;
import eu.mihosoft.vrl.v3d.parametrics.Parameter;
public class Tetrahedron extends Primitive {
/**
* Center of this tetrahedron.
*/
private Vector3d center;
/**
* Tetrahedron circumscribed radius.
*/
private double radius;
/** The centered. */
private boolean centered = true;
/** The properties. */
private final PropertyStorage properties = new PropertyStorage();
/**
* Constructor. Creates a new tetrahedron with center {@code [0,0,0]} and
* dimensions {@code [1,1,1]}.
*/
public Tetrahedron() {
center = new Vector3d(0, 0, 0);
radius = 1;
}
/**
* Constructor. Creates a new tetrahedron with center {@code [0,0,0]} and
* radius {@code size}.
*
* @param size size
*/
public Tetrahedron(double size) {
center = new Vector3d(0, 0, 0);
radius = size;
}
/**
* Constructor. Creates a new tetrahedron with the specified center and
* radius.
*
* @param center center of the tetrahedron
* @param size of the tetrahedron
*/
public Tetrahedron(Vector3d center, double size) {
this.center = center;
this.radius = size;
}
/* (non-Javadoc)
* @see eu.mihosoft.vrl.v3d.Primitive#toPolygons()
*/
@Override
public List toPolygons() {
if(radius<=0)
throw new NumberFormatException("radius can not be negative");
double _1_sqrt2 = 1/Math.sqrt(2);
List points = new ArrayList<>();
points.add(new Vector3d(-1,0,-_1_sqrt2));
points.add(new Vector3d(+1,0,-_1_sqrt2));
points.add(new Vector3d(0,-1,+_1_sqrt2));
points.add(new Vector3d(0,+1,+_1_sqrt2));
List polygons = HullUtil.hull(points).scale(radius/Math.sqrt(3)).getPolygons();
return polygons;
}
/**
* Gets the center.
*
* @return the center
*/
public Vector3d getCenter() {
return center;
}
/**
* Sets the center.
*
* @param center the center to set
*/
public Tetrahedron setCenter(Vector3d center) {
this.center = center;
return this;
}
/**
* Gets the radius.
*
* @return the radius
*/
public double getRadius() {
return radius;
}
/**
* Sets the radius.
*
* @param radius the radius to set
*/
public void setRadius(double radius) {
this.radius = radius;
}
/* (non-Javadoc)
* @see eu.mihosoft.vrl.v3d.Primitive#getProperties()
*/
@Override
public PropertyStorage getProperties() {
return properties;
}
/**
* Defines that this tetrahedron will not be centered.
* @return this tetrahedron
*/
public Tetrahedron noCenter() {
centered = false;
return this;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy