本文整理汇总了Java中com.vividsolutions.jts.triangulate.quadedge.QuadEdge类的典型用法代码示例。如果您正苦于以下问题:Java QuadEdge类的具体用法?Java QuadEdge怎么用?Java QuadEdge使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
QuadEdge类属于com.vividsolutions.jts.triangulate.quadedge包,在下文中一共展示了QuadEdge类的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Java代码示例。
示例1: insertSite
import com.vividsolutions.jts.triangulate.quadedge.QuadEdge; //导入依赖的package包/类
/**
* Inserts a new point into a subdivision representing a Delaunay
* triangulation, and fixes the affected edges so that the result is still a
* Delaunay triangulation.
* <p>
*
* @return a quadedge containing the inserted vertex
*/
public QuadEdge insertSite(Vertex v) {
/**
* This code is based on Guibas and Stolfi (1985), with minor modifications
* and a bug fix from Dani Lischinski (Graphic Gems 1993). (The modification
* I believe is the test for the inserted site falling exactly on an
* existing edge. Without this test zero-width triangles have been observed
* to be created)
*/
QuadEdge e = this.subdiv.locate(v);
if (this.subdiv.isVertexOfEdge(e, v)) {
// point is already in subdivision.
return e;
} else if (this.subdiv.isOnEdge(e, v.getCoordinate())) {
// the point lies exactly on an edge, so delete the edge
// (it will be replaced by a pair of edges which have the point as a vertex)
e = e.oPrev();
this.subdiv.delete(e.oNext());
}
/**
* Connect the new point to the vertices of the containing triangle
* (or quadrilateral, if the new point fell on an existing edge.)
*/
QuadEdge base = this.subdiv.makeEdge(e.orig(), v);
QuadEdge.splice(base, e);
QuadEdge startEdge = base;
do {
base = this.subdiv.connect(e, base.sym());
e = base.oPrev();
} while (e.lNext() != startEdge);
// Examine suspect edges to ensure that the Delaunay condition
// is satisfied.
do {
QuadEdge t = e.oPrev();
if (t.dest().rightOf(e) && v.isInCircle(e.orig(), t.dest(), e.dest())) {
QuadEdge.swap(e);
e = e.oPrev();
} else if (e.oNext() == startEdge) {
return base; // no more suspect edges.
} else {
e = e.oNext().lPrev();
}
} while (true);
}
开发者ID:gegy1000,项目名称:Earth,代码行数:56,代码来源:IncrementalDelaunayTriangulator.java
示例2: insertSite
import com.vividsolutions.jts.triangulate.quadedge.QuadEdge; //导入依赖的package包/类
/**
* Inserts a new point into a subdivision representing a Delaunay
* triangulation, and fixes the affected edges so that the result is still a
* Delaunay triangulation.
* <p/>
*
* @return a quadedge containing the inserted vertex
*/
public QuadEdge insertSite(Vertex v) {
/**
* This code is based on Guibas and Stolfi (1985), with minor modifications
* and a bug fix from Dani Lischinski (Graphic Gems 1993). (The modification
* I believe is the test for the inserted site falling exactly on an
* existing edge. Without this test zero-width triangles have been observed
* to be created)
*/
QuadEdge e = subdiv.locate(v);
if (subdiv.isVertexOfEdge(e, v)) {
// point is already in subdivision.
return e;
} else if (subdiv.isOnEdge(e, v.getCoordinate())) {
// the point lies exactly on an edge, so delete the edge
// (it will be replaced by a pair of edges which have the point as a vertex)
e = e.oPrev();
subdiv.delete(e.oNext());
}
/**
* Connect the new point to the vertices of the containing triangle
* (or quadrilateral, if the new point fell on an existing edge.)
*/
QuadEdge base = subdiv.makeEdge(e.orig(), v);
QuadEdge.splice(base, e);
QuadEdge startEdge = base;
do {
base = subdiv.connect(e, base.sym());
e = base.oPrev();
} while (e.lNext() != startEdge);
// Examine suspect edges to ensure that the Delaunay condition
// is satisfied.
do {
QuadEdge t = e.oPrev();
if (t.dest().rightOf(e) && v.isInCircle(e.orig(), t.dest(), e.dest())) {
QuadEdge.swap(e);
e = e.oPrev();
} else if (e.oNext() == startEdge) {
return base; // no more suspect edges.
} else {
e = e.oNext().lPrev();
}
} while (true);
}
开发者ID:Semantive,项目名称:jts,代码行数:56,代码来源:IncrementalDelaunayTriangulator.java
示例3: insertSite
import com.vividsolutions.jts.triangulate.quadedge.QuadEdge; //导入依赖的package包/类
/**
* Inserts a new point into a subdivision representing a Delaunay
* triangulation, and fixes the affected edges so that the result is still a
* Delaunay triangulation.
* <p>
*
* @return a quadedge containing the inserted vertex
*/
public QuadEdge insertSite(Vertex v) {
/**
* This code is based on Guibas and Stolfi (1985), with minor modifications
* and a bug fix from Dani Lischinski (Graphic Gems 1993). (The modification
* I believe is the test for the inserted site falling exactly on an
* existing edge. Without this test zero-width triangles have been observed
* to be created)
*/
QuadEdge e = subdiv.locate(v);
if (subdiv.isVertexOfEdge(e, v)) {
// point is already in subdivision.
return e;
}
else if (subdiv.isOnEdge(e, v.getCoordinate())) {
// the point lies exactly on an edge, so delete the edge
// (it will be replaced by a pair of edges which have the point as a vertex)
e = e.oPrev();
subdiv.delete(e.oNext());
}
/**
* Connect the new point to the vertices of the containing triangle
* (or quadrilateral, if the new point fell on an existing edge.)
*/
QuadEdge base = subdiv.makeEdge(e.orig(), v);
QuadEdge.splice(base, e);
QuadEdge startEdge = base;
do {
base = subdiv.connect(e, base.sym());
e = base.oPrev();
} while (e.lNext() != startEdge);
// Examine suspect edges to ensure that the Delaunay condition
// is satisfied.
do {
QuadEdge t = e.oPrev();
if (t.dest().rightOf(e) && v.isInCircle(e.orig(), t.dest(), e.dest())) {
QuadEdge.swap(e);
e = e.oPrev();
} else if (e.oNext() == startEdge) {
return base; // no more suspect edges.
} else {
e = e.oNext().lPrev();
}
} while (true);
}
开发者ID:GitHubDroid,项目名称:geodroid_master_update,代码行数:57,代码来源:IncrementalDelaunayTriangulator.java
示例4: compare
import com.vividsolutions.jts.triangulate.quadedge.QuadEdge; //导入依赖的package包/类
/**
* Method of comparison.
*
* @param qeA
* quad edge to compare
* @param qeB
* quad edge to compare
* @return
* 1 if double value associated to qeA < double
* value associated to qeB,
* 0 if values are equals,
* -1 otherwise
*/
@Override
public int compare(QuadEdge qeA, QuadEdge qeB) {
if (this.map.get(qeA) < this.map.get(qeB)) {
return 1;
} else if (this.map.get(qeA) == this.map.get(qeB)) {
return 0;
} else {
return -1;
}
}
开发者ID:GIScience,项目名称:openrouteservice,代码行数:24,代码来源:DoubleComparator.java
示例5: compare
import com.vividsolutions.jts.triangulate.quadedge.QuadEdge; //导入依赖的package包/类
/**
* Method of comparison.
*
* @param qeA
* quad edge to compare
* @param qeB
* quad edge to compare
* @return
* 1 if double value associated to qeA < double
* value associated to qeB,
* 0 if values are equals,
* -1 otherwise
*/
@Override
public int compare(QuadEdge qeA, QuadEdge qeB) {
if (this.map.get(qeA) < this.map.get(qeB)) {
return 1;
} else if (this.map.get(qeA) == this.map.get(qeB)) {
return 0;
} else {
return -1;
}
}
开发者ID:fiskurgit,项目名称:KortidTol,代码行数:24,代码来源:DoubleComparator.java
示例6: DoubleComparator
import com.vividsolutions.jts.triangulate.quadedge.QuadEdge; //导入依赖的package包/类
/**
* Constructor.
*
* @param map
* map containing QuadEdge and Double
*/
public DoubleComparator(Map<QuadEdge,Double> map) {
this.map = map;
}
开发者ID:GIScience,项目名称:openrouteservice,代码行数:10,代码来源:DoubleComparator.java
示例7: DoubleComparator
import com.vividsolutions.jts.triangulate.quadedge.QuadEdge; //导入依赖的package包/类
/**
* Constructor.
*
* @param map
* map containing QuadEdge and Double
*/
public DoubleComparator(Map<QuadEdge,Double> map) {
this.map = map;
}
开发者ID:fiskurgit,项目名称:KortidTol,代码行数:10,代码来源:DoubleComparator.java
注:本文中的com.vividsolutions.jts.triangulate.quadedge.QuadEdge类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论