HTML5坦克大战1
在JavaScript中,不要在变量为定义之前去使用,这样很难察觉并且无法运行。
颜色不对。
当我的坦克移动时,敌人坦克消失。
tankGame3.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
</head>
<body onkeydown="getCommand()">
<h6>HTML5坦克大战</h6>
<!--这是坦克大战的战场 -->
<canvas id="tankMap" width="400px" height="300px" style="background-color:black"></canvas>
<script type="text/javascript" src="tankGame3.js"></script>
<script type="text/javascript">
//定义一个Hero类
//把绘制坦克封装成一个函数,将来可以作为成员函数
//x表示坦克的横坐标,y表示纵坐标,direct方法
//
//得到画布
var canvas1=document.getElementById("tankMap");
//得到绘图上下文(你可以理解是画笔)
var cxt=canvas1.getContext("2d");
var hero=new Hero(140,140,0,heroColor);
//定义敌人的坦克(敌人的坦克有多少?单个定义还是放在数组中。
var enemyTanks=new Array();
//先死后活,定3个,后面我们把敌人坦克的数量做成变量
for(var i=0;i<6;i++){
//创建一个坦克
var enemyTank=new EnemyTank((i+1)*50,0,2,enemyColor);
//把这个坦克放入数组
enemyTanks[i]=enemyTank;
//画出这个坦克
//drawTank(enemyTank);
}
flashTankMap();
//专门写一个函数,用于定时刷新我们的作战区,把要在作战区出现的元素
//(自己坦克,敌人坦克,子弹,草坪,障碍物)
function flashTankMap(){
cxt.clearRect(0,0,400,300);
//我的坦克
drawTank(hero);
//敌人的坦克
for(var i=0;i<3;i++){
drawTank(enemyTanks[i]);
}
}
//这是一个接收用户按键函数
function getCommand(){
var code=event.keyCode;
switch(code){
case 87:
hero.moveUp();
break;
case 68:
hero.moveRight();
break;
case 83:
hero.moveDown();
break;
case 65:
hero.moveLeft();
break;
}
//drawTank(hero);
//要触发这个函数flashTankMap
flashTankMap();
//重新绘制所有的敌人坦克,你可以在这里写代码(思想:每隔一段时间来刷新画布。。
//用一个函数,专门用于定时刷新屏幕。
}
</script>
tankGame.js
//为了编程方便,我们定义两个颜色数组
var heroColor=new Array("#BA9658","#FEF26E");
var enemyColor=new Array("#00A2B5","#00FEFE");
//这是一个坦克类
function Tank(x, y, direct,color){
this.x=x;
this.y=y;
this.speed=1;
this.direct=direct;
this.color=color;
//上移
this.moveUp=function(){
this.y-=this.speed;
this.direct=0;
}
//右移
this.moveRight=function(){
this.x+=this.speed;
this.direct=1;
}
//下移
this.moveDown=function(){
this.y+=this.speed;
this.direct=2;
}
//左移
this.moveLeft=function(){
this.x-=this.speed;
this.direct=3;
}
}
function Hero(x,y,direct,color){
//下面两句话的作用是通过对象冒充,达到继承的效果
this.tank=Tank;
this.tank(x,y,direct,color);
}
//定义一个EnemyTank类
function EnemyTank(x, y, direct,color){
//也通过对象冒充,来继承Tank
this.tank=Tank;
this.tank(x,y,direct,color);
}
//将来这个函数可以画坦克
//绘制坦克
function drawTank(tank){
//考虑方向
switch(tank.direct){
case 0:
case 2:
cxt.fillStyle=tank.color[0];
//韩老师使用先死-->后活
cxt.fillRect(tank.x, tank.y, 5, 30);
//画出右边的矩形
cxt.fillRect(tank.x+15, tank.y,5,30);
cxt.fillRect(tank.x+6, tank.y+5,8,20);
//画出圆形坦克
cxt.fillStyle=tank.color[1];
cxt.arc(tank.x+10, tank.y+15,4,0,Math.PI*2,true);
cxt.fill();
//画出炮筒
cxt.strokeStyle=tank.color[1];
cxt.lineWidth=2;
cxt.beginPath();
cxt.moveTo(tank.x+10, tank.y+15);
if(tank.direct==0){
cxt.lineTo(tank.x+10, tank.y);
}else if(tank.direct==2){
cxt.lineTo(tank.x+10, tank.y+30);
}
cxt.closePath();
cxt.stroke();
break;
case 1:
case 3:
cxt.fillStyle=tank.color[0];
//韩老师使用先死-->后活
cxt.fillRect(tank.x, tank.y, 30, 5);
//画出右边的矩形
cxt.fillRect(tank.x, tank.y+15,30,5);
//画出中间矩形
cxt.fillRect(tank.x+5, tank.y+6,20,8);
//画出圆形坦克
cxt.fillStyle=tank.color[1];
cxt.arc(tank.x+15, tank.y+10,4,0,Math.PI*2,true);
cxt.fill();
//画出炮筒
cxt.strokeStyle=tank.color[1];
cxt.lineWidth=2;
cxt.beginPath();
cxt.moveTo(tank.x+15, tank.y+10);
if(tank.direct==1){
cxt.lineTo(tank.x+30, tank.y+10);
}else if(tank.direct==3){
cxt.lineTo(tank.x, tank.y+10);
}
cxt.closePath();
cxt.stroke();
break;
}
}
(3)自己的坦克可以发送子弹,只能发送一颗。
1.子弹,不管是敌人的还是我的,都是作战区的一个元素。因此我们可以定义为全局变量。
OOP,所以子弹也是一个对象。
2 去处理用户按下j键时的反应
3.画出自己的子弹->写了一个函数(思想)[自己回去把坦克大战写个n遍]。
4.在哪里调用。刷新作战区的函数调用。
5.考虑子弹位置的编写。
6.子弹是不动的,《让子弹飞一会儿》。
7.子弹坐标怎样自动地变换,思想是我们可以定时去修改子弹的目标。
8.在什么地方去调用这个bullet。
HTML5坦克大战1的更多相关文章
- 基于HTML5坦克大战游戏简化版
之前我们有分享过不少经典的HTML5游戏,有些还是很有意思的,比如HTML5版切水果游戏和HTML5中国象棋游戏.今天要分享的是一款简化版的HTML5坦克大战游戏,方向键控制坦克的行进方向,空格键发射 ...
- HTML5坦克大战(韩顺平版本)
HTML5坦克大战(韩顺平版本) 2017-3-22 22:46:22 by SemiconductorKING 去年暑假学习了一下HTML5实现简单的坦克大战,觉得对JavaScript初学者来说, ...
- HTML5坦克大战
在JavaScript中,不要在变量为定义之前去使用,这样很难察觉并且无法运行. 颜色不对. 当我的坦克移动时,敌人坦克消失. tankGame3.html <!DOCTYPE html> ...
- HTML5坦克大战(1)绘制坦克
坦克尺寸如下: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head&g ...
- HTML5坦克大战(2)绘制坦克复习
html代码: <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head&g ...
- HTML5 坦克大战
代码 点击打开链接
- html5制作坦克大战
全部html5都采用绘图技术完成.坦克是画出来的.(坦克,子弹,墙,水,草坪) 首先我们画出坦克. 坦克是两边两个矩形,中间一个大矩形,矩形了有一个圆,还有一根线. 画出坦克的思路是以坦克的左上角为参 ...
- 《HTML5经典坦克大战》游戏(代码)
前几天粗略地学了HTML5,然后就用它写了一个<经典坦克大战>游戏. 现在想分享一下我写的代码,写得不好请大家多多指教. 给大家推荐一个网站,这个网站是为大学生而做,为方便学习编程的同学而 ...
- 小强的HTML5移动开发之路(7)——坦克大战游戏1
来自:http://blog.csdn.net/dawanganban/article/details/17693145 上一篇中我们介绍了关于Canvas的基础知识,用Canvas绘制各种图形和图片 ...
随机推荐
- webview长按保存图片
private String imgurl = ""; /*** * 功能:长按图片保存到手机 */ @Override public void onC ...
- 域名解析-CNAME
不要把域名解析简单看成把一个域名指向一个IP那么简单的事. 事实上域名解析能做的事非常多. 简单样例,假如你买了一台server仅仅有一个IP,你想弄两站点,而且仅仅想直接通过IP就能訪问,就是不加什 ...
- 【JMeter4.0学习(十一)】之JMeter对(Mysql、Oracle)数据库性能测试脚本开发
一.MySQL数据库链接: 注:下面所产生的问题一律参考详见:<[JMeter4.0]之遇到的问题总结(持续更新)>(包括Mysql.Orcale) 准备:引包,包路径一定要放对位置,参考 ...
- 从sql走向linq的我撞死在起点上
[本文纯个人理解,错误轻喷,非常希望能有大神指点] A left (outer) join B on A.bid=B.id 上面这句话叫做左连接,原因是left(左)join(加入,连入)被译为左连接 ...
- shiro 实现自己定义权限规则校验
<span style="font-family: Arial, Helvetica, sans-serif;">在系统中使用shiro进行权限管理,当用户訪问没有权限 ...
- easyui首页模板
Easyui首页html代码 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "htt ...
- 安装PyTorch 0.4.0
https://blog.csdn.net/sunqiande88/article/details/80085569 https://blog.csdn.net/xiangxianghehe/arti ...
- EasyNVR无插件摄像机直播之:摄像机网页低延时无插件直播实现
背景需求 对于摄像机直播,客户反馈的最多就是实现web直播.摆脱插件,可以自定义集成等问题, 对于熟悉EasyNVR已经完美的解决了这些问题.然而对于web播放也存在一些问题,通常我们web播放RTM ...
- WebApi 中使用 Session
1. 在 Global.asax.cs 文件中加入session支持 protected void Application_Start() { AreaRegistration.RegisterAll ...
- Python高级入门01-property
JAVA中存在对变量 私有化,公开,保护... 私有化时候,需要提供一个公开的get 和 set方法对外公开,让别人进行调用 python中同样存在 私有化变量定义是__是这个双下划线,eg:_ ...