Remove poly2tri because it's for stuff that never got finished
This commit is contained in:
parent
c46e08c76e
commit
d4ff48435c
42 changed files with 0 additions and 5245 deletions
|
@ -1,124 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri;
|
||||
|
||||
import org.poly2tri.geometry.polygon.Polygon;
|
||||
import org.poly2tri.geometry.polygon.PolygonSet;
|
||||
import org.poly2tri.triangulation.Triangulatable;
|
||||
import org.poly2tri.triangulation.TriangulationAlgorithm;
|
||||
import org.poly2tri.triangulation.TriangulationContext;
|
||||
import org.poly2tri.triangulation.TriangulationMode;
|
||||
import org.poly2tri.triangulation.TriangulationProcess;
|
||||
import org.poly2tri.triangulation.delaunay.sweep.DTSweep;
|
||||
import org.poly2tri.triangulation.delaunay.sweep.DTSweepContext;
|
||||
import org.poly2tri.triangulation.sets.ConstrainedPointSet;
|
||||
import org.poly2tri.triangulation.sets.PointSet;
|
||||
import org.poly2tri.triangulation.util.PolygonGenerator;
|
||||
|
||||
public class Poly2Tri
|
||||
{
|
||||
|
||||
private static final TriangulationAlgorithm _defaultAlgorithm = TriangulationAlgorithm.DTSweep;
|
||||
|
||||
public static void triangulate( PolygonSet ps )
|
||||
{
|
||||
TriangulationContext<?> tcx = createContext( _defaultAlgorithm );
|
||||
for( Polygon p : ps.getPolygons() )
|
||||
{
|
||||
tcx.prepareTriangulation( p );
|
||||
triangulate( tcx );
|
||||
tcx.clear();
|
||||
}
|
||||
}
|
||||
|
||||
public static void triangulate( Polygon p )
|
||||
{
|
||||
triangulate( _defaultAlgorithm, p );
|
||||
}
|
||||
|
||||
public static void triangulate( ConstrainedPointSet cps )
|
||||
{
|
||||
triangulate( _defaultAlgorithm, cps );
|
||||
}
|
||||
|
||||
public static void triangulate( PointSet ps )
|
||||
{
|
||||
triangulate( _defaultAlgorithm, ps );
|
||||
}
|
||||
|
||||
public static TriangulationContext<?> createContext( TriangulationAlgorithm algorithm )
|
||||
{
|
||||
switch( algorithm )
|
||||
{
|
||||
case DTSweep:
|
||||
default:
|
||||
return new DTSweepContext();
|
||||
}
|
||||
}
|
||||
|
||||
public static void triangulate( TriangulationAlgorithm algorithm,
|
||||
Triangulatable t )
|
||||
{
|
||||
TriangulationContext<?> tcx;
|
||||
|
||||
// long time = System.nanoTime();
|
||||
tcx = createContext( algorithm );
|
||||
tcx.prepareTriangulation( t );
|
||||
triangulate( tcx );
|
||||
// logger.info( "Triangulation of {} points [{}ms]", tcx.getPoints().size(), ( System.nanoTime() - time ) / 1e6 );
|
||||
}
|
||||
|
||||
public static void triangulate( TriangulationContext<?> tcx )
|
||||
{
|
||||
switch( tcx.algorithm() )
|
||||
{
|
||||
case DTSweep:
|
||||
default:
|
||||
DTSweep.triangulate( (DTSweepContext)tcx );
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Will do a warmup run to let the JVM optimize the triangulation code
|
||||
*/
|
||||
public static void warmup()
|
||||
{
|
||||
/*
|
||||
* After a method is run 10000 times, the Hotspot compiler will compile
|
||||
* it into native code. Periodically, the Hotspot compiler may recompile
|
||||
* the method. After an unspecified amount of time, then the compilation
|
||||
* system should become quiet.
|
||||
*/
|
||||
Polygon poly = PolygonGenerator.RandomCircleSweep2( 50, 50000 );
|
||||
TriangulationProcess process = new TriangulationProcess();
|
||||
process.triangulate( poly );
|
||||
}
|
||||
}
|
|
@ -1,269 +0,0 @@
|
|||
package org.poly2tri.geometry.polygon;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.triangulation.Triangulatable;
|
||||
import org.poly2tri.triangulation.TriangulationContext;
|
||||
import org.poly2tri.triangulation.TriangulationMode;
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
import org.poly2tri.triangulation.delaunay.DelaunayTriangle;
|
||||
|
||||
public class Polygon implements Triangulatable
|
||||
{
|
||||
|
||||
protected ArrayList<TriangulationPoint> _points = new ArrayList<TriangulationPoint>();
|
||||
protected ArrayList<TriangulationPoint> _steinerPoints;
|
||||
protected ArrayList<Polygon> _holes;
|
||||
|
||||
protected List<DelaunayTriangle> m_triangles;
|
||||
|
||||
protected PolygonPoint _last;
|
||||
|
||||
/**
|
||||
* To create a polygon we need atleast 3 separate points
|
||||
*
|
||||
* @param p1
|
||||
* @param p2
|
||||
* @param p3
|
||||
*/
|
||||
public Polygon( PolygonPoint p1, PolygonPoint p2, PolygonPoint p3 )
|
||||
{
|
||||
p1._next = p2;
|
||||
p2._next = p3;
|
||||
p3._next = p1;
|
||||
p1._previous = p3;
|
||||
p2._previous = p1;
|
||||
p3._previous = p2;
|
||||
_points.add( p1 );
|
||||
_points.add( p2 );
|
||||
_points.add( p3 );
|
||||
}
|
||||
|
||||
/**
|
||||
* Requires atleast 3 points
|
||||
* @param points - ordered list of points forming the polygon.
|
||||
* No duplicates are allowed
|
||||
*/
|
||||
public Polygon( List<PolygonPoint> points )
|
||||
{
|
||||
// Lets do one sanity check that first and last point hasn't got same position
|
||||
// Its something that often happen when importing polygon data from other formats
|
||||
if( points.get(0).equals( points.get(points.size()-1) ) )
|
||||
{
|
||||
points.remove( points.size()-1 );
|
||||
}
|
||||
_points.addAll( points );
|
||||
}
|
||||
|
||||
/**
|
||||
* Requires atleast 3 points
|
||||
*
|
||||
* @param points
|
||||
*/
|
||||
public Polygon( PolygonPoint[] points )
|
||||
{
|
||||
this( Arrays.asList( points ) );
|
||||
}
|
||||
|
||||
public TriangulationMode getTriangulationMode()
|
||||
{
|
||||
return TriangulationMode.POLYGON;
|
||||
}
|
||||
|
||||
public int pointCount()
|
||||
{
|
||||
int count = _points.size();
|
||||
if( _steinerPoints != null )
|
||||
{
|
||||
count += _steinerPoints.size();
|
||||
}
|
||||
return count;
|
||||
}
|
||||
|
||||
public void addSteinerPoint( TriangulationPoint point )
|
||||
{
|
||||
if( _steinerPoints == null )
|
||||
{
|
||||
_steinerPoints = new ArrayList<TriangulationPoint>();
|
||||
}
|
||||
_steinerPoints.add( point );
|
||||
}
|
||||
|
||||
public void addSteinerPoints( List<TriangulationPoint> points )
|
||||
{
|
||||
if( _steinerPoints == null )
|
||||
{
|
||||
_steinerPoints = new ArrayList<TriangulationPoint>();
|
||||
}
|
||||
_steinerPoints.addAll( points );
|
||||
}
|
||||
|
||||
public void clearSteinerPoints()
|
||||
{
|
||||
if( _steinerPoints != null )
|
||||
{
|
||||
_steinerPoints.clear();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Assumes: that given polygon is fully inside the current polygon
|
||||
* @param poly - a subtraction polygon
|
||||
*/
|
||||
public void addHole( Polygon poly )
|
||||
{
|
||||
if( _holes == null )
|
||||
{
|
||||
_holes = new ArrayList<Polygon>();
|
||||
}
|
||||
_holes.add( poly );
|
||||
// XXX: tests could be made here to be sure it is fully inside
|
||||
// addSubtraction( poly.getPoints() );
|
||||
}
|
||||
|
||||
/**
|
||||
* Will insert a point in the polygon after given point
|
||||
*
|
||||
* @param a
|
||||
* @param b
|
||||
* @param p
|
||||
*/
|
||||
public void insertPointAfter( PolygonPoint a, PolygonPoint newPoint )
|
||||
{
|
||||
// Validate that
|
||||
int index = _points.indexOf( a );
|
||||
if( index != -1 )
|
||||
{
|
||||
newPoint.setNext( a.getNext() );
|
||||
newPoint.setPrevious( a );
|
||||
a.getNext().setPrevious( newPoint );
|
||||
a.setNext( newPoint );
|
||||
_points.add( index+1, newPoint );
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new RuntimeException( "Tried to insert a point into a Polygon after a point not belonging to the Polygon" );
|
||||
}
|
||||
}
|
||||
|
||||
public void addPoints( List<PolygonPoint> list )
|
||||
{
|
||||
PolygonPoint first;
|
||||
for( PolygonPoint p : list )
|
||||
{
|
||||
p.setPrevious( _last );
|
||||
if( _last != null )
|
||||
{
|
||||
p.setNext( _last.getNext() );
|
||||
_last.setNext( p );
|
||||
}
|
||||
_last = p;
|
||||
_points.add( p );
|
||||
}
|
||||
first = (PolygonPoint)_points.get(0);
|
||||
_last.setNext( first );
|
||||
first.setPrevious( _last );
|
||||
}
|
||||
|
||||
/**
|
||||
* Will add a point after the last point added
|
||||
*
|
||||
* @param p
|
||||
*/
|
||||
public void addPoint(PolygonPoint p )
|
||||
{
|
||||
p.setPrevious( _last );
|
||||
p.setNext( _last.getNext() );
|
||||
_last.setNext( p );
|
||||
_points.add( p );
|
||||
}
|
||||
|
||||
public void removePoint( PolygonPoint p )
|
||||
{
|
||||
PolygonPoint next, prev;
|
||||
|
||||
next = p.getNext();
|
||||
prev = p.getPrevious();
|
||||
prev.setNext( next );
|
||||
next.setPrevious( prev );
|
||||
_points.remove( p );
|
||||
}
|
||||
|
||||
public PolygonPoint getPoint()
|
||||
{
|
||||
return _last;
|
||||
}
|
||||
|
||||
public List<TriangulationPoint> getPoints()
|
||||
{
|
||||
return _points;
|
||||
}
|
||||
|
||||
public List<DelaunayTriangle> getTriangles()
|
||||
{
|
||||
return m_triangles;
|
||||
}
|
||||
|
||||
public void addTriangle( DelaunayTriangle t )
|
||||
{
|
||||
m_triangles.add( t );
|
||||
}
|
||||
|
||||
public void addTriangles( List<DelaunayTriangle> list )
|
||||
{
|
||||
m_triangles.addAll( list );
|
||||
}
|
||||
|
||||
public void clearTriangulation()
|
||||
{
|
||||
if( m_triangles != null )
|
||||
{
|
||||
m_triangles.clear();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Creates constraints and populates the context with points
|
||||
*/
|
||||
public void prepareTriangulation( TriangulationContext<?> tcx )
|
||||
{
|
||||
if( m_triangles == null )
|
||||
{
|
||||
m_triangles = new ArrayList<DelaunayTriangle>( _points.size() );
|
||||
}
|
||||
else
|
||||
{
|
||||
m_triangles.clear();
|
||||
}
|
||||
|
||||
// Outer constraints
|
||||
for( int i = 0; i < _points.size()-1 ; i++ )
|
||||
{
|
||||
tcx.newConstraint( _points.get( i ), _points.get( i+1 ) );
|
||||
}
|
||||
tcx.newConstraint( _points.get( 0 ), _points.get( _points.size()-1 ) );
|
||||
tcx.addPoints( _points );
|
||||
|
||||
// Hole constraints
|
||||
if( _holes != null )
|
||||
{
|
||||
for( Polygon p : _holes )
|
||||
{
|
||||
for( int i = 0; i < p._points.size()-1 ; i++ )
|
||||
{
|
||||
tcx.newConstraint( p._points.get( i ), p._points.get( i+1 ) );
|
||||
}
|
||||
tcx.newConstraint( p._points.get( 0 ), p._points.get( p._points.size()-1 ) );
|
||||
tcx.addPoints( p._points );
|
||||
}
|
||||
}
|
||||
|
||||
if( _steinerPoints != null )
|
||||
{
|
||||
tcx.addPoints( _steinerPoints );
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -1,39 +0,0 @@
|
|||
package org.poly2tri.geometry.polygon;
|
||||
|
||||
import org.poly2tri.triangulation.point.TPoint;
|
||||
|
||||
public class PolygonPoint extends TPoint
|
||||
{
|
||||
protected PolygonPoint _next;
|
||||
protected PolygonPoint _previous;
|
||||
|
||||
public PolygonPoint( double x, double y )
|
||||
{
|
||||
super( x, y );
|
||||
}
|
||||
|
||||
public PolygonPoint( double x, double y, double z )
|
||||
{
|
||||
super( x, y, z );
|
||||
}
|
||||
|
||||
public void setPrevious( PolygonPoint p )
|
||||
{
|
||||
_previous = p;
|
||||
}
|
||||
|
||||
public void setNext( PolygonPoint p )
|
||||
{
|
||||
_next = p;
|
||||
}
|
||||
|
||||
public PolygonPoint getNext()
|
||||
{
|
||||
return _next;
|
||||
}
|
||||
|
||||
public PolygonPoint getPrevious()
|
||||
{
|
||||
return _previous;
|
||||
}
|
||||
}
|
|
@ -1,58 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.geometry.polygon;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
public class PolygonSet
|
||||
{
|
||||
protected ArrayList<Polygon> _polygons = new ArrayList<Polygon>();
|
||||
|
||||
public PolygonSet()
|
||||
{
|
||||
}
|
||||
|
||||
public PolygonSet( Polygon poly )
|
||||
{
|
||||
_polygons.add( poly );
|
||||
}
|
||||
|
||||
public void add( Polygon p )
|
||||
{
|
||||
_polygons.add( p );
|
||||
}
|
||||
|
||||
public List<Polygon> getPolygons()
|
||||
{
|
||||
return _polygons;
|
||||
}
|
||||
}
|
|
@ -1,15 +0,0 @@
|
|||
package org.poly2tri.geometry.polygon;
|
||||
|
||||
public class PolygonUtil
|
||||
{
|
||||
/**
|
||||
* TODO
|
||||
* @param polygon
|
||||
*/
|
||||
public static void validate( Polygon polygon )
|
||||
{
|
||||
// TODO: implement
|
||||
// 1. Check for duplicate points
|
||||
// 2. Check for intersecting sides
|
||||
}
|
||||
}
|
|
@ -1,17 +0,0 @@
|
|||
package org.poly2tri.geometry.primitives;
|
||||
|
||||
public abstract class Edge<A extends Point>
|
||||
{
|
||||
protected A p;
|
||||
protected A q;
|
||||
|
||||
public A getP()
|
||||
{
|
||||
return p;
|
||||
}
|
||||
|
||||
public A getQ()
|
||||
{
|
||||
return q;
|
||||
}
|
||||
}
|
|
@ -1,31 +0,0 @@
|
|||
package org.poly2tri.geometry.primitives;
|
||||
|
||||
public abstract class Point
|
||||
{
|
||||
public abstract double getX();
|
||||
public abstract double getY();
|
||||
public abstract double getZ();
|
||||
|
||||
public abstract float getXf();
|
||||
public abstract float getYf();
|
||||
public abstract float getZf();
|
||||
|
||||
public abstract void set( double x, double y, double z );
|
||||
|
||||
protected static int calculateHashCode( double x, double y, double z)
|
||||
{
|
||||
int result = 17;
|
||||
|
||||
final long a = Double.doubleToLongBits(x);
|
||||
result += 31 * result + (int) (a ^ (a >>> 32));
|
||||
|
||||
final long b = Double.doubleToLongBits(y);
|
||||
result += 31 * result + (int) (b ^ (b >>> 32));
|
||||
|
||||
final long c = Double.doubleToLongBits(z);
|
||||
result += 31 * result + (int) (c ^ (c >>> 32));
|
||||
|
||||
return result;
|
||||
|
||||
}
|
||||
}
|
|
@ -1,71 +0,0 @@
|
|||
package org.poly2tri.transform.coordinate;
|
||||
|
||||
/**
|
||||
* A transform that aligns given source normal with the XY plane normal [0,0,1]
|
||||
*
|
||||
* @author thahlen@gmail.com
|
||||
*/
|
||||
|
||||
public class AnyToXYTransform extends Matrix3Transform
|
||||
{
|
||||
/**
|
||||
* Assumes source normal is normalized
|
||||
*/
|
||||
public AnyToXYTransform( double nx, double ny, double nz )
|
||||
{
|
||||
setSourceNormal( nx, ny, nz );
|
||||
}
|
||||
|
||||
/**
|
||||
* Assumes source normal is normalized
|
||||
*
|
||||
* @param nx
|
||||
* @param ny
|
||||
* @param nz
|
||||
*/
|
||||
public void setSourceNormal( double nx, double ny, double nz )
|
||||
{
|
||||
double h,f,c,vx,vy,hvx;
|
||||
|
||||
vx = -ny;
|
||||
vy = nx;
|
||||
c = nz;
|
||||
|
||||
h = (1-c)/(1-c*c);
|
||||
hvx = h*vx;
|
||||
f = (c < 0) ? -c : c;
|
||||
|
||||
if( f < 1.0 - 1.0E-4 )
|
||||
{
|
||||
m00=c + hvx*vx;
|
||||
m01=hvx*vy;
|
||||
m02=-vy;
|
||||
m10=hvx*vy;
|
||||
m11=c + h*vy*vy;
|
||||
m12=vx;
|
||||
m20=vy;
|
||||
m21=-vx;
|
||||
m22=c;
|
||||
}
|
||||
else
|
||||
{
|
||||
// if "from" and "to" vectors are nearly parallel
|
||||
m00=1;
|
||||
m01=0;
|
||||
m02=0;
|
||||
m10=0;
|
||||
m11=1;
|
||||
m12=0;
|
||||
m20=0;
|
||||
m21=0;
|
||||
if( c > 0 )
|
||||
{
|
||||
m22=1;
|
||||
}
|
||||
else
|
||||
{
|
||||
m22=-1;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,12 +0,0 @@
|
|||
package org.poly2tri.transform.coordinate;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.geometry.primitives.Point;
|
||||
|
||||
public abstract interface CoordinateTransform
|
||||
{
|
||||
public abstract void transform( Point p, Point store );
|
||||
public abstract void transform( Point p );
|
||||
public abstract void transform( List<? extends Point> list );
|
||||
}
|
|
@ -1,38 +0,0 @@
|
|||
package org.poly2tri.transform.coordinate;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.geometry.primitives.Point;
|
||||
|
||||
public abstract class Matrix3Transform implements CoordinateTransform
|
||||
{
|
||||
protected double m00,m01,m02,m10,m11,m12,m20,m21,m22;
|
||||
|
||||
public void transform( Point p, Point store )
|
||||
{
|
||||
final double px = p.getX();
|
||||
final double py = p.getY();
|
||||
final double pz = p.getZ();
|
||||
store.set(m00 * px + m01 * py + m02 * pz,
|
||||
m10 * px + m11 * py + m12 * pz,
|
||||
m20 * px + m21 * py + m22 * pz );
|
||||
}
|
||||
|
||||
public void transform( Point p )
|
||||
{
|
||||
final double px = p.getX();
|
||||
final double py = p.getY();
|
||||
final double pz = p.getZ();
|
||||
p.set(m00 * px + m01 * py + m02 * pz,
|
||||
m10 * px + m11 * py + m12 * pz,
|
||||
m20 * px + m21 * py + m22 * pz );
|
||||
}
|
||||
|
||||
public void transform( List<? extends Point> list )
|
||||
{
|
||||
for( Point p : list )
|
||||
{
|
||||
transform( p );
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,21 +0,0 @@
|
|||
package org.poly2tri.transform.coordinate;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.geometry.primitives.Point;
|
||||
|
||||
public class NoTransform implements CoordinateTransform
|
||||
{
|
||||
public void transform( Point p, Point store )
|
||||
{
|
||||
store.set( p.getX(), p.getY(), p.getZ() );
|
||||
}
|
||||
|
||||
public void transform( Point p )
|
||||
{
|
||||
}
|
||||
|
||||
public void transform( List<? extends Point> list )
|
||||
{
|
||||
}
|
||||
}
|
|
@ -1,74 +0,0 @@
|
|||
package org.poly2tri.transform.coordinate;
|
||||
|
||||
/**
|
||||
* A transform that aligns the XY plane normal [0,0,1] with any given target normal
|
||||
*
|
||||
* http://www.cs.brown.edu/~jfh/papers/Moller-EBA-1999/paper.pdf
|
||||
*
|
||||
* @author thahlen@gmail.com
|
||||
*
|
||||
*/
|
||||
public class XYToAnyTransform extends Matrix3Transform
|
||||
{
|
||||
/**
|
||||
* Assumes target normal is normalized
|
||||
*/
|
||||
public XYToAnyTransform( double nx, double ny, double nz )
|
||||
{
|
||||
setTargetNormal( nx, ny, nz );
|
||||
}
|
||||
|
||||
/**
|
||||
* Assumes target normal is normalized
|
||||
*
|
||||
* @param nx
|
||||
* @param ny
|
||||
* @param nz
|
||||
*/
|
||||
public void setTargetNormal( double nx, double ny, double nz )
|
||||
{
|
||||
double h,f,c,vx,vy,hvx;
|
||||
|
||||
vx = ny;
|
||||
vy = -nx;
|
||||
c = nz;
|
||||
|
||||
h = (1-c)/(1-c*c);
|
||||
hvx = h*vx;
|
||||
f = (c < 0) ? -c : c;
|
||||
|
||||
if( f < 1.0 - 1.0E-4 )
|
||||
{
|
||||
m00=c + hvx*vx;
|
||||
m01=hvx*vy;
|
||||
m02=-vy;
|
||||
m10=hvx*vy;
|
||||
m11=c + h*vy*vy;
|
||||
m12=vx;
|
||||
m20=vy;
|
||||
m21=-vx;
|
||||
m22=c;
|
||||
}
|
||||
else
|
||||
{
|
||||
// if "from" and "to" vectors are nearly parallel
|
||||
m00=1;
|
||||
m01=0;
|
||||
m02=0;
|
||||
m10=0;
|
||||
m11=1;
|
||||
m12=0;
|
||||
m20=0;
|
||||
m21=0;
|
||||
if( c > 0 )
|
||||
{
|
||||
m22=1;
|
||||
}
|
||||
else
|
||||
{
|
||||
m22=-1;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
|
@ -1,22 +0,0 @@
|
|||
package org.poly2tri.triangulation;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.triangulation.delaunay.DelaunayTriangle;
|
||||
|
||||
public interface Triangulatable
|
||||
{
|
||||
/**
|
||||
* Preparations needed before triangulation start should be handled here
|
||||
* @param tcx
|
||||
*/
|
||||
public void prepareTriangulation( TriangulationContext<?> tcx );
|
||||
|
||||
public List<DelaunayTriangle> getTriangles();
|
||||
public List<TriangulationPoint> getPoints();
|
||||
public void addTriangle( DelaunayTriangle t );
|
||||
public void addTriangles( List<DelaunayTriangle> list );
|
||||
public void clearTriangulation();
|
||||
|
||||
public TriangulationMode getTriangulationMode();
|
||||
}
|
|
@ -1,36 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation;
|
||||
|
||||
public enum TriangulationAlgorithm
|
||||
{
|
||||
DTSweep
|
||||
}
|
|
@ -1,55 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation;
|
||||
|
||||
/**
|
||||
* Forces a triangle edge between two points p and q
|
||||
* when triangulating. For example used to enforce
|
||||
* Polygon Edges during a polygon triangulation.
|
||||
*
|
||||
* @author Thomas Åhlén, thahlen@gmail.com
|
||||
*/
|
||||
public class TriangulationConstraint
|
||||
{
|
||||
protected TriangulationPoint p;
|
||||
protected TriangulationPoint q;
|
||||
|
||||
public TriangulationPoint getP()
|
||||
{
|
||||
return p;
|
||||
}
|
||||
|
||||
public TriangulationPoint getQ()
|
||||
{
|
||||
return q;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,171 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.triangulation.delaunay.DelaunayTriangle;
|
||||
|
||||
public abstract class TriangulationContext<A extends TriangulationDebugContext>
|
||||
{
|
||||
protected A _debug;
|
||||
protected boolean _debugEnabled = false;
|
||||
|
||||
protected ArrayList<DelaunayTriangle> _triList = new ArrayList<DelaunayTriangle>();
|
||||
|
||||
protected ArrayList<TriangulationPoint> _points = new ArrayList<TriangulationPoint>(200);
|
||||
protected TriangulationMode _triangulationMode;
|
||||
protected Triangulatable _triUnit;
|
||||
|
||||
private boolean _terminated = false;
|
||||
private boolean _waitUntilNotified;
|
||||
|
||||
private int _stepTime = -1;
|
||||
private int _stepCount = 0;
|
||||
public int getStepCount() { return _stepCount; }
|
||||
|
||||
public void done()
|
||||
{
|
||||
_stepCount++;
|
||||
}
|
||||
|
||||
public abstract TriangulationAlgorithm algorithm();
|
||||
|
||||
public void prepareTriangulation( Triangulatable t )
|
||||
{
|
||||
_triUnit = t;
|
||||
_triangulationMode = t.getTriangulationMode();
|
||||
t.prepareTriangulation( this );
|
||||
}
|
||||
|
||||
public abstract TriangulationConstraint newConstraint( TriangulationPoint a, TriangulationPoint b );
|
||||
|
||||
public void addToList( DelaunayTriangle triangle )
|
||||
{
|
||||
_triList.add( triangle );
|
||||
}
|
||||
|
||||
public List<DelaunayTriangle> getTriangles()
|
||||
{
|
||||
return _triList;
|
||||
}
|
||||
|
||||
public Triangulatable getTriangulatable()
|
||||
{
|
||||
return _triUnit;
|
||||
}
|
||||
|
||||
public List<TriangulationPoint> getPoints()
|
||||
{
|
||||
return _points;
|
||||
}
|
||||
|
||||
public synchronized void update(String message)
|
||||
{
|
||||
if( _debugEnabled )
|
||||
{
|
||||
try
|
||||
{
|
||||
synchronized( this )
|
||||
{
|
||||
_stepCount++;
|
||||
if( _stepTime > 0 )
|
||||
{
|
||||
wait( (int)_stepTime );
|
||||
/** Can we resume execution or are we expected to wait? */
|
||||
if( _waitUntilNotified )
|
||||
{
|
||||
wait();
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
wait();
|
||||
}
|
||||
// We have been notified
|
||||
_waitUntilNotified = false;
|
||||
}
|
||||
}
|
||||
catch( InterruptedException e )
|
||||
{
|
||||
update("Triangulation was interrupted");
|
||||
}
|
||||
}
|
||||
if( _terminated )
|
||||
{
|
||||
throw new RuntimeException( "Triangulation process terminated before completion");
|
||||
}
|
||||
}
|
||||
|
||||
public void clear()
|
||||
{
|
||||
_points.clear();
|
||||
_terminated = false;
|
||||
if( _debug != null )
|
||||
{
|
||||
_debug.clear();
|
||||
}
|
||||
_stepCount=0;
|
||||
}
|
||||
|
||||
public TriangulationMode getTriangulationMode()
|
||||
{
|
||||
return _triangulationMode;
|
||||
}
|
||||
|
||||
public synchronized void waitUntilNotified(boolean b)
|
||||
{
|
||||
_waitUntilNotified = b;
|
||||
}
|
||||
|
||||
public void terminateTriangulation()
|
||||
{
|
||||
_terminated=true;
|
||||
}
|
||||
|
||||
public boolean isDebugEnabled()
|
||||
{
|
||||
return _debugEnabled;
|
||||
}
|
||||
|
||||
public abstract void isDebugEnabled( boolean b );
|
||||
|
||||
public A getDebugContext()
|
||||
{
|
||||
return _debug;
|
||||
}
|
||||
|
||||
public void addPoints( List<TriangulationPoint> points )
|
||||
{
|
||||
_points.addAll( points );
|
||||
}
|
||||
}
|
|
@ -1,13 +0,0 @@
|
|||
package org.poly2tri.triangulation;
|
||||
|
||||
public abstract class TriangulationDebugContext
|
||||
{
|
||||
protected TriangulationContext<?> _tcx;
|
||||
|
||||
public TriangulationDebugContext( TriangulationContext<?> tcx )
|
||||
{
|
||||
_tcx = tcx;
|
||||
}
|
||||
|
||||
public abstract void clear();
|
||||
}
|
|
@ -1,6 +0,0 @@
|
|||
package org.poly2tri.triangulation;
|
||||
|
||||
public enum TriangulationMode
|
||||
{
|
||||
UNCONSTRAINED,CONSTRAINED,POLYGON;
|
||||
}
|
|
@ -1,112 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
import org.poly2tri.geometry.primitives.Point;
|
||||
import org.poly2tri.triangulation.delaunay.sweep.DTSweepConstraint;
|
||||
|
||||
|
||||
public abstract class TriangulationPoint extends Point
|
||||
{
|
||||
// List of edges this point constitutes an upper ending point (CDT)
|
||||
private ArrayList<DTSweepConstraint> edges;
|
||||
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
return "[" + getX() + "," + getY() + "]";
|
||||
}
|
||||
|
||||
public abstract double getX();
|
||||
public abstract double getY();
|
||||
public abstract double getZ();
|
||||
|
||||
public abstract float getXf();
|
||||
public abstract float getYf();
|
||||
public abstract float getZf();
|
||||
|
||||
public abstract void set( double x, double y, double z );
|
||||
|
||||
public ArrayList<DTSweepConstraint> getEdges()
|
||||
{
|
||||
return edges;
|
||||
}
|
||||
|
||||
public void addEdge( DTSweepConstraint e )
|
||||
{
|
||||
if( edges == null )
|
||||
{
|
||||
edges = new ArrayList<DTSweepConstraint>();
|
||||
}
|
||||
edges.add( e );
|
||||
}
|
||||
|
||||
public boolean hasEdges()
|
||||
{
|
||||
return edges != null;
|
||||
}
|
||||
|
||||
/**
|
||||
* @param p - edge destination point
|
||||
* @return the edge from this point to given point
|
||||
*/
|
||||
public DTSweepConstraint getEdge( TriangulationPoint p )
|
||||
{
|
||||
for( DTSweepConstraint c : edges )
|
||||
{
|
||||
if( c.p == p )
|
||||
{
|
||||
return c;
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public boolean equals(Object obj)
|
||||
{
|
||||
if( obj instanceof TriangulationPoint )
|
||||
{
|
||||
TriangulationPoint p = (TriangulationPoint)obj;
|
||||
return getX() == p.getX() && getY() == p.getY();
|
||||
}
|
||||
return super.equals( obj );
|
||||
}
|
||||
|
||||
public int hashCode()
|
||||
{
|
||||
long bits = java.lang.Double.doubleToLongBits(getX());
|
||||
bits ^= java.lang.Double.doubleToLongBits(getY()) * 31;
|
||||
return (((int) bits) ^ ((int) (bits >> 32)));
|
||||
}
|
||||
|
||||
}
|
|
@ -1,341 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation;
|
||||
|
||||
import java.lang.Thread.State;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.Poly2Tri;
|
||||
import org.poly2tri.geometry.polygon.Polygon;
|
||||
import org.poly2tri.geometry.polygon.PolygonSet;
|
||||
import org.poly2tri.triangulation.sets.ConstrainedPointSet;
|
||||
import org.poly2tri.triangulation.sets.PointSet;
|
||||
|
||||
|
||||
/**
|
||||
*
|
||||
* @author Thomas Åhlén, thahlen@gmail.com
|
||||
*
|
||||
*/
|
||||
public class TriangulationProcess implements Runnable
|
||||
{
|
||||
|
||||
private final TriangulationAlgorithm _algorithm;
|
||||
|
||||
private TriangulationContext<?> _tcx;
|
||||
private Thread _thread;
|
||||
private boolean _isTerminated = false;
|
||||
private int _pointCount = 0;
|
||||
private long _timestamp = 0;
|
||||
private double _triangulationTime = 0;
|
||||
|
||||
private boolean _awaitingTermination;
|
||||
private boolean _restart = false;
|
||||
|
||||
private ArrayList<Triangulatable> _triangulations = new ArrayList<Triangulatable>();
|
||||
|
||||
private ArrayList<TriangulationProcessListener> _listeners = new ArrayList<TriangulationProcessListener>();
|
||||
|
||||
public void addListener( TriangulationProcessListener listener )
|
||||
{
|
||||
_listeners.add( listener );
|
||||
}
|
||||
|
||||
public void removeListener( TriangulationProcessListener listener )
|
||||
{
|
||||
_listeners.remove( listener );
|
||||
}
|
||||
|
||||
public void clearListeners()
|
||||
{
|
||||
_listeners.clear();
|
||||
}
|
||||
|
||||
/**
|
||||
* Notify all listeners of this new event
|
||||
* @param event
|
||||
*/
|
||||
private void sendEvent( TriangulationProcessEvent event )
|
||||
{
|
||||
for( TriangulationProcessListener l : _listeners )
|
||||
{
|
||||
l.triangulationEvent( event, _tcx.getTriangulatable() );
|
||||
}
|
||||
}
|
||||
|
||||
public int getStepCount()
|
||||
{
|
||||
return _tcx.getStepCount();
|
||||
}
|
||||
|
||||
public long getTimestamp()
|
||||
{
|
||||
return _timestamp;
|
||||
}
|
||||
|
||||
public double getTriangulationTime()
|
||||
{
|
||||
return _triangulationTime;
|
||||
}
|
||||
|
||||
/**
|
||||
* Uses SweepLine algorithm by default
|
||||
* @param algorithm
|
||||
*/
|
||||
public TriangulationProcess()
|
||||
{
|
||||
this( TriangulationAlgorithm.DTSweep );
|
||||
}
|
||||
|
||||
public TriangulationProcess( TriangulationAlgorithm algorithm )
|
||||
{
|
||||
_algorithm = algorithm;
|
||||
_tcx = Poly2Tri.createContext( algorithm );
|
||||
}
|
||||
|
||||
/**
|
||||
* This retriangulates same set as previous triangulation
|
||||
* useful if you want to do consecutive triangulations with
|
||||
* same data. Like when you when you want to do performance
|
||||
* tests.
|
||||
*/
|
||||
// public void triangulate()
|
||||
// {
|
||||
// start();
|
||||
// }
|
||||
|
||||
/**
|
||||
* Triangulate a PointSet with eventual constraints
|
||||
*
|
||||
* @param cps
|
||||
*/
|
||||
public void triangulate( PointSet ps )
|
||||
{
|
||||
_triangulations.clear();
|
||||
_triangulations.add( ps );
|
||||
start();
|
||||
}
|
||||
|
||||
/**
|
||||
* Triangulate a PointSet with eventual constraints
|
||||
*
|
||||
* @param cps
|
||||
*/
|
||||
public void triangulate( ConstrainedPointSet cps )
|
||||
{
|
||||
_triangulations.clear();
|
||||
_triangulations.add( cps );
|
||||
start();
|
||||
}
|
||||
|
||||
/**
|
||||
* Triangulate a PolygonSet
|
||||
*
|
||||
* @param ps
|
||||
*/
|
||||
public void triangulate( PolygonSet ps )
|
||||
{
|
||||
_triangulations.clear();
|
||||
_triangulations.addAll( ps.getPolygons() );
|
||||
start();
|
||||
}
|
||||
|
||||
/**
|
||||
* Triangulate a Polygon
|
||||
*
|
||||
* @param ps
|
||||
*/
|
||||
public void triangulate( Polygon polygon )
|
||||
{
|
||||
_triangulations.clear();
|
||||
_triangulations.add( polygon );
|
||||
start();
|
||||
}
|
||||
|
||||
/**
|
||||
* Triangulate a List of Triangulatables
|
||||
*
|
||||
* @param ps
|
||||
*/
|
||||
public void triangulate( List<Triangulatable> list )
|
||||
{
|
||||
_triangulations.clear();
|
||||
_triangulations.addAll( list );
|
||||
start();
|
||||
}
|
||||
|
||||
private void start()
|
||||
{
|
||||
if( _thread == null || _thread.getState() == State.TERMINATED )
|
||||
{
|
||||
_isTerminated = false;
|
||||
_thread = new Thread( this, _algorithm.name() + "." + _tcx.getTriangulationMode() );
|
||||
_thread.start();
|
||||
sendEvent( TriangulationProcessEvent.Started );
|
||||
}
|
||||
else
|
||||
{
|
||||
// Triangulation already running. Terminate it so we can start a new
|
||||
shutdown();
|
||||
_restart = true;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean isWaiting()
|
||||
{
|
||||
if( _thread != null && _thread.getState() == State.WAITING )
|
||||
{
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public void run()
|
||||
{
|
||||
_pointCount=0;
|
||||
try
|
||||
{
|
||||
long time = System.nanoTime();
|
||||
for( Triangulatable t : _triangulations )
|
||||
{
|
||||
_tcx.clear();
|
||||
_tcx.prepareTriangulation( t );
|
||||
_pointCount += _tcx._points.size();
|
||||
Poly2Tri.triangulate( _tcx );
|
||||
}
|
||||
_triangulationTime = ( System.nanoTime() - time ) / 1e6;
|
||||
sendEvent( TriangulationProcessEvent.Done );
|
||||
}
|
||||
catch( RuntimeException e )
|
||||
{
|
||||
if( _awaitingTermination )
|
||||
{
|
||||
_awaitingTermination = false;
|
||||
sendEvent( TriangulationProcessEvent.Aborted );
|
||||
}
|
||||
else
|
||||
{
|
||||
e.printStackTrace();
|
||||
sendEvent( TriangulationProcessEvent.Failed );
|
||||
}
|
||||
}
|
||||
catch( Exception e )
|
||||
{
|
||||
e.printStackTrace();
|
||||
sendEvent( TriangulationProcessEvent.Failed );
|
||||
}
|
||||
finally
|
||||
{
|
||||
_timestamp = System.currentTimeMillis();
|
||||
_isTerminated = true;
|
||||
_thread = null;
|
||||
}
|
||||
|
||||
// Autostart a new triangulation?
|
||||
if( _restart )
|
||||
{
|
||||
_restart = false;
|
||||
start();
|
||||
}
|
||||
}
|
||||
|
||||
public void resume()
|
||||
{
|
||||
if( _thread != null )
|
||||
{
|
||||
// Only force a resume when process is waiting for a notification
|
||||
if( _thread.getState() == State.WAITING )
|
||||
{
|
||||
synchronized( _tcx )
|
||||
{
|
||||
_tcx.notify();
|
||||
}
|
||||
}
|
||||
else if( _thread.getState() == State.TIMED_WAITING )
|
||||
{
|
||||
_tcx.waitUntilNotified( false );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void shutdown()
|
||||
{
|
||||
_awaitingTermination = true;
|
||||
_tcx.terminateTriangulation();
|
||||
resume();
|
||||
}
|
||||
|
||||
public TriangulationContext<?> getContext()
|
||||
{
|
||||
return _tcx;
|
||||
}
|
||||
|
||||
public boolean isDone()
|
||||
{
|
||||
return _isTerminated;
|
||||
}
|
||||
|
||||
public void requestRead()
|
||||
{
|
||||
_tcx.waitUntilNotified( true );
|
||||
}
|
||||
|
||||
public boolean isReadable()
|
||||
{
|
||||
if( _thread == null )
|
||||
{
|
||||
return true;
|
||||
}
|
||||
else
|
||||
{
|
||||
synchronized( _thread )
|
||||
{
|
||||
if( _thread.getState() == State.WAITING )
|
||||
{
|
||||
return true;
|
||||
}
|
||||
else if( _thread.getState() == State.TIMED_WAITING )
|
||||
{
|
||||
// Make sure that it stays readable
|
||||
_tcx.waitUntilNotified( true );
|
||||
return true;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public int getPointCount()
|
||||
{
|
||||
return _pointCount;
|
||||
}
|
||||
}
|
|
@ -1,36 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation;
|
||||
|
||||
public enum TriangulationProcessEvent
|
||||
{
|
||||
Started,Waiting,Failed,Aborted,Done
|
||||
}
|
|
@ -1,36 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation;
|
||||
|
||||
public interface TriangulationProcessListener
|
||||
{
|
||||
public void triangulationEvent( TriangulationProcessEvent e, Triangulatable unit );
|
||||
}
|
|
@ -1,213 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/package org.poly2tri.triangulation;
|
||||
|
||||
|
||||
/**
|
||||
* @author Thomas Åhlén, thahlen@gmail.com
|
||||
*/
|
||||
public class TriangulationUtil
|
||||
{
|
||||
public final static double EPSILON = 1e-12;
|
||||
|
||||
// Returns triangle circumcircle point and radius
|
||||
// public static Tuple2<TPoint, Double> circumCircle( TPoint a, TPoint b, TPoint c )
|
||||
// {
|
||||
// double A = det( a, b, c );
|
||||
// double C = detC( a, b, c );
|
||||
//
|
||||
// double sa = a.getX() * a.getX() + a.getY() * a.getY();
|
||||
// double sb = b.getX() * b.getX() + b.getY() * b.getY();
|
||||
// double sc = c.getX() * c.getX() + c.getY() * c.getY();
|
||||
//
|
||||
// TPoint bx1 = new TPoint( sa, a.getY() );
|
||||
// TPoint bx2 = new TPoint( sb, b.getY() );
|
||||
// TPoint bx3 = new TPoint( sc, c.getY() );
|
||||
// double bx = det( bx1, bx2, bx3 );
|
||||
//
|
||||
// TPoint by1 = new TPoint( sa, a.getX() );
|
||||
// TPoint by2 = new TPoint( sb, b.getX() );
|
||||
// TPoint by3 = new TPoint( sc, c.getX() );
|
||||
// double by = det( by1, by2, by3 );
|
||||
//
|
||||
// double x = bx / ( 2 * A );
|
||||
// double y = by / ( 2 * A );
|
||||
//
|
||||
// TPoint center = new TPoint( x, y );
|
||||
// double radius = Math.sqrt( bx * bx + by * by - 4 * A * C ) / ( 2 * Math.abs( A ) );
|
||||
//
|
||||
// return new Tuple2<TPoint, Double>( center, radius );
|
||||
// }
|
||||
|
||||
/**
|
||||
* <b>Requirement</b>:<br>
|
||||
* 1. a,b and c form a triangle.<br>
|
||||
* 2. a and d is know to be on opposite side of bc<br>
|
||||
* <pre>
|
||||
* a
|
||||
* +
|
||||
* / \
|
||||
* / \
|
||||
* b/ \c
|
||||
* +-------+
|
||||
* / B \
|
||||
* / \
|
||||
* </pre>
|
||||
* <b>Fact</b>: d has to be in area B to have a chance to be inside the circle formed by
|
||||
* a,b and c<br>
|
||||
* d is outside B if orient2d(a,b,d) or orient2d(c,a,d) is CW<br>
|
||||
* This preknowledge gives us a way to optimize the incircle test
|
||||
* @param a - triangle point, opposite d
|
||||
* @param b - triangle point
|
||||
* @param c - triangle point
|
||||
* @param d - point opposite a
|
||||
* @return true if d is inside circle, false if on circle edge
|
||||
*/
|
||||
public static boolean smartIncircle( final TriangulationPoint pa,
|
||||
final TriangulationPoint pb,
|
||||
final TriangulationPoint pc,
|
||||
final TriangulationPoint pd )
|
||||
{
|
||||
final double pdx = pd.getX();
|
||||
final double pdy = pd.getY();
|
||||
final double adx = pa.getX() - pdx;
|
||||
final double ady = pa.getY() - pdy;
|
||||
final double bdx = pb.getX() - pdx;
|
||||
final double bdy = pb.getY() - pdy;
|
||||
|
||||
final double adxbdy = adx * bdy;
|
||||
final double bdxady = bdx * ady;
|
||||
final double oabd = adxbdy - bdxady;
|
||||
// oabd = orient2d(pa,pb,pd);
|
||||
if( oabd <= 0 )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
final double cdx = pc.getX() - pdx;
|
||||
final double cdy = pc.getY() - pdy;
|
||||
|
||||
final double cdxady = cdx * ady;
|
||||
final double adxcdy = adx * cdy;
|
||||
final double ocad = cdxady - adxcdy;
|
||||
// ocad = orient2d(pc,pa,pd);
|
||||
if( ocad <= 0 )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
final double bdxcdy = bdx * cdy;
|
||||
final double cdxbdy = cdx * bdy;
|
||||
|
||||
final double alift = adx * adx + ady * ady;
|
||||
final double blift = bdx * bdx + bdy * bdy;
|
||||
final double clift = cdx * cdx + cdy * cdy;
|
||||
|
||||
final double det = alift * ( bdxcdy - cdxbdy ) + blift * ocad + clift * oabd;
|
||||
|
||||
return det > 0;
|
||||
}
|
||||
|
||||
/**
|
||||
* @see smartIncircle
|
||||
* @param pa
|
||||
* @param pb
|
||||
* @param pc
|
||||
* @param pd
|
||||
* @return
|
||||
*/
|
||||
public static boolean inScanArea( final TriangulationPoint pa,
|
||||
final TriangulationPoint pb,
|
||||
final TriangulationPoint pc,
|
||||
final TriangulationPoint pd )
|
||||
{
|
||||
final double pdx = pd.getX();
|
||||
final double pdy = pd.getY();
|
||||
final double adx = pa.getX() - pdx;
|
||||
final double ady = pa.getY() - pdy;
|
||||
final double bdx = pb.getX() - pdx;
|
||||
final double bdy = pb.getY() - pdy;
|
||||
|
||||
final double adxbdy = adx * bdy;
|
||||
final double bdxady = bdx * ady;
|
||||
final double oabd = adxbdy - bdxady;
|
||||
// oabd = orient2d(pa,pb,pd);
|
||||
if( oabd <= 0 )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
final double cdx = pc.getX() - pdx;
|
||||
final double cdy = pc.getY() - pdy;
|
||||
|
||||
final double cdxady = cdx * ady;
|
||||
final double adxcdy = adx * cdy;
|
||||
final double ocad = cdxady - adxcdy;
|
||||
// ocad = orient2d(pc,pa,pd);
|
||||
if( ocad <= 0 )
|
||||
{
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Forumla to calculate signed area<br>
|
||||
* Positive if CCW<br>
|
||||
* Negative if CW<br>
|
||||
* 0 if collinear<br>
|
||||
* <pre>
|
||||
* A[P1,P2,P3] = (x1*y2 - y1*x2) + (x2*y3 - y2*x3) + (x3*y1 - y3*x1)
|
||||
* = (x1-x3)*(y2-y3) - (y1-y3)*(x2-x3)
|
||||
* </pre>
|
||||
*/
|
||||
public static Orientation orient2d( TriangulationPoint pa,
|
||||
TriangulationPoint pb,
|
||||
TriangulationPoint pc )
|
||||
{
|
||||
double detleft = ( pa.getX() - pc.getX() ) * ( pb.getY() - pc.getY() );
|
||||
double detright = ( pa.getY() - pc.getY() ) * ( pb.getX() - pc.getX() );
|
||||
double val = detleft - detright;
|
||||
if( val > -EPSILON && val < EPSILON )
|
||||
{
|
||||
return Orientation.Collinear;
|
||||
}
|
||||
else if( val > 0 )
|
||||
{
|
||||
return Orientation.CCW;
|
||||
}
|
||||
return Orientation.CW;
|
||||
}
|
||||
|
||||
public enum Orientation
|
||||
{
|
||||
CW,CCW,Collinear;
|
||||
}
|
||||
}
|
|
@ -1,685 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.delaunay;
|
||||
|
||||
import java.util.ArrayList;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
import org.poly2tri.triangulation.delaunay.sweep.DTSweepConstraint;
|
||||
import org.poly2tri.triangulation.point.TPoint;
|
||||
|
||||
|
||||
public class DelaunayTriangle
|
||||
{
|
||||
|
||||
/** Neighbor pointers */
|
||||
public final DelaunayTriangle[] neighbors = new DelaunayTriangle[3];
|
||||
/** Flags to determine if an edge is a Constrained edge */
|
||||
public final boolean[] cEdge = new boolean[] { false, false, false };
|
||||
/** Flags to determine if an edge is a Delauney edge */
|
||||
public final boolean[] dEdge = new boolean[] { false, false, false };
|
||||
/** Has this triangle been marked as an interior triangle? */
|
||||
protected boolean interior = false;
|
||||
|
||||
public final TriangulationPoint[] points = new TriangulationPoint[3];
|
||||
|
||||
public DelaunayTriangle( TriangulationPoint p1, TriangulationPoint p2, TriangulationPoint p3 )
|
||||
{
|
||||
points[0] = p1;
|
||||
points[1] = p2;
|
||||
points[2] = p3;
|
||||
}
|
||||
|
||||
public int index( TriangulationPoint p )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
else if( p == points[2] )
|
||||
{
|
||||
return 2;
|
||||
}
|
||||
throw new RuntimeException("Calling index with a point that doesn't exist in triangle");
|
||||
}
|
||||
|
||||
public int indexCW( TriangulationPoint p )
|
||||
{
|
||||
int index = index(p);
|
||||
switch( index )
|
||||
{
|
||||
case 0: return 2;
|
||||
case 1: return 0;
|
||||
default: return 1;
|
||||
}
|
||||
}
|
||||
|
||||
public int indexCCW( TriangulationPoint p )
|
||||
{
|
||||
int index = index(p);
|
||||
switch( index )
|
||||
{
|
||||
case 0: return 1;
|
||||
case 1: return 2;
|
||||
default: return 0;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean contains( TriangulationPoint p )
|
||||
{
|
||||
return ( p == points[0] || p == points[1] || p == points[2] );
|
||||
}
|
||||
|
||||
public boolean contains( DTSweepConstraint e )
|
||||
{
|
||||
return ( contains( e.p ) && contains( e.q ) );
|
||||
}
|
||||
|
||||
public boolean contains( TriangulationPoint p, TriangulationPoint q )
|
||||
{
|
||||
return ( contains( p ) && contains( q ) );
|
||||
}
|
||||
|
||||
// Update neighbor pointers
|
||||
private void markNeighbor( TriangulationPoint p1,
|
||||
TriangulationPoint p2,
|
||||
DelaunayTriangle t )
|
||||
{
|
||||
if( ( p1 == points[2] && p2 == points[1] ) || ( p1 == points[1] && p2 == points[2] ) )
|
||||
{
|
||||
neighbors[0] = t;
|
||||
}
|
||||
else if( ( p1 == points[0] && p2 == points[2] ) || ( p1 == points[2] && p2 == points[0] ) )
|
||||
{
|
||||
neighbors[1] = t;
|
||||
}
|
||||
else if( ( p1 == points[0] && p2 == points[1] ) || ( p1 == points[1] && p2 == points[0] ) )
|
||||
{
|
||||
neighbors[2] = t;
|
||||
}
|
||||
else
|
||||
{
|
||||
// throw new Exception("Neighbor error, please report!");
|
||||
}
|
||||
}
|
||||
|
||||
/* Exhaustive search to update neighbor pointers */
|
||||
public void markNeighbor( DelaunayTriangle t )
|
||||
{
|
||||
if( t.contains( points[1], points[2] ) )
|
||||
{
|
||||
neighbors[0] = t;
|
||||
t.markNeighbor( points[1], points[2], this );
|
||||
}
|
||||
else if( t.contains( points[0], points[2] ) )
|
||||
{
|
||||
neighbors[1] = t;
|
||||
t.markNeighbor( points[0], points[2], this );
|
||||
}
|
||||
else if( t.contains( points[0], points[1] ) )
|
||||
{
|
||||
neighbors[2] = t;
|
||||
t.markNeighbor( points[0], points[1], this );
|
||||
}
|
||||
else
|
||||
{
|
||||
}
|
||||
}
|
||||
|
||||
public void clearNeighbors()
|
||||
{
|
||||
neighbors[0] = neighbors[1] = neighbors[2] = null;
|
||||
}
|
||||
|
||||
public void clearNeighbor( DelaunayTriangle triangle )
|
||||
{
|
||||
if( neighbors[0] == triangle )
|
||||
{
|
||||
neighbors[0] = null;
|
||||
}
|
||||
else if( neighbors[1] == triangle )
|
||||
{
|
||||
neighbors[1] = null;
|
||||
}
|
||||
else
|
||||
{
|
||||
neighbors[2] = null;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Clears all references to all other triangles and points
|
||||
*/
|
||||
public void clear()
|
||||
{
|
||||
DelaunayTriangle t;
|
||||
for( int i=0; i<3; i++ )
|
||||
{
|
||||
t = neighbors[i];
|
||||
if( t != null )
|
||||
{
|
||||
t.clearNeighbor( this );
|
||||
}
|
||||
}
|
||||
clearNeighbors();
|
||||
points[0]=points[1]=points[2]=null;
|
||||
}
|
||||
/**
|
||||
* @param t - opposite triangle
|
||||
* @param p - the point in t that isn't shared between the triangles
|
||||
* @return
|
||||
*/
|
||||
public TriangulationPoint oppositePoint( DelaunayTriangle t, TriangulationPoint p )
|
||||
{
|
||||
assert t != this : "self-pointer error";
|
||||
return pointCW( t.pointCW(p) );
|
||||
}
|
||||
|
||||
// The neighbor clockwise to given point
|
||||
public DelaunayTriangle neighborCW( TriangulationPoint point )
|
||||
{
|
||||
if( point == points[0] )
|
||||
{
|
||||
return neighbors[1];
|
||||
}
|
||||
else if( point == points[1] )
|
||||
{
|
||||
return neighbors[2];
|
||||
}
|
||||
return neighbors[0];
|
||||
}
|
||||
|
||||
// The neighbor counter-clockwise to given point
|
||||
public DelaunayTriangle neighborCCW( TriangulationPoint point )
|
||||
{
|
||||
if( point == points[0] )
|
||||
{
|
||||
return neighbors[2];
|
||||
}
|
||||
else if( point == points[1] )
|
||||
{
|
||||
return neighbors[0];
|
||||
}
|
||||
return neighbors[1];
|
||||
}
|
||||
|
||||
// The neighbor across to given point
|
||||
public DelaunayTriangle neighborAcross( TriangulationPoint opoint )
|
||||
{
|
||||
if( opoint == points[0] )
|
||||
{
|
||||
return neighbors[0];
|
||||
}
|
||||
else if( opoint == points[1] )
|
||||
{
|
||||
return neighbors[1];
|
||||
}
|
||||
return neighbors[2];
|
||||
}
|
||||
|
||||
// The point counter-clockwise to given point
|
||||
public TriangulationPoint pointCCW( TriangulationPoint point )
|
||||
{
|
||||
if( point == points[0] )
|
||||
{
|
||||
return points[1];
|
||||
}
|
||||
else if( point == points[1] )
|
||||
{
|
||||
return points[2];
|
||||
}
|
||||
else if( point == points[2] )
|
||||
{
|
||||
return points[0];
|
||||
}
|
||||
throw new RuntimeException("[FIXME] point location error");
|
||||
}
|
||||
|
||||
// The point counter-clockwise to given point
|
||||
public TriangulationPoint pointCW( TriangulationPoint point )
|
||||
{
|
||||
if( point == points[0] )
|
||||
{
|
||||
return points[2];
|
||||
}
|
||||
else if( point == points[1] )
|
||||
{
|
||||
return points[0];
|
||||
}
|
||||
else if( point == points[2] )
|
||||
{
|
||||
return points[1];
|
||||
}
|
||||
throw new RuntimeException("[FIXME] point location error");
|
||||
}
|
||||
|
||||
// Legalize triangle by rotating clockwise around oPoint
|
||||
public void legalize( TriangulationPoint oPoint, TriangulationPoint nPoint )
|
||||
{
|
||||
if( oPoint == points[0] )
|
||||
{
|
||||
points[1] = points[0];
|
||||
points[0] = points[2];
|
||||
points[2] = nPoint;
|
||||
}
|
||||
else if( oPoint == points[1] )
|
||||
{
|
||||
points[2] = points[1];
|
||||
points[1] = points[0];
|
||||
points[0] = nPoint;
|
||||
}
|
||||
else if( oPoint == points[2] )
|
||||
{
|
||||
points[0] = points[2];
|
||||
points[2] = points[1];
|
||||
points[1] = nPoint;
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new RuntimeException("legalization bug");
|
||||
}
|
||||
}
|
||||
|
||||
public void printDebug()
|
||||
{
|
||||
System.out.println( points[0] + "," + points[1] + "," + points[2] );
|
||||
}
|
||||
|
||||
// Finalize edge marking
|
||||
public void markNeighborEdges()
|
||||
{
|
||||
for( int i = 0; i < 3; i++ )
|
||||
{
|
||||
if( cEdge[i] )
|
||||
{
|
||||
switch( i )
|
||||
{
|
||||
case 0:
|
||||
if( neighbors[0] != null )
|
||||
neighbors[0].markConstrainedEdge( points[1], points[2] );
|
||||
break;
|
||||
case 1:
|
||||
if( neighbors[1] != null )
|
||||
neighbors[1].markConstrainedEdge( points[0], points[2] );
|
||||
break;
|
||||
case 2:
|
||||
if( neighbors[2] != null )
|
||||
neighbors[2].markConstrainedEdge( points[0], points[1] );
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void markEdge( DelaunayTriangle triangle )
|
||||
{
|
||||
for( int i = 0; i < 3; i++ )
|
||||
{
|
||||
if( cEdge[i] )
|
||||
{
|
||||
switch( i )
|
||||
{
|
||||
case 0:
|
||||
triangle.markConstrainedEdge( points[1], points[2] );
|
||||
break;
|
||||
case 1:
|
||||
triangle.markConstrainedEdge( points[0], points[2] );
|
||||
break;
|
||||
case 2:
|
||||
triangle.markConstrainedEdge( points[0], points[1] );
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void markEdge( ArrayList<DelaunayTriangle> tList )
|
||||
{
|
||||
|
||||
for( DelaunayTriangle t : tList )
|
||||
{
|
||||
for( int i = 0; i < 3; i++ )
|
||||
{
|
||||
if( t.cEdge[i] )
|
||||
{
|
||||
switch( i )
|
||||
{
|
||||
case 0:
|
||||
markConstrainedEdge( t.points[1], t.points[2] );
|
||||
break;
|
||||
case 1:
|
||||
markConstrainedEdge( t.points[0], t.points[2] );
|
||||
break;
|
||||
case 2:
|
||||
markConstrainedEdge( t.points[0], t.points[1] );
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void markConstrainedEdge( int index )
|
||||
{
|
||||
cEdge[index] = true;
|
||||
}
|
||||
|
||||
public void markConstrainedEdge( DTSweepConstraint edge )
|
||||
{
|
||||
markConstrainedEdge( edge.p, edge.q );
|
||||
if( ( edge.q == points[0] && edge.p == points[1] )
|
||||
|| ( edge.q == points[1] && edge.p == points[0] ) )
|
||||
{
|
||||
cEdge[2] = true;
|
||||
}
|
||||
else if( ( edge.q == points[0] && edge.p == points[2] )
|
||||
|| ( edge.q == points[2] && edge.p == points[0] ) )
|
||||
{
|
||||
cEdge[1] = true;
|
||||
}
|
||||
else if( ( edge.q == points[1] && edge.p == points[2] )
|
||||
|| ( edge.q == points[2] && edge.p == points[1] ) )
|
||||
{
|
||||
cEdge[0] = true;
|
||||
}
|
||||
}
|
||||
|
||||
// Mark edge as constrained
|
||||
public void markConstrainedEdge( TriangulationPoint p, TriangulationPoint q )
|
||||
{
|
||||
if( ( q == points[0] && p == points[1] ) || ( q == points[1] && p == points[0] ) )
|
||||
{
|
||||
cEdge[2] = true;
|
||||
}
|
||||
else if( ( q == points[0] && p == points[2] ) || ( q == points[2] && p == points[0] ) )
|
||||
{
|
||||
cEdge[1] = true;
|
||||
}
|
||||
else if( ( q == points[1] && p == points[2] ) || ( q == points[2] && p == points[1] ) )
|
||||
{
|
||||
cEdge[0] = true;
|
||||
}
|
||||
}
|
||||
|
||||
public double area()
|
||||
{
|
||||
double a = (points[0].getX() - points[2].getX())*(points[1].getY() - points[0].getY());
|
||||
double b = (points[0].getX() - points[1].getX())*(points[2].getY() - points[0].getY());
|
||||
|
||||
return 0.5*Math.abs( a - b );
|
||||
}
|
||||
|
||||
public TPoint centroid()
|
||||
{
|
||||
double cx = ( points[0].getX() + points[1].getX() + points[2].getX() ) / 3d;
|
||||
double cy = ( points[0].getY() + points[1].getY() + points[2].getY() ) / 3d;
|
||||
return new TPoint( cx, cy );
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the neighbor that share this edge
|
||||
*
|
||||
* @param constrainedEdge
|
||||
* @return index of the shared edge or -1 if edge isn't shared
|
||||
*/
|
||||
public int edgeIndex( TriangulationPoint p1, TriangulationPoint p2 )
|
||||
{
|
||||
if( points[0] == p1 )
|
||||
{
|
||||
if( points[1] == p2 )
|
||||
{
|
||||
return 2;
|
||||
}
|
||||
else if( points[2] == p2 )
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
else if( points[1] == p1 )
|
||||
{
|
||||
if( points[2] == p2 )
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
else if( points[0] == p2 )
|
||||
{
|
||||
return 2;
|
||||
}
|
||||
}
|
||||
else if( points[2] == p1 )
|
||||
{
|
||||
if( points[0] == p2 )
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
else if( points[1] == p2 )
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
public boolean getConstrainedEdgeCCW( TriangulationPoint p )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
return cEdge[2];
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
return cEdge[0];
|
||||
}
|
||||
return cEdge[1];
|
||||
}
|
||||
|
||||
public boolean getConstrainedEdgeCW( TriangulationPoint p )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
return cEdge[1];
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
return cEdge[2];
|
||||
}
|
||||
return cEdge[0];
|
||||
}
|
||||
|
||||
public boolean getConstrainedEdgeAcross( TriangulationPoint p )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
return cEdge[0];
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
return cEdge[1];
|
||||
}
|
||||
return cEdge[2];
|
||||
}
|
||||
|
||||
public void setConstrainedEdgeCCW( TriangulationPoint p, boolean ce )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
cEdge[2] = ce;
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
cEdge[0] = ce;
|
||||
}
|
||||
else
|
||||
{
|
||||
cEdge[1] = ce;
|
||||
}
|
||||
}
|
||||
|
||||
public void setConstrainedEdgeCW( TriangulationPoint p, boolean ce )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
cEdge[1] = ce;
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
cEdge[2] = ce;
|
||||
}
|
||||
else
|
||||
{
|
||||
cEdge[0] = ce;
|
||||
}
|
||||
}
|
||||
|
||||
public void setConstrainedEdgeAcross( TriangulationPoint p, boolean ce )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
cEdge[0] = ce;
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
cEdge[1] = ce;
|
||||
}
|
||||
else
|
||||
{
|
||||
cEdge[2] = ce;
|
||||
}
|
||||
}
|
||||
|
||||
public boolean getDelunayEdgeCCW( TriangulationPoint p )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
return dEdge[2];
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
return dEdge[0];
|
||||
}
|
||||
return dEdge[1];
|
||||
}
|
||||
|
||||
public boolean getDelunayEdgeCW( TriangulationPoint p )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
return dEdge[1];
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
return dEdge[2];
|
||||
}
|
||||
return dEdge[0];
|
||||
}
|
||||
|
||||
public boolean getDelunayEdgeAcross( TriangulationPoint p )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
return dEdge[0];
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
return dEdge[1];
|
||||
}
|
||||
return dEdge[2];
|
||||
}
|
||||
|
||||
public void setDelunayEdgeCCW( TriangulationPoint p, boolean e )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
dEdge[2] = e;
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
dEdge[0] = e;
|
||||
}
|
||||
else
|
||||
{
|
||||
dEdge[1] = e;
|
||||
}
|
||||
}
|
||||
|
||||
public void setDelunayEdgeCW( TriangulationPoint p, boolean e )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
dEdge[1] = e;
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
dEdge[2] = e;
|
||||
}
|
||||
else
|
||||
{
|
||||
dEdge[0] = e;
|
||||
}
|
||||
}
|
||||
|
||||
public void setDelunayEdgeAcross( TriangulationPoint p, boolean e )
|
||||
{
|
||||
if( p == points[0] )
|
||||
{
|
||||
dEdge[0] = e;
|
||||
}
|
||||
else if( p == points[1] )
|
||||
{
|
||||
dEdge[1] = e;
|
||||
}
|
||||
else
|
||||
{
|
||||
dEdge[2] = e;
|
||||
}
|
||||
}
|
||||
|
||||
public void clearDelunayEdges()
|
||||
{
|
||||
dEdge[0] = false;
|
||||
dEdge[1] = false;
|
||||
dEdge[2] = false;
|
||||
}
|
||||
|
||||
public boolean isInterior()
|
||||
{
|
||||
return interior;
|
||||
}
|
||||
|
||||
public void isInterior( boolean b )
|
||||
{
|
||||
interior = b;
|
||||
}
|
||||
}
|
|
@ -1,179 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
|
||||
|
||||
/**
|
||||
* @author Thomas Åhlen (thahlen@gmail.com)
|
||||
*/
|
||||
public class AdvancingFront
|
||||
{
|
||||
public AdvancingFrontNode head;
|
||||
public AdvancingFrontNode tail;
|
||||
protected AdvancingFrontNode search;
|
||||
|
||||
public AdvancingFront( AdvancingFrontNode head, AdvancingFrontNode tail )
|
||||
{
|
||||
this.head = head;
|
||||
this.tail = tail;
|
||||
this.search = head;
|
||||
addNode( head );
|
||||
addNode( tail );
|
||||
}
|
||||
|
||||
public void addNode( AdvancingFrontNode node )
|
||||
{
|
||||
// _searchTree.put( node.key, node );
|
||||
}
|
||||
|
||||
public void removeNode( AdvancingFrontNode node )
|
||||
{
|
||||
// _searchTree.delete( node.key );
|
||||
}
|
||||
|
||||
public String toString()
|
||||
{
|
||||
StringBuilder sb = new StringBuilder();
|
||||
AdvancingFrontNode node = head;
|
||||
while( node != tail )
|
||||
{
|
||||
sb.append( node.point.getX() ).append( "->" );
|
||||
node = node.next;
|
||||
}
|
||||
sb.append( tail.point.getX() );
|
||||
return sb.toString();
|
||||
}
|
||||
|
||||
private final AdvancingFrontNode findSearchNode( double x )
|
||||
{
|
||||
// TODO: implement BST index
|
||||
return search;
|
||||
}
|
||||
|
||||
/**
|
||||
* We use a balancing tree to locate a node smaller or equal to
|
||||
* given key value
|
||||
*
|
||||
* @param x
|
||||
* @return
|
||||
*/
|
||||
public AdvancingFrontNode locateNode( TriangulationPoint point )
|
||||
{
|
||||
return locateNode( point.getX() );
|
||||
}
|
||||
|
||||
private AdvancingFrontNode locateNode( double x )
|
||||
{
|
||||
AdvancingFrontNode node = findSearchNode(x);
|
||||
if( x < node.value )
|
||||
{
|
||||
while( (node = node.prev) != null )
|
||||
{
|
||||
if( x >= node.value )
|
||||
{
|
||||
search = node;
|
||||
return node;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
while( (node = node.next) != null )
|
||||
{
|
||||
if( x < node.value )
|
||||
{
|
||||
search = node.prev;
|
||||
return node.prev;
|
||||
}
|
||||
}
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* This implementation will use simple node traversal algorithm to find
|
||||
* a point on the front
|
||||
*
|
||||
* @param point
|
||||
* @return
|
||||
*/
|
||||
public AdvancingFrontNode locatePoint( final TriangulationPoint point )
|
||||
{
|
||||
final double px = point.getX();
|
||||
AdvancingFrontNode node = findSearchNode(px);
|
||||
final double nx = node.point.getX();
|
||||
|
||||
if( px == nx )
|
||||
{
|
||||
if( point != node.point )
|
||||
{
|
||||
// We might have two nodes with same x value for a short time
|
||||
if( point == node.prev.point )
|
||||
{
|
||||
node = node.prev;
|
||||
}
|
||||
else if( point == node.next.point )
|
||||
{
|
||||
node = node.next;
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new RuntimeException( "Failed to find Node for given afront point");
|
||||
// node = null;
|
||||
}
|
||||
}
|
||||
}
|
||||
else if( px < nx )
|
||||
{
|
||||
while( (node = node.prev) != null )
|
||||
{
|
||||
if( point == node.point )
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
while( (node = node.next) != null )
|
||||
{
|
||||
if( point == node.point )
|
||||
{
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
search = node;
|
||||
return node;
|
||||
}
|
||||
}
|
|
@ -1,43 +0,0 @@
|
|||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
public class AdvancingFrontIndex<A>
|
||||
{
|
||||
double _min,_max;
|
||||
IndexNode<A> _root;
|
||||
|
||||
public AdvancingFrontIndex( double min, double max, int depth )
|
||||
{
|
||||
if( depth > 5 ) depth = 5;
|
||||
_root = createIndex( depth );
|
||||
}
|
||||
|
||||
private IndexNode<A> createIndex( int n )
|
||||
{
|
||||
IndexNode<A> node = null;
|
||||
if( n > 0 )
|
||||
{
|
||||
node = new IndexNode<A>();
|
||||
node.bigger = createIndex( n-1 );
|
||||
node.smaller = createIndex( n-1 );
|
||||
}
|
||||
return node;
|
||||
}
|
||||
|
||||
public A fetchAndRemoveIndex( A key )
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
public A fetchAndInsertIndex( A key )
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
class IndexNode<A>
|
||||
{
|
||||
A value;
|
||||
IndexNode<A> smaller;
|
||||
IndexNode<A> bigger;
|
||||
double range;
|
||||
}
|
||||
}
|
|
@ -1,84 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
import org.poly2tri.triangulation.delaunay.DelaunayTriangle;
|
||||
|
||||
|
||||
|
||||
public class AdvancingFrontNode
|
||||
{
|
||||
protected AdvancingFrontNode next = null;
|
||||
protected AdvancingFrontNode prev = null;
|
||||
|
||||
protected final Double key; // XXX: BST
|
||||
protected final double value;
|
||||
protected final TriangulationPoint point;
|
||||
protected DelaunayTriangle triangle;
|
||||
|
||||
public AdvancingFrontNode( TriangulationPoint point )
|
||||
{
|
||||
this.point = point;
|
||||
value = point.getX();
|
||||
key = Double.valueOf( value ); // XXX: BST
|
||||
}
|
||||
|
||||
public AdvancingFrontNode getNext()
|
||||
{
|
||||
return next;
|
||||
}
|
||||
|
||||
public AdvancingFrontNode getPrevious()
|
||||
{
|
||||
return prev;
|
||||
}
|
||||
|
||||
public TriangulationPoint getPoint()
|
||||
{
|
||||
return point;
|
||||
}
|
||||
|
||||
public DelaunayTriangle getTriangle()
|
||||
{
|
||||
return triangle;
|
||||
}
|
||||
|
||||
public boolean hasNext()
|
||||
{
|
||||
return next != null;
|
||||
}
|
||||
|
||||
public boolean hasPrevious()
|
||||
{
|
||||
return prev != null;
|
||||
}
|
||||
}
|
File diff suppressed because it is too large
Load diff
|
@ -1,103 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
import java.util.logging.Logger;
|
||||
import org.poly2tri.triangulation.TriangulationConstraint;
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author Thomas Åhlén, thahlen@gmail.com
|
||||
*
|
||||
*/
|
||||
public class DTSweepConstraint extends TriangulationConstraint
|
||||
{
|
||||
|
||||
public TriangulationPoint p;
|
||||
public TriangulationPoint q;
|
||||
|
||||
/**
|
||||
* Give two points in any order. Will always be ordered so
|
||||
* that q.y > p.y and q.x > p.x if same y value
|
||||
*
|
||||
* @param p1
|
||||
* @param p2
|
||||
*/
|
||||
public DTSweepConstraint( TriangulationPoint p1, TriangulationPoint p2 )
|
||||
// throws DuplicatePointException
|
||||
{
|
||||
p = p1;
|
||||
q = p2;
|
||||
if( p1.getY() > p2.getY() )
|
||||
{
|
||||
q = p1;
|
||||
p = p2;
|
||||
}
|
||||
else if( p1.getY() == p2.getY() )
|
||||
{
|
||||
if( p1.getX() > p2.getX() )
|
||||
{
|
||||
q = p1;
|
||||
p = p2;
|
||||
}
|
||||
else if( p1.getX() == p2.getX() )
|
||||
{
|
||||
// throw new DuplicatePointException( p1 + "=" + p2 );
|
||||
// return;
|
||||
}
|
||||
}
|
||||
q.addEdge(this);
|
||||
}
|
||||
|
||||
// public TPoint intersect( TPoint a, TPoint b )
|
||||
// {
|
||||
// double pqx,pqy,bax,bay,t;
|
||||
//
|
||||
// pqx = p.getX()-q.getX();
|
||||
// pqy = p.getY()-q.getY();
|
||||
// t = pqy*(a.getX()-q.getX()) - pqx*(a.getY()-q.getY() );
|
||||
// t /= pqx*(b.getY()-a.getY()) - pqy*(b.getX()-a.getX());
|
||||
// bax = t*(b.getX()-a.getX()) + a.getX();
|
||||
// bay = t*(b.getY()-a.getY()) + a.getY();
|
||||
// return new TPoint( bax, bay );
|
||||
// }
|
||||
|
||||
public TriangulationPoint getP()
|
||||
{
|
||||
return p;
|
||||
}
|
||||
|
||||
public TriangulationPoint getQ()
|
||||
{
|
||||
return q;
|
||||
}
|
||||
}
|
|
@ -1,280 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
import java.util.ArrayDeque;
|
||||
import java.util.Collections;
|
||||
import org.poly2tri.triangulation.Triangulatable;
|
||||
import org.poly2tri.triangulation.TriangulationAlgorithm;
|
||||
import org.poly2tri.triangulation.TriangulationConstraint;
|
||||
import org.poly2tri.triangulation.TriangulationContext;
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
import org.poly2tri.triangulation.delaunay.DelaunayTriangle;
|
||||
import org.poly2tri.triangulation.point.TPoint;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author Thomas Åhlén, thahlen@gmail.com
|
||||
*
|
||||
*/
|
||||
public class DTSweepContext extends TriangulationContext<DTSweepDebugContext>
|
||||
{
|
||||
|
||||
// Inital triangle factor, seed triangle will extend 30% of
|
||||
// PointSet width to both left and right.
|
||||
private final float ALPHA = 0.3f;
|
||||
|
||||
/** Advancing front **/
|
||||
protected AdvancingFront aFront;
|
||||
/** head point used with advancing front */
|
||||
private TriangulationPoint _head;
|
||||
/** tail point used with advancing front */
|
||||
private TriangulationPoint _tail;
|
||||
protected Basin basin = new Basin();
|
||||
protected EdgeEvent edgeEvent = new EdgeEvent();
|
||||
|
||||
private DTSweepPointComparator _comparator = new DTSweepPointComparator();
|
||||
|
||||
public DTSweepContext()
|
||||
{
|
||||
clear();
|
||||
}
|
||||
|
||||
public void isDebugEnabled( boolean b )
|
||||
{
|
||||
if( b )
|
||||
{
|
||||
if( _debug == null )
|
||||
{
|
||||
_debug = new DTSweepDebugContext(this);
|
||||
}
|
||||
}
|
||||
_debugEnabled = b;
|
||||
}
|
||||
|
||||
public void removeFromList( DelaunayTriangle triangle )
|
||||
{
|
||||
_triList.remove( triangle );
|
||||
// TODO: remove all neighbor pointers to this triangle
|
||||
// for( int i=0; i<3; i++ )
|
||||
// {
|
||||
// if( triangle.neighbors[i] != null )
|
||||
// {
|
||||
// triangle.neighbors[i].clearNeighbor( triangle );
|
||||
// }
|
||||
// }
|
||||
// triangle.clearNeighbors();
|
||||
}
|
||||
|
||||
protected void meshClean(DelaunayTriangle triangle)
|
||||
{
|
||||
DelaunayTriangle t1,t2;
|
||||
if( triangle != null )
|
||||
{
|
||||
ArrayDeque<DelaunayTriangle> deque = new ArrayDeque<DelaunayTriangle>();
|
||||
deque.addFirst(triangle);
|
||||
triangle.isInterior(true);
|
||||
|
||||
while( !deque.isEmpty() )
|
||||
{
|
||||
t1 = deque.removeFirst();
|
||||
_triUnit.addTriangle( t1 );
|
||||
for( int i=0; i<3; ++i )
|
||||
{
|
||||
if( !t1.cEdge[i] )
|
||||
{
|
||||
t2 = t1.neighbors[i];
|
||||
if( t2 != null && !t2.isInterior() )
|
||||
{
|
||||
t2.isInterior(true);
|
||||
deque.addLast(t2);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public void clear()
|
||||
{
|
||||
super.clear();
|
||||
_triList.clear();
|
||||
}
|
||||
|
||||
public AdvancingFront getAdvancingFront()
|
||||
{
|
||||
return aFront;
|
||||
}
|
||||
|
||||
public void setHead( TriangulationPoint p1 ) { _head = p1; }
|
||||
public TriangulationPoint getHead() { return _head; }
|
||||
|
||||
public void setTail( TriangulationPoint p1 ) { _tail = p1; }
|
||||
public TriangulationPoint getTail() { return _tail; }
|
||||
|
||||
public void addNode( AdvancingFrontNode node )
|
||||
{
|
||||
// System.out.println( "add:" + node.key + ":" + System.identityHashCode(node.key));
|
||||
// m_nodeTree.put( node.getKey(), node );
|
||||
aFront.addNode( node );
|
||||
}
|
||||
|
||||
public void removeNode( AdvancingFrontNode node )
|
||||
{
|
||||
// System.out.println( "remove:" + node.key + ":" + System.identityHashCode(node.key));
|
||||
// m_nodeTree.delete( node.getKey() );
|
||||
aFront.removeNode( node );
|
||||
}
|
||||
|
||||
public AdvancingFrontNode locateNode( TriangulationPoint point )
|
||||
{
|
||||
return aFront.locateNode( point );
|
||||
}
|
||||
|
||||
public void createAdvancingFront()
|
||||
{
|
||||
AdvancingFrontNode head,tail,middle;
|
||||
// Initial triangle
|
||||
DelaunayTriangle iTriangle = new DelaunayTriangle( _points.get(0),
|
||||
getTail(),
|
||||
getHead() );
|
||||
addToList( iTriangle );
|
||||
|
||||
head = new AdvancingFrontNode( iTriangle.points[1] );
|
||||
head.triangle = iTriangle;
|
||||
middle = new AdvancingFrontNode( iTriangle.points[0] );
|
||||
middle.triangle = iTriangle;
|
||||
tail = new AdvancingFrontNode( iTriangle.points[2] );
|
||||
|
||||
aFront = new AdvancingFront( head, tail );
|
||||
aFront.addNode( middle );
|
||||
|
||||
// TODO: I think it would be more intuitive if head is middles next and not previous
|
||||
// so swap head and tail
|
||||
aFront.head.next = middle;
|
||||
middle.next = aFront.tail;
|
||||
middle.prev = aFront.head;
|
||||
aFront.tail.prev = middle;
|
||||
}
|
||||
|
||||
class Basin
|
||||
{
|
||||
AdvancingFrontNode leftNode;
|
||||
AdvancingFrontNode bottomNode;
|
||||
AdvancingFrontNode rightNode;
|
||||
public double width;
|
||||
public boolean leftHighest;
|
||||
}
|
||||
|
||||
class EdgeEvent
|
||||
{
|
||||
DTSweepConstraint constrainedEdge;
|
||||
public boolean right;
|
||||
}
|
||||
|
||||
/**
|
||||
* Try to map a node to all sides of this triangle that don't have
|
||||
* a neighbor.
|
||||
*
|
||||
* @param t
|
||||
*/
|
||||
public void mapTriangleToNodes( DelaunayTriangle t )
|
||||
{
|
||||
AdvancingFrontNode n;
|
||||
for( int i=0; i<3; i++ )
|
||||
{
|
||||
if( t.neighbors[i] == null )
|
||||
{
|
||||
n = aFront.locatePoint( t.pointCW( t.points[i] ) );
|
||||
if( n != null )
|
||||
{
|
||||
n.triangle = t;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void prepareTriangulation( Triangulatable t )
|
||||
{
|
||||
super.prepareTriangulation( t );
|
||||
|
||||
double xmax, xmin;
|
||||
double ymax, ymin;
|
||||
|
||||
xmax = xmin = _points.get(0).getX();
|
||||
ymax = ymin = _points.get(0).getY();
|
||||
// Calculate bounds. Should be combined with the sorting
|
||||
for( TriangulationPoint p : _points )
|
||||
{
|
||||
if( p.getX() > xmax )
|
||||
xmax = p.getX();
|
||||
if( p.getX() < xmin )
|
||||
xmin = p.getX();
|
||||
if( p.getY() > ymax )
|
||||
ymax = p.getY();
|
||||
if( p.getY() < ymin )
|
||||
ymin = p.getY();
|
||||
}
|
||||
|
||||
double deltaX = ALPHA * ( xmax - xmin );
|
||||
double deltaY = ALPHA * ( ymax - ymin );
|
||||
TPoint p1 = new TPoint( xmax + deltaX, ymin - deltaY );
|
||||
TPoint p2 = new TPoint( xmin - deltaX, ymin - deltaY );
|
||||
|
||||
setHead( p1 );
|
||||
setTail( p2 );
|
||||
|
||||
// long time = System.nanoTime();
|
||||
// Sort the points along y-axis
|
||||
Collections.sort( _points, _comparator );
|
||||
// logger.info( "Triangulation setup [{}ms]", ( System.nanoTime() - time ) / 1e6 );
|
||||
}
|
||||
|
||||
|
||||
public void finalizeTriangulation()
|
||||
{
|
||||
_triUnit.addTriangles( _triList );
|
||||
_triList.clear();
|
||||
}
|
||||
|
||||
@Override
|
||||
public TriangulationConstraint newConstraint( TriangulationPoint a, TriangulationPoint b )
|
||||
{
|
||||
return new DTSweepConstraint( a, b );
|
||||
}
|
||||
|
||||
@Override
|
||||
public TriangulationAlgorithm algorithm()
|
||||
{
|
||||
return TriangulationAlgorithm.DTSweep;
|
||||
}
|
||||
}
|
|
@ -1,105 +0,0 @@
|
|||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationContext;
|
||||
import org.poly2tri.triangulation.TriangulationDebugContext;
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
import org.poly2tri.triangulation.delaunay.DelaunayTriangle;
|
||||
|
||||
public class DTSweepDebugContext extends TriangulationDebugContext
|
||||
{
|
||||
/*
|
||||
* Fields used for visual representation of current triangulation
|
||||
*/
|
||||
protected DelaunayTriangle _primaryTriangle;
|
||||
protected DelaunayTriangle _secondaryTriangle;
|
||||
protected TriangulationPoint _activePoint;
|
||||
protected AdvancingFrontNode _activeNode;
|
||||
protected DTSweepConstraint _activeConstraint;
|
||||
|
||||
public DTSweepDebugContext( DTSweepContext tcx )
|
||||
{
|
||||
super( tcx );
|
||||
}
|
||||
|
||||
public boolean isDebugContext()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
// private Tuple2<TPoint,Double> m_circumCircle = new Tuple2<TPoint,Double>( new TPoint(), new Double(0) );
|
||||
// public Tuple2<TPoint,Double> getCircumCircle() { return m_circumCircle; }
|
||||
public DelaunayTriangle getPrimaryTriangle()
|
||||
{
|
||||
return _primaryTriangle;
|
||||
}
|
||||
|
||||
public DelaunayTriangle getSecondaryTriangle()
|
||||
{
|
||||
return _secondaryTriangle;
|
||||
}
|
||||
|
||||
public AdvancingFrontNode getActiveNode()
|
||||
{
|
||||
return _activeNode;
|
||||
}
|
||||
|
||||
public DTSweepConstraint getActiveConstraint()
|
||||
{
|
||||
return _activeConstraint;
|
||||
}
|
||||
|
||||
public TriangulationPoint getActivePoint()
|
||||
{
|
||||
return _activePoint;
|
||||
}
|
||||
|
||||
public void setPrimaryTriangle( DelaunayTriangle triangle )
|
||||
{
|
||||
_primaryTriangle = triangle;
|
||||
_tcx.update("setPrimaryTriangle");
|
||||
}
|
||||
|
||||
public void setSecondaryTriangle( DelaunayTriangle triangle )
|
||||
{
|
||||
_secondaryTriangle = triangle;
|
||||
_tcx.update("setSecondaryTriangle");
|
||||
}
|
||||
|
||||
public void setActivePoint( TriangulationPoint point )
|
||||
{
|
||||
_activePoint = point;
|
||||
}
|
||||
|
||||
public void setActiveConstraint( DTSweepConstraint e )
|
||||
{
|
||||
_activeConstraint = e;
|
||||
_tcx.update("setWorkingSegment");
|
||||
}
|
||||
|
||||
public void setActiveNode( AdvancingFrontNode node )
|
||||
{
|
||||
_activeNode = node;
|
||||
_tcx.update("setWorkingNode");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void clear()
|
||||
{
|
||||
_primaryTriangle = null;
|
||||
_secondaryTriangle = null;
|
||||
_activePoint = null;
|
||||
_activeNode = null;
|
||||
_activeConstraint = null;
|
||||
}
|
||||
|
||||
// public void setWorkingCircumCircle( TPoint point, TPoint point2, TPoint point3 )
|
||||
// {
|
||||
// double dx,dy;
|
||||
//
|
||||
// CircleXY.circumCenter( point, point2, point3, m_circumCircle.a );
|
||||
// dx = m_circumCircle.a.getX()-point.getX();
|
||||
// dy = m_circumCircle.a.getY()-point.getY();
|
||||
// m_circumCircle.b = Double.valueOf( Math.sqrt( dx*dx + dy*dy ) );
|
||||
//
|
||||
// }
|
||||
}
|
|
@ -1,35 +0,0 @@
|
|||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
import java.util.Comparator;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
|
||||
public class DTSweepPointComparator implements Comparator<TriangulationPoint>
|
||||
{
|
||||
public int compare( TriangulationPoint p1, TriangulationPoint p2 )
|
||||
{
|
||||
if(p1.getY() < p2.getY() )
|
||||
{
|
||||
return -1;
|
||||
}
|
||||
else if( p1.getY() > p2.getY())
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
if(p1.getX() < p2.getX())
|
||||
{
|
||||
return -1;
|
||||
}
|
||||
else if( p1.getX() > p2.getX() )
|
||||
{
|
||||
return 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
|
@ -1,15 +0,0 @@
|
|||
package org.poly2tri.triangulation.delaunay.sweep;
|
||||
|
||||
public class PointOnEdgeException extends RuntimeException
|
||||
{
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
private static final long serialVersionUID = 1L;
|
||||
|
||||
public PointOnEdgeException( String msg )
|
||||
{
|
||||
super(msg);
|
||||
}
|
||||
}
|
|
@ -1,94 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.point;
|
||||
|
||||
import java.nio.FloatBuffer;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
|
||||
|
||||
public class FloatBufferPoint extends TriangulationPoint
|
||||
{
|
||||
private final FloatBuffer _fb;
|
||||
private final int _ix,_iy,_iz;
|
||||
|
||||
public FloatBufferPoint( FloatBuffer fb, int index )
|
||||
{
|
||||
_fb = fb;
|
||||
_ix = index;
|
||||
_iy = index+1;
|
||||
_iz = index+2;
|
||||
}
|
||||
|
||||
public final double getX()
|
||||
{
|
||||
return _fb.get( _ix );
|
||||
}
|
||||
public final double getY()
|
||||
{
|
||||
return _fb.get( _iy );
|
||||
}
|
||||
public final double getZ()
|
||||
{
|
||||
return _fb.get( _iz );
|
||||
}
|
||||
|
||||
public final float getXf()
|
||||
{
|
||||
return _fb.get( _ix );
|
||||
}
|
||||
public final float getYf()
|
||||
{
|
||||
return _fb.get( _iy );
|
||||
}
|
||||
public final float getZf()
|
||||
{
|
||||
return _fb.get( _iz );
|
||||
}
|
||||
|
||||
@Override
|
||||
public void set( double x, double y, double z )
|
||||
{
|
||||
_fb.put( _ix, (float)x );
|
||||
_fb.put( _iy, (float)y );
|
||||
_fb.put( _iz, (float)z );
|
||||
}
|
||||
|
||||
public static TriangulationPoint[] toPoints( FloatBuffer fb )
|
||||
{
|
||||
FloatBufferPoint[] points = new FloatBufferPoint[fb.limit()/3];
|
||||
for( int i=0,j=0; i<points.length; i++, j+=3 )
|
||||
{
|
||||
points[i] = new FloatBufferPoint(fb, j);
|
||||
}
|
||||
return points;
|
||||
}
|
||||
}
|
|
@ -1,69 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.point;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
|
||||
public class TPoint extends TriangulationPoint
|
||||
{
|
||||
private double _x;
|
||||
private double _y;
|
||||
private double _z;
|
||||
|
||||
public TPoint( double x, double y )
|
||||
{
|
||||
this( x, y, 0 );
|
||||
}
|
||||
|
||||
public TPoint( double x, double y, double z )
|
||||
{
|
||||
_x = x;
|
||||
_y = y;
|
||||
_z = z;
|
||||
}
|
||||
|
||||
public double getX() { return _x; }
|
||||
public double getY() { return _y; }
|
||||
public double getZ() { return _z; }
|
||||
|
||||
public float getXf() { return (float)_x; }
|
||||
public float getYf() { return (float)_y; }
|
||||
public float getZf() { return (float)_z; }
|
||||
|
||||
@Override
|
||||
public void set( double x, double y, double z )
|
||||
{
|
||||
_x = x;
|
||||
_y = y;
|
||||
_z = z;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,121 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.sets;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationContext;
|
||||
import org.poly2tri.triangulation.TriangulationMode;
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
|
||||
/**
|
||||
* Extends the PointSet by adding some Constraints on how it will be triangulated<br>
|
||||
* A constraint defines an edge between two points in the set, these edges can not
|
||||
* be crossed. They will be enforced triangle edges after a triangulation.
|
||||
* <p>
|
||||
*
|
||||
*
|
||||
* @author Thomas Åhlén, thahlen@gmail.com
|
||||
*/
|
||||
public class ConstrainedPointSet extends PointSet
|
||||
{
|
||||
int[] _index;
|
||||
List<TriangulationPoint> _constrainedPointList = null;
|
||||
|
||||
public ConstrainedPointSet( List<TriangulationPoint> points, int[] index )
|
||||
{
|
||||
super( points );
|
||||
_index = index;
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @param points - A list of all points in PointSet
|
||||
* @param constraints - Pairs of two points defining a constraint, all points <b>must</b> be part of given PointSet!
|
||||
*/
|
||||
public ConstrainedPointSet( List<TriangulationPoint> points, List<TriangulationPoint> constraints )
|
||||
{
|
||||
super( points );
|
||||
_constrainedPointList = new ArrayList<TriangulationPoint>();
|
||||
_constrainedPointList.addAll(constraints);
|
||||
}
|
||||
|
||||
@Override
|
||||
public TriangulationMode getTriangulationMode()
|
||||
{
|
||||
return TriangulationMode.CONSTRAINED;
|
||||
}
|
||||
|
||||
public int[] getEdgeIndex()
|
||||
{
|
||||
return _index;
|
||||
}
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
@Override
|
||||
public void prepareTriangulation( TriangulationContext tcx )
|
||||
{
|
||||
super.prepareTriangulation( tcx );
|
||||
if( _constrainedPointList != null )
|
||||
{
|
||||
TriangulationPoint p1,p2;
|
||||
Iterator iterator = _constrainedPointList.iterator();
|
||||
while(iterator.hasNext())
|
||||
{
|
||||
p1 = (TriangulationPoint)iterator.next();
|
||||
p2 = (TriangulationPoint)iterator.next();
|
||||
tcx.newConstraint(p1,p2);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
for( int i = 0; i < _index.length; i+=2 )
|
||||
{
|
||||
// XXX: must change!!
|
||||
tcx.newConstraint( _points.get( _index[i] ), _points.get( _index[i+1] ) );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* TODO: TO BE IMPLEMENTED!
|
||||
* Peforms a validation on given input<br>
|
||||
* 1. Check's if there any constraint edges are crossing or collinear<br>
|
||||
* 2.
|
||||
* @return
|
||||
*/
|
||||
public boolean isValid()
|
||||
{
|
||||
return true;
|
||||
}
|
||||
}
|
|
@ -1,95 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.sets;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.triangulation.Triangulatable;
|
||||
import org.poly2tri.triangulation.TriangulationContext;
|
||||
import org.poly2tri.triangulation.TriangulationMode;
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
import org.poly2tri.triangulation.delaunay.DelaunayTriangle;
|
||||
|
||||
public class PointSet implements Triangulatable
|
||||
{
|
||||
List<TriangulationPoint> _points;
|
||||
List<DelaunayTriangle> _triangles;
|
||||
|
||||
public PointSet( List<TriangulationPoint> points )
|
||||
{
|
||||
_points = new ArrayList<TriangulationPoint>();
|
||||
_points.addAll( points );
|
||||
}
|
||||
|
||||
public TriangulationMode getTriangulationMode()
|
||||
{
|
||||
return TriangulationMode.UNCONSTRAINED;
|
||||
}
|
||||
|
||||
public List<TriangulationPoint> getPoints()
|
||||
{
|
||||
return _points;
|
||||
}
|
||||
|
||||
public List<DelaunayTriangle> getTriangles()
|
||||
{
|
||||
return _triangles;
|
||||
}
|
||||
|
||||
public void addTriangle( DelaunayTriangle t )
|
||||
{
|
||||
_triangles.add( t );
|
||||
}
|
||||
|
||||
public void addTriangles( List<DelaunayTriangle> list )
|
||||
{
|
||||
_triangles.addAll( list );
|
||||
}
|
||||
|
||||
public void clearTriangulation()
|
||||
{
|
||||
_triangles.clear();
|
||||
}
|
||||
|
||||
public void prepareTriangulation( TriangulationContext<?> tcx )
|
||||
{
|
||||
if( _triangles == null )
|
||||
{
|
||||
_triangles = new ArrayList<DelaunayTriangle>( _points.size() );
|
||||
}
|
||||
else
|
||||
{
|
||||
_triangles.clear();
|
||||
}
|
||||
tcx.addPoints( _points );
|
||||
}
|
||||
}
|
|
@ -1,38 +0,0 @@
|
|||
package org.poly2tri.triangulation.util;
|
||||
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
import org.poly2tri.triangulation.TriangulationPoint;
|
||||
import org.poly2tri.triangulation.point.TPoint;
|
||||
|
||||
public class PointGenerator
|
||||
{
|
||||
public static List<TriangulationPoint> uniformDistribution( int n, double scale )
|
||||
{
|
||||
ArrayList<TriangulationPoint> points = new ArrayList<TriangulationPoint>();
|
||||
for( int i=0; i<n; i++ )
|
||||
{
|
||||
points.add( new TPoint( scale*(0.5 - Math.random()), scale*(0.5 - Math.random()) ) );
|
||||
}
|
||||
return points;
|
||||
}
|
||||
|
||||
public static List<TriangulationPoint> uniformGrid( int n, double scale )
|
||||
{
|
||||
double x=0;
|
||||
double size = scale/n;
|
||||
double halfScale = 0.5*scale;
|
||||
|
||||
ArrayList<TriangulationPoint> points = new ArrayList<TriangulationPoint>();
|
||||
for( int i=0; i<n+1; i++ )
|
||||
{
|
||||
x = halfScale - i*size;
|
||||
for( int j=0; j<n+1; j++ )
|
||||
{
|
||||
points.add( new TPoint( x, halfScale - j*size ) );
|
||||
}
|
||||
}
|
||||
return points;
|
||||
}
|
||||
}
|
|
@ -1,94 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.util;
|
||||
|
||||
import org.poly2tri.geometry.polygon.Polygon;
|
||||
import org.poly2tri.geometry.polygon.PolygonPoint;
|
||||
|
||||
public class PolygonGenerator
|
||||
{
|
||||
private static final double PI_2 = 2.0*Math.PI;
|
||||
|
||||
public static Polygon RandomCircleSweep( double scale, int vertexCount )
|
||||
{
|
||||
PolygonPoint point;
|
||||
PolygonPoint[] points;
|
||||
double radius = scale/4;
|
||||
|
||||
points = new PolygonPoint[vertexCount];
|
||||
for(int i=0; i<vertexCount; i++)
|
||||
{
|
||||
do
|
||||
{
|
||||
if( i%250 == 0 )
|
||||
{
|
||||
radius += scale/2*(0.5 - Math.random());
|
||||
}
|
||||
else if( i%50 == 0 )
|
||||
{
|
||||
radius += scale/5*(0.5 - Math.random());
|
||||
}
|
||||
else
|
||||
{
|
||||
radius += 25*scale/vertexCount*(0.5 - Math.random());
|
||||
}
|
||||
radius = radius > scale/2 ? scale/2 : radius;
|
||||
radius = radius < scale/10 ? scale/10 : radius;
|
||||
} while( radius < scale/10 || radius > scale/2 );
|
||||
point = new PolygonPoint( radius*Math.cos( (PI_2*i)/vertexCount ),
|
||||
radius*Math.sin( (PI_2*i)/vertexCount ) );
|
||||
points[i] = point;
|
||||
}
|
||||
return new Polygon( points );
|
||||
}
|
||||
|
||||
public static Polygon RandomCircleSweep2( double scale, int vertexCount )
|
||||
{
|
||||
PolygonPoint point;
|
||||
PolygonPoint[] points;
|
||||
double radius = scale/4;
|
||||
|
||||
points = new PolygonPoint[vertexCount];
|
||||
for(int i=0; i<vertexCount; i++)
|
||||
{
|
||||
do
|
||||
{
|
||||
radius += scale/5*(0.5 - Math.random());
|
||||
radius = radius > scale/2 ? scale/2 : radius;
|
||||
radius = radius < scale/10 ? scale/10 : radius;
|
||||
} while( radius < scale/10 || radius > scale/2 );
|
||||
point = new PolygonPoint( radius*Math.cos( (PI_2*i)/vertexCount ),
|
||||
radius*Math.sin( (PI_2*i)/vertexCount ) );
|
||||
points[i] = point;
|
||||
}
|
||||
return new Polygon( points );
|
||||
}
|
||||
}
|
|
@ -1,17 +0,0 @@
|
|||
package org.poly2tri.triangulation.util;
|
||||
|
||||
import org.poly2tri.geometry.polygon.Polygon;
|
||||
|
||||
/**
|
||||
* Use a QuadTree traversal to add steiner points
|
||||
* inside the polygon that needs refinement
|
||||
*
|
||||
* @author thahlen@gmail.com
|
||||
*/
|
||||
public class QuadTreeRefinement
|
||||
{
|
||||
public static final void refine( Polygon p, int depth )
|
||||
{
|
||||
|
||||
}
|
||||
}
|
|
@ -1,43 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.util;
|
||||
|
||||
public class Tuple2<A,B>
|
||||
{
|
||||
public A a;
|
||||
public B b;
|
||||
|
||||
public Tuple2(A a,B b)
|
||||
{
|
||||
this.a = a;
|
||||
this.b = b;
|
||||
}
|
||||
}
|
|
@ -1,45 +0,0 @@
|
|||
/* Poly2Tri
|
||||
* Copyright (c) 2009-2010, Poly2Tri Contributors
|
||||
* http://code.google.com/p/poly2tri/
|
||||
*
|
||||
* All rights reserved.
|
||||
*
|
||||
* Redistribution and use in source and binary forms, with or without modification,
|
||||
* are permitted provided that the following conditions are met:
|
||||
*
|
||||
* * Redistributions of source code must retain the above copyright notice,
|
||||
* this list of conditions and the following disclaimer.
|
||||
* * Redistributions in binary form must reproduce the above copyright notice,
|
||||
* this list of conditions and the following disclaimer in the documentation
|
||||
* and/or other materials provided with the distribution.
|
||||
* * Neither the name of Poly2Tri nor the names of its contributors may be
|
||||
* used to endorse or promote products derived from this software without specific
|
||||
* prior written permission.
|
||||
*
|
||||
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
|
||||
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
||||
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
||||
* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
||||
* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
*/
|
||||
package org.poly2tri.triangulation.util;
|
||||
|
||||
public class Tuple3<A,B,C>
|
||||
{
|
||||
public A a;
|
||||
public B b;
|
||||
public C c;
|
||||
|
||||
public Tuple3(A a,B b,C c)
|
||||
{
|
||||
this.a = a;
|
||||
this.b = b;
|
||||
this.c = c;
|
||||
}
|
||||
}
|
Loading…
Add table
Reference in a new issue