游戏中寻找学习java的乐趣之坦克大战系列10-高效雷达(下)
前言
本篇将给大家准备一个非常高效的雷达扫描坦克,可以有效的锁定敌人。
高效雷达坦克示例
废话就不多说了,直接上代码吧。
1.importjava.awt.color;
2.
3.importrobocode.advancedrobot;
4.importrobocode.robotdeathevent;
5.importrobocode.scannedrobotevent;
6.
7.publicclassqfradarrobotextendsadvancedrobot{
8.enemytarget;//定义敌人
9.finaldoublepi=math.pi;//创建常量pi
10.intdirection=1;//向前方向值为1,向后为-1;
11.publicvoidrun(){
12.target=newenemy();
13.target.distance=10000;//初始化敌人距离
14.
15.this.setadjustgunforrobotturn(true);//使枪和坦克独立
16.this.setadjustradarforgunturn(true);//时枪和雷达独立
17.
18.this.turnradarrightradians(2*pi);//雷达扫描一周(弧度)
19.
20.while(true){
21.doscanner();//扫描别的坦克
22.out.println(target.distance);
23.execute();//执行以上所有命令
24.}
25.}
26.
27.
28.//移动坦克
29.privatevoiddomovement(){
30.
31.if(gettime()%20==0){
32.//每20个时间间隔执行一次
33.direction*=-1;//反向运动
34.setahead(direction*300);//前后运动
35.}
36.//依据弧度转向
37.this.setturnrightradians(target.bearing+(pi/2));
38.
39.}
40.
41.
42.
43.
44.//雷达扫描
45.privatevoiddoscanner(){
46.doubleradaroffset;//雷达扫描区域
47.if(gettime()-target.ctime>4){
48.//如果4秒内在小区域中没有发现目标
49.radaroffset=360;//雷达转一圈
50.}else{
51.//找到目标后使搜索范围扩大以至于不丢失目标
52.radaroffset=this.getradarheadingradians()-absbearing(getx(),gety(),target.x,target.y);
53.if(radaroffset<0){
54.radaroffset-=pi/8;//稍稍增大扫描区域
55.}else{
56.radaroffset+=pi/8;//稍稍增大扫描区域
57.}
58.}
59.this.setturnradarleftradians(normalisebearing(radaroffset));//旋转雷达
60.
61.}
62.
63.
64.
65.//转向弧度差
66.publicdoublenormalisebearing(doubleang){
67.if(ang>pi)
68.ang-=2*pi;
69.if(ang<-pi)
70.ang+=2*pi;
71.returnang;
72.}
73.
74.
75.//如果角度大于360度,则得到标准化角度
76.publicdoublenormaliseheading(doubleang){
77.if(ang>2*pi){
78.ang-=2*pi;
79.}
80.if(ang<0){
81.ang+=2*pi;
82.}
83.returnang;
84.}
85.//确定目标的移动直线距离
86.publicdoublegetrange(doublex1,doubley1,doublex2,doubley2){
87.doublexo=x2-x1;
88.doubleyo=y2-y1;
89.doubleh=math.sqrt(xo*xo+yo*yo);
90.returnh;
91.}
92.
93.
94.
95.
96.
97.//确定绝对位置的方法
98.publicdoubleabsbearing(doublex1,doubley1,doublex2,doubley2){
99.doublexo=x2-x1;//水平位移
100.doubleyo=y2-y1;//垂直位移
101.doubleh=getrange(x1,y1,x2,y2);
102.if(xo>0&&yo>0){
103.returnmath.asin(xo/h);//正弦弧度
104.}
105.if(xo>0&&yo<0){
106.returnmath.pi-math.asin(xo/h);
107.}
108.if(xo<0&&yo<0){
109.returnmath.pi+math.asin(-xo/h);
110.}
111.if(xo0){
112.return2.0*math.pi-math.asin(-xo/h);
113.}
114.return0;
115.}
116.
117.//扫描到敌方坦克
118.publicvoidonscannedrobot(scannedrobotevente){
119.if((e.getdistance()
121.doubleabsbearing_rad=(this.getheadingradians()+e.getbearingradians())%(2*pi);
122.//定义坦克的相关信息
123.target.name=e.getname();
124.target.x=getx()+math.sin(absbearing_rad)*e.getdistance();//计算目标的x坐标
125.target.y=gety()+math.cos(absbearing_rad)*e.getdistance();//计算目标的y坐标
126.target.bearing=e.getbearingradians();//
127.target.head=e.getheadingradians();//获得坦克头的方向
128.target.ctime=gettime();//记录扫描到坦克的时间
129.target.speed=e.getvelocity();//记录目标的速度
130.target.distance=e.getdistance();//记录目标离自己的距离
131.
132.}
133.
134.}
135.
136.
137.
138.
139.//内部类,用来保存对手的相关信息
140.classenemy{
141.stringname;//定义坦克的名字
142.
143.publicdoublebearing;
144.publicdoublehead;
145.publiclongctime;//记录扫描到该坦克的时间
146.publicdoublespeed;
147.publicdoublex,y;//坐标
148.publicdoubledistance;//距离
149.//预计坦克x坐标
150.publicdoubleguessx(longwhen){
151.longdiff=when-ctime;
152.returnx+math.sin(head)*speed*diff;
153.}
154.//预计坦克y坐标
155.publicdoubleguessy(longwhen){
156.longdiff=when-ctime;
157.returny+math.cos(head)*speed*diff;
158.}
159.}
160.}
通过示例代码中的注释大家能够发现,本坦克的雷达扫描就是基于敌人的移动方式提前预判敌人可能会出现的目标位置,如果敌人不再预测的目标位置,便会快速旋转雷达一周以便于更方便的锁定敌人。
好啦,本期内容就到这里喽,我是不会玩游戏却非得写游戏的陈老师,一起来学习java吧!