- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于狄洛尼三角网生成算法的源代码
import java.util.*;
import java.awt.*;
public class MyEdge {
public static int count=0;
public int id;
private int begin;
private int end;
private int useCount;
public MyEdge(int begin,int end)
{
this.id=++count;
this.begin=begin;
this.end=end;
this.useCount=0;
}
public MyEdge(MyPoint begin,MyPoint end)
{
this.id=++count;
this.begin=begin.id;
this.end=end.id;
this.useCount=0;
}
public int getUseCount()
{
return this.useCount;
}
public void addUseCount()
{
this.useCount++;
}
/*
* 下面这两个方法是得到边的来个顶点
* 若集合中没有指定的对象则返回空值
*/
public MyPoint getBeginPoint(MapInteger,MyPoint pointSet)
{
MyPoint temp=pointSet.get(this.begin);
return temp;
}
public MyPoint getEndPoint(MapInteger,MyPoint pointSet)
{
MyPoint temp=pointSet.get(this.end);
return temp;
}
/*
* 下面是根据两个点的ID,在边集中找寻两点组成的边
* 返回的是边对象
* 若没找到,则返回空
*/
public static MyEdge getEdge(int begin,int end,MapInteger,MyEdge edgeSet)
{
MyEdge temp=null;
for(int i=1;i=edgeSet.size();i++)
{
temp=edgeSet.get(i);
if(temp.begin==begintemp.end==end)
break;
}
return temp;
}
/*
* 下面是根据两个点对象,在边集中找寻两点组成的边
* 返回的是边对象
* 若没找到,则返回空
*/
public static MyEdge getEdge(MyPoint begin,MyPoint end,MapInteger,MyEdge edgeSet)
{
MyEdge temp=null;
for(int i=1;i=edgeSet.size();i++)
{
temp=edgeSet.get(i);
if(temp.begin==begin.idtemp.end==end.id)
break;
}
return temp;
}
public void draw(Graphics g,MapInteger,MyPoint pointSet)
{
MyPoint begin=pointSet.get(this.begin);
MyPoint end=pointSet.get(this.end);
Color c=g.getColor();
g.setColor(Color.blue);
g.drawLine(begin.x, begin.y, end.x,end.y );
g.setColor(c);
}
/*
* 下面这个方法是用来判断点在当前直线的左边还是右边
* 当然当前直线是有方向的
* 若点在直线的右边,则返回false
* 否则返回true
*/
public boolean isOnLeft(MyPoint p,MapInteger,MyPoint pointSet)
{
boolean flag=false;
MyPoint begin=pointSet.get(this.begin);
MyPoint end=pointSet.get(this.end);
int Line=(begin.y-end.y)*p.x+(end.x-begin.x
您可能关注的文档
最近下载
- 创业管理(第5版)张玉利_课后习题答案.pdf
- 平面国----优质课件可编辑.pptx VIP
- IPC9151C2010印制板工艺产量质量和相关可靠性PCQR2基准测试标准和数据库.docx VIP
- 大学生城市轨道交通机电职业规划.pptx VIP
- 第三代核电技术AP1000 - 孙汉虹.pdf
- 福建省福州市乌山小学五年级上册语文阅读训练及答案版.pdf VIP
- 广西壮族自治区贵港市覃塘区2023-2024学年九年级上学期期中考试英语试题(含听力).docx VIP
- AP1000失去主给水事故模拟.docx
- 轨道交通供电系统安装监理组织方案.docx VIP
- GB 4706.1标准解读_从模块上分析标准结构 - 爬电距离和电气间隙系统.xlsx
原创力文档


文档评论(0)