All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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