亚洲免费不卡_在线视频精品_国产尤物精品_久久久久网址_久久精品91_欧美va天堂在线_狠狠入ady亚洲精品_亚洲午夜精品福利_国产精品草草_午夜精品久久99蜜桃的功能介绍

HTML5實現經典坦克大戰坦克亂走還能發出一個子彈
來源:易賢網 閱讀:1739 次 日期:2014-07-23 11:52:21
溫馨提示:易賢網小編為您整理了“HTML5實現經典坦克大戰坦克亂走還能發出一個子彈”,方便廣大網友查閱!

代碼如下:

<pre name="code" class="html">tank.html</pre><pre name="code" class="html"><!DOCTYPE html>

<html>

<head>

<meta charset="utf-8"/>

</head>

<body onkeydown="getCommand();">

<h1>hmtl5-經典的坦克大戰</h1>

<!--坦克大戰的戰場-->

<canvas id="tankMap" width="400px" height="300px" style="background-color:black"></canvas>

<span id="aa">數據</span>

<!--把tankGames.js引入到本頁面-->

<script type="text/javascript" src="tank.js"></script>

<script type="text/javascript">

//得到畫布

var canvas1=document.getElementById("tankMap");

//得到繪圖上下文(你可以理解是畫筆)

var cxt=canvas1.getContext("2d");

//我的坦克 hero

//方向

var hero=new Hero(140,140,0,heroColor);

//定義一顆空子彈

var heroBullet=null;

//定義敵人的坦克(敵人的坦克有多少? 思路 : 是單個單個的定義,還是放在數組中?)

var enemyTanks=new Array();

//先死后活 ,定3個,后面我們把敵人坦克的數量,作出變量

//0->上, 1->右, 2->下 3->左

for(var i=0;i<3;i++){

//創建一個坦克

var enemyTank=new EnemyTank((i+1)*50,0,2,enmeyColor);

//把這個坦克放入數組

enemyTanks[i]=enemyTank;

}

//先調用一次

flashTankMap();

//專門寫一個函數,用于定時刷新我們的作戰區,把要在作戰區出現的元素(自己坦克,敵人坦克,子彈,炸彈,

//障礙物...)->游戲思想

function flashTankMap(){

//把畫布清理

cxt.clearRect(0,0,400,300);

//我的坦克

drawTank(hero);

//畫出自己的子彈

//子彈飛效果是怎么出現的?[答 : 首先我們應該每隔一定時間(setInterval)就去刷新作戰區,如果在刷新的時候,子彈坐標變換了,給人的感覺就是子彈在飛!]

drawHeroBullet();

//敵人的坦克

//畫出所有敵人坦克

for(var i=0;i<3;i++){

drawTank(enemyTanks[i]);

}

}

//這是一個接受用戶按鍵函數

function getCommand(){

//我怎么知道,玩家按下的是什么鍵

//說明當按下鍵后 事件--->event對象----->事件處理函數()

var code=event.keyCode;//對應字母的ascii碼->我們看碼表

switch(code){

case 87://上

hero.moveUp();

break;

case 68:

hero.moveRight();

break;

case 83:

hero.moveDown();

break;

case 65:

hero.moveLeft();

break;

case 74:

hero.shotEnemy();

break;

}

//觸發這個函數 flashTankMap();

flashTankMap();

//重新繪制所有的敵人的坦克.你可以在這里寫代碼(思想,我們干脆些一個函數,專門用于定時刷新我們的畫布[作戰區])

}

//每隔100毫秒去刷新一次作戰區

window.setInterval("flashTankMap()",100);

</script>

</body>

</html></pre>

tank.js

代碼如下:

<pre></pre>

<pre name="code" class="html"><pre name="code" class="javascript">//為了編程方便,我們定義兩個顏色數組

var heroColor=new Array("#BA9658","#FEF26E");

var enmeyColor=new Array("#00A2B5","#00FEFE");

//其它的敵人坦克,這里的擴展性,還是不錯的.

//子彈類

function Bullet(x,y,direct,speed){

this.x=x;

this.y=y;

this.direct=direct;

this.speed=speed;

this.timer=null;

this.isLive=true;

this.run=function run(){

//在該表這個子彈的坐標時,我們先判斷子彈是否已經到邊界

if(this.x<=0||this.x>=400||this.y<=0||this.y>=300){

//子彈要停止.

window.clearInterval(this.timer);

//子彈死亡

this.isLive=false;

}else{

//這個可以去修改坐標

switch(this.direct){

case 0:

this.y-=this.speed;

break;

case 1:

this.x+=this.speed;

break;

case 2:

this.y+=this.speed;

break;

case 3:

this.x-=this.speed;

break;

}

}

document.getElementById("aa").innerText="子彈x="+this.x+" 子彈y="+this.y;

}

}

//這是一個Tank類

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;

}

}

//定義一個Hero類

//x 表示坦克的 橫坐標, y 表示縱坐標, direct 方向

function Hero(x,y,direct,color){

//下面兩句話的作用是通過對象冒充,達到繼承的效果

this.tank=Tank;

this.tank(x,y,direct,color);

//增加一個函數,射擊敵人坦克.

this.shotEnemy=function(){

//創建子彈, 子彈的位置應該和hero有關系,并且和hero的方向有關.!!!

//this.x 就是當前hero的橫坐標,這里我們簡單的處理(細化)

switch(this.direct){

case 0:

heroBullet=new Bullet(this.x+9,this.y,this.direct,1);

break;

case 1:

heroBullet=new Bullet(this.x+30,this.y+9,this.direct,1);

break;

case 2:

heroBullet=new Bullet(this.x+9,this.y+30,this.direct,1);

break;

case 3: //右

heroBullet=new Bullet(this.x,this.y+9,this.direct,1);

break;

}

//調用我們的子彈run, 50 是老師多次測試得到的一個結論.

var timer=window.setInterval("heroBullet.run()",50);

//把這個timer賦給這個子彈(js對象是引用傳遞!)

heroBullet.timer=timer;

}

}

//定義一個EnemyTank類

function EnemyTank (x,y,direct,color){

//也通過對象冒充,來繼承Tank

this.tank=Tank;

this.tank(x,y,direct,color);

}

//畫出自己的子彈,多說一句,你也可以把該函數封裝到Hero類中

function drawHeroBullet(){

//這里,我們加入了一句話,但是要知道這里加,是需要對整個程序有把握

if(heroBullet!=null&&heroBullet.isLive){

cxt.fillStyle="#FEF26E";

cxt.fillRect(heroBullet.x,heroBullet.y,2,2);

}

}

//繪制坦克

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,360,true);

cxt.fill();

//畫出炮筒(直線)

cxt.strokeStyle=tank.color[1];

//設置線條的寬度

cxt.lineWidth=1.5;

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,360,true);

cxt.fill();

//畫出炮筒(直線)

cxt.strokeStyle=tank.color[1];

//設置線條的寬度

cxt.lineWidth=1.5;

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;

}

}

</pre>

<pre></pre>

</pre>

更多信息請查看IT技術專欄

更多信息請查看網頁制作
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

亚洲免费不卡_在线视频精品_国产尤物精品_久久久久网址_久久精品91_欧美va天堂在线_狠狠入ady亚洲精品_亚洲午夜精品福利_国产精品草草_午夜精品久久99蜜桃的功能介绍
亚洲大黄网站| 欧美亚洲免费在线| 亚洲欧美视频| 欧美日韩视频一区二区三区| 国产精品v欧美精品v日韩 | 久久欧美肥婆一二区| 欧美日韩精品免费看| 国产日本精品| 亚洲图色在线| 久久久久久亚洲精品杨幂换脸 | 欧美激情性爽国产精品17p| 亚洲无玛一区| 噜噜噜噜噜久久久久久91| 狠狠色噜噜狠狠色综合久| 亚洲一级在线| 亚洲精品视频一区二区三区| 久久精品电影| 国产伦精品一区二区三区| 国产一区二区三区四区老人| 国产精品久久亚洲7777| 国产综合婷婷| 欧美成熟视频| 久久伊人亚洲| 久久国产精品亚洲77777| 99精品久久| 亚洲第一伊人| 亚洲成人在线视频网站| 国产精品二区在线| 午夜精品亚洲| 牛夜精品久久久久久久99黑人| 一本一本久久| 亚洲欧洲另类| 亚洲黄色毛片| 日韩视频精品| 亚洲精品三级| 一区二区毛片| 国产日韩欧美一区在线| 一本色道久久| 国产亚洲午夜| 亚洲一区二区三区高清不卡| 国产欧美日韩一区二区三区在线 | 亚洲国产精品综合| 亚洲午夜高清视频| 亚洲天堂偷拍| 亚洲人成久久| 国产精品色网| 性色一区二区三区| 久久人人97超碰人人澡爱香蕉 | 欧美久色视频| 国产精品国产三级欧美二区| 欧美日韩一区二区三区免费| 国产精品v亚洲精品v日韩精品| 午夜精品久久久久99热蜜桃导演 | 久久国产精品一区二区三区| 美女久久网站| 欧美日韩视频在线一区二区观看视频| 欧美韩国一区| 亚洲国产精品一区制服丝袜| 亚洲精品婷婷| 国产精品久久国产愉拍 | 亚洲高清视频在线观看| 99精品国产在热久久婷婷| 一区二区三区三区在线| 麻豆精品视频| 亚洲图片在线观看| 亚洲一区二区三区色| 久久精品日产第一区二区三区| 久久久久一区二区| 亚洲二区精品| 久久www成人_看片免费不卡| 欧美精品91| 99热精品在线观看| 欧美精品一区三区在线观看| 99精品免费网| 欧美日韩精品免费看| 夜夜嗨一区二区三区| 久久日韩精品| 国产精品视频福利| 亚洲午夜精品久久久久久app| 国产精品美女| 亚洲五月婷婷| 久久久久久久高潮| 宅男噜噜噜66一区二区| 欧美视频观看一区| 久久婷婷影院| 亚洲欧美卡通另类91av| 亚洲大片av| 欧美日韩亚洲一区二区三区在线 | 午夜精品电影| 亚洲一区三区在线观看| 亚洲午夜精品久久久久久app| 午夜亚洲激情| 亚洲少妇诱惑| 99精品欧美| 激情视频一区二区| 欧美激情第六页| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲狠狠婷婷| 一区二区亚洲| 国产在线观看一区| 欧美在线网址| 久久青青草综合| 久久国产主播精品| 久久本道综合色狠狠五月| 亚洲看片免费| 亚洲欧洲另类| 亚洲精品一品区二品区三品区| 欧美日韩精品久久| 欧美日本韩国在线| 欧美午夜影院| 国模精品一区二区三区| 欧美日韩爆操| 亚洲手机视频| 亚洲精品综合| 国产亚洲成人一区| 亚洲免费网址| 久久久国产亚洲精品| 久久精品日产第一区二区| 男人的天堂亚洲| 久久久一本精品99久久精品66| 免费亚洲一区二区| 欧美激情第二页| 国一区二区在线观看| 影音先锋久久精品| 国产欧美日韩亚洲一区二区三区| 日韩一级在线| 亚洲影音先锋| 欧美99在线视频观看| 午夜精品剧场| 伊人久久综合| 香蕉亚洲视频| 国内精品久久久久久久97牛牛 | 久久精品麻豆| 黄页网站一区| 99精品国产99久久久久久福利| 日韩一区二区久久| 久久亚洲不卡| 亚洲高清成人| 久久久久国产精品午夜一区| 国产精品扒开腿做爽爽爽软件| 亚洲激情女人| 噜噜噜91成人网| 好看的亚洲午夜视频在线| 一本色道久久综合| 欧美~级网站不卡| 在线精品亚洲| 久久久777| 亚洲美女啪啪| 欧美日韩喷水| 亚洲欧美日韩精品一区二区| 国产一区二区三区无遮挡| 国产欧美日韩一区| 国模大胆一区二区三区| 国产精品美女| 亚洲三级电影在线观看| 欧美精品观看| 久久久精品动漫| 亚洲作爱视频| 亚洲网站在线| 欧美精品午夜| 另类亚洲自拍| 亚洲美女一区| 影音先锋在线一区| 欧美不卡在线| 麻豆成人av| 国产精品入口| 在线亚洲观看| 亚洲激情黄色| 在线精品一区| 好吊一区二区三区| 欧美成人69| 久久精品一本| 久久精品国产清高在天天线| 国产精品久久久久9999高清| 精品999成人| 欧美特黄一区| 欧美精品二区三区四区免费看视频| 午夜一区二区三视频在线观看| 亚洲精品美女91| 亚洲国产专区| 亚洲欧洲一区二区在线观看| 国产精品mm| 韩国在线一区| 在线日韩av| 99www免费人成精品| 伊甸园精品99久久久久久| 国产精品第十页| 国产一区二区中文字幕免费看| 老司机久久99久久精品播放免费| 美女尤物久久精品| 欧美阿v一级看视频| 欧美精品日本| 永久久久久久| 一区二区福利| 久久国产精品一区二区三区| 麻豆久久婷婷| 欧美 日韩 国产在线| 欧美另类视频在线| 在线观看成人av电影| 日韩视频二区| 久久国产精品高清| 欧美日韩蜜桃| 国产欧美另类| 欧美+日本+国产+在线a∨观看| 欧美黄色精品| 亚洲精品123区| 亚洲一区二区精品在线观看| 久久精品日韩| 亚洲高清免费| 久久精品综合| 亚洲国产精品一区| 午夜一级在线看亚洲| 欧美激情偷拍| 日韩一级网站| 午夜久久tv| 一本色道久久综合| 欧美一区网站| 99精品国产一区二区青青牛奶| 亚洲一区二区毛片| 国内精品久久久久久久影视麻豆| 在线亚洲成人| 欧美网站在线| 免费久久99精品国产自在现线| 欧美日韩免费观看一区=区三区| 亚洲国内欧美| 欧美激情成人在线| 国产精品日韩欧美一区| 国产精品二区三区四区| 亚洲在线日韩| 亚洲激情成人| 欧美日韩精品免费看| 国产一区二区高清不卡| 精品91在线| 午夜视频久久久| 国产精品一区二区三区免费观看 | 看欧美日韩国产| 亚洲国产一区二区三区高清| 美女亚洲精品| 99伊人成综合| 国产精品高清一区二区三区| 久久成人一区| 国产精品乱码| 在线视频免费在线观看一区二区| 欧美精品一区三区在线观看| 亚洲一区二区毛片| 亚洲美女啪啪| 在线观看欧美一区| 亚洲午夜激情| 国产精品多人| 欧美日韩国产综合视频在线| 免费永久网站黄欧美| 亚洲每日在线| 亚洲黄色一区| 亚洲欧洲日本一区二区三区| 欧美色123| 午夜精品久久| 午夜日韩av| 欧美理论在线| 久久一区欧美| 女主播福利一区| 乱码第一页成人| 欧美中日韩免费视频| 亚洲在线视频| 久久精品一二三区| 久久夜色精品| 久久精品国产综合精品| 男人天堂欧美日韩| 久久综合久久久| 欧美激情第10页| 欧美日韩国产精品一卡| 欧美日韩一区在线观看视频| 欧美成人免费在线| 国产真实久久| 亚洲精选一区| 亚洲在线观看| 欧美激情麻豆| 在线成人av| 国产区欧美区日韩区| 国产精品综合色区在线观看| 亚洲欧美国产不卡| 欧美一区二区三区久久精品| 欧美日本韩国在线| 影音先锋久久| 亚洲影视在线| 欧美日韩精品免费观看视频完整| 狠狠色综合网站久久久久久久| 一区国产精品| 国产农村妇女精品一二区| 久久精品综合一区| 国内精品嫩模av私拍在线观看| 亚洲国产精品www| 亚洲一区日韩| 国产精品v欧美精品v日韩精品| 极品日韩av| 欧美一进一出视频| 国产精品国产三级国产专区53| 伊人久久综合| 麻豆91精品| 亚洲国产91| 久久综合福利| 99国产成+人+综合+亚洲欧美| 久久国产日韩| 亚洲人成免费| 欧美精品一卡| 性色一区二区| 亚洲激情综合| 欧美涩涩视频| 男女精品网站| 99视频精品免费观看| 午夜视频一区| 免费日韩一区二区| 一本综合精品| 亚洲一本视频| 巨乳诱惑日韩免费av| 亚洲色诱最新| 亚洲黄色大片| 黄页网站一区| 欧美日韩精品免费观看视一区二区 | 一区二区福利| 欧美涩涩网站| 欧美在线高清| 久久都是精品| 国产精品裸体一区二区三区| 亚洲婷婷免费| 欧美婷婷在线| 午夜精品免费| 久久影院亚洲| 久久精品123| 午夜一区在线| 亚洲综合不卡| 国产嫩草一区二区三区在线观看| 亚洲精品1区| 亚洲国产精品第一区二区| 欧美精品97| 欧美日韩a区| 欧美1区免费| 欧美激情 亚洲a∨综合| 久久蜜桃精品| 久久综合狠狠| 久久免费高清| 欧美国产三级| 国产精品对白刺激久久久| 欧美成人高清| 欧美午夜一区| 激情欧美一区| 亚洲区第一页| 在线亚洲观看| 国产农村妇女精品一二区| 国产日韩视频| 亚洲在线免费| 玖玖国产精品视频| 欧美日韩在线大尺度| 韩日精品视频| 亚洲免费久久| 亚洲综合另类| 欧美粗暴jizz性欧美20| 欧美成人午夜| 好吊日精品视频| 日韩午夜黄色| 欧美亚洲专区| 欧美三级视频| 999在线观看精品免费不卡网站| 日韩视频在线观看国产| 国产精品一区二区你懂得| 久久久噜噜噜久久狠狠50岁| 欧美日韩亚洲一区二区三区在线 | 欧美成人中文| 亚洲高清在线| 国产精品日韩高清| 午夜精品免费| 亚洲精品资源| 午夜视频一区| 一区二区三区av| 欧美精品一区二区三区在线看午夜| 亚洲性视频h| 性娇小13――14欧美| 国产精品国产一区二区 | 亚洲精品资源| 美女黄网久久| 韩国精品一区二区三区| 国产精品一区二区你懂得| 欧美日韩免费| 亚洲女人av| 精品91在线| 久久综合影音| 国产欧美日韩综合一区在线播放| 久久亚洲色图| 国产欧美日本在线| 极品日韩av| 欧美另类女人| 午夜宅男久久久| 日韩视频免费| 国产精品videossex久久发布| 夜久久久久久| 伊人久久成人| 欧美精品麻豆| 久热这里只精品99re8久| 一区二区毛片| 亚洲激情精品| 国产精品a级|