• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Java QuadEdge类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了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;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Java OrcOutputFormat类代码示例发布时间:2022-05-23
下一篇:
Java ConsumeOrderlyContext类代码示例发布时间:2022-05-23
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap