中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

html5 迷宮游戲(碰撞檢測(cè))實(shí)例一
來(lái)源:易賢網(wǎng) 閱讀:1538 次 日期:2016-07-13 13:58:39
溫馨提示:易賢網(wǎng)小編為您整理了“html5 迷宮游戲(碰撞檢測(cè))實(shí)例一”,方便廣大網(wǎng)友查閱!

通過(guò)鼠標(biāo)拖拽在畫(huà)布上添加墻壁,通過(guò)方向鍵控制多邊形上下左右移動(dòng),遇到墻壁則無(wú)法前進(jìn),下面為大家介紹下需要解決的問(wèn)題及具體的實(shí)現(xiàn)代碼,感興趣的朋友可以學(xué)習(xí)下

需要解決的問(wèn)題

鼠標(biāo)按下,鼠標(biāo)拖動(dòng),鼠標(biāo)釋放事件的檢測(cè)

多邊形的繪制

墻壁的繪制

多邊形和墻壁的碰撞檢測(cè)(實(shí)質(zhì)上是圓和線段的相交判斷)

MYCode:

代碼如下:

<html>

<head>

<title>迷宮</title>

<script>

var canvas_width = 900;

var canvas_height = 350;

var ctx;

var canvas;

var everything = [];

var cur_wall;

var wall_width;

var wall_style = "rgb(200,0,200)";

var walls = [];

var in_motion = false;

var unit = 10;

function Token(sx, sy, rad, style_string, n)

{

this.sx = sx;

this.sy = sy;

this.rad = rad;

this.draw = draw_token;

this.n = n;

this.angle = (2 * Math.PI) / n;

this.move = move_token;

this.fill_style = style_string;

}

function draw_token()//繪制正n邊形

{

ctx.fill_style = this.fill_style;

ctx.beginPath();

var i;

var rad = this.rad;

ctx.moveTo(this.sx + rad * Math.cos(-0.5 * this.angle), this.sy + rad * Math.sin(-0.5 * this.angle));

for (i = 1; i < this.n; i++)

ctx.lineTo(this.sx + rad * Math.cos((i - 0.5) * this.angle), this.sy + rad * Math.sin((i - 0.5) * this.angle));

ctx.fill();

}

function move_token(dx, dy)

{

this.sx += dx;

this.sy += dy;

var i;

var wall;

for (i = 0; i < walls.length; i++)

{

wall = walls[i];

if (intersect(wall.sx, wall.sy, wall.fx, wall.fy, this.sx, this.sy, this.rad))

{

this.sx -= dx;

this.sy -= dy;

break;

}

}

}

function Wall(sx, sy, fx, fy, width, styleString)

{

this.sx = sx;

this.sy = sy;

this.fx = fx;

this.fy = fy;

this.width = width;

this.draw = draw_line;

this.strokeStyle = styleString;

}

function draw_line()

{

ctx.lineWidth = this.width;

ctx.strokeStye = this.strokeStyle;

ctx.beginPath();

ctx.moveTo(this.sx, this.sy);

ctx.lineTo(this.fx, this.fy);

ctx.stroke();

}

//note

var mypent = new Token(100, 100, 20, "rgb(0,0,250)", 5);

everything.push(mypent);

function init()

{

canvas = document.getElementById("canvas");

ctx = canvas.getContext('2d');

//note

canvas.addEventListener('mousedown', start_wall, false);

canvas.addEventListener('mousemove', stretch_wall, false);

canvas.addEventListener('mouseup', finish_wall, false);

window.addEventListener('keydown', getkey_and_move, false);

draw_all();

}

function start_wall(ev)

{

var mx;

var my;

if (ev.layerX || ev.layerx == 0)

{

mx = ev.layerX;

my = ev.layerY;

}

else if (ev.offsetX || ev.offsetX == 0)

{

mx = ev.offsetX;

my = ev.offsetY;

}

cur_wall = new Wall(mx, my, mx + 1, my + 1, wall_width, wall_style);

in_motion = true;

everything.push(cur_wall);

draw_all();

}

function stretch_wall(ev)

{

if (in_motion)

{

var mx;

var my;

if (ev.layerX || ev.layerX == 0)

{

mx = ev.layerX;

my = ev.layerY;

}

else if (ev.offsetX || ev.offsetX == 0)

{

mx = ev.offsetX;

my = ev.offsetY;

}

cur_wall.fx = mx;

cur_wall.fy = my;

draw_all();

}

}

function finish_wall(ev)

{

in_motion = false;

walls.push(cur_wall);

}

function draw_all()

{

ctx.clearRect(0, 0, canvas_width, canvas_height);

var i;

for (i = 0; i < everything.length; i++)

{

everything[i].draw();

}

}

function getkey_and_move(event)

{

var keyCode;

if (event == null)

{

keyCode = window.event.keyCode;

window.event.preventDefault();

}

else

{

keyCode = event.keyCode;

event.preventDefault();

}

switch (keyCode)

{

case 37://left arrow

mypent.move(-unit, 0);

break;

case 38://up arrow

mypent.move(0, -unit);

break;

case 39://right arrow

mypent.move(unit, 0);

break;

case 40:

mypent.move(0, unit);

break;

default:

//window.removeEventListener('keydown', getkey_and_move, false);

}

draw_all();

}

function intersect(sx, sy, fx, fy, cx, cy, rad)

{

var dx;

var dy;

var t;

var rt;

dx = fx - sx;

dy = fy - sy;

t = 0.0 - (((sx - cx) * dx + (sy - cy) * dy) / (dx * dx + dy * dy));

if (t < 0.0)

{

t = 0.0;

}

else if (t > 1.0)

t = 1.0;

var dx1 = (sx + t * dx) - cx;

var dy1 = (sy + t * dy) - cy;

var rt = dx1 * dx1 + dy1 * dy1;

if (rt < rad * rad)

return true;

else

return false;

}

</script>

<body onLoad="init();">

<canvas id="canvas" width="900" height="350"></canvas>

</body>

</html>

難點(diǎn)

多邊形和線段碰撞檢測(cè)的方法

函數(shù)intersect()負(fù)責(zé)檢測(cè)多邊形和線段是否相交

記線段上一點(diǎn)p(x,y)

線段2個(gè)端點(diǎn)是(sx,sy)和(fx,fy)

dx=fx-sx

dy=fy-sy

x和y可以表示如下

x=sx+t*dx

y=sy+t*dy

要判斷線段和多邊形是否相交,轉(zhuǎn)化為判斷線段和多邊形的外接圓是否相交

為此需要找到線段上離圓心o最近的一點(diǎn)p

如果|op|<圓的半徑,則可以判斷線段和圓相交。

否則不相交。

怎么找到線段上離圓心距離最近的點(diǎn)呢?

p點(diǎn)到o點(diǎn)的距離可以表示為

distance=sqrt((x-cx)*(x-cx)+(y-cy)*(y-cy));

代入

x=sx+t*dx和y=sy+t*dy

可以得到distance是一個(gè)關(guān)于t的函數(shù)

對(duì)此函數(shù)求導(dǎo)

求出函數(shù)值為0時(shí)對(duì)應(yīng)的t值就可以得到距離圓心最近的點(diǎn)

更多信息請(qǐng)查看網(wǎng)頁(yè)制作
易賢網(wǎng)手機(jī)網(wǎng)站地址:html5 迷宮游戲(碰撞檢測(cè))實(shí)例一
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!
相關(guān)閱讀網(wǎng)頁(yè)制作

2026上岸·考公考編培訓(xùn)報(bào)班

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
亚洲成人在线视频播放| 欧美片网站免费| 亚洲一区二区三区久久| 欧美黄色一区二区| 国产一区二区视频在线观看 | 欧美成人精品一区| 亚洲福利视频一区| 久久婷婷av| 性欧美xxxx大乳国产app| 99精品热视频| 久久综合久色欧美综合狠狠| 国产欧美日韩亚洲精品| 欧美日韩免费视频| 激情综合五月天| 日韩午夜在线播放| 久久亚洲国产成人| 亚洲国产精品第一区二区| 久久免费视频网站| 亚洲国产日韩在线| 欧美精品一区二区蜜臀亚洲 | 国产精品卡一卡二卡三| av不卡在线| 欧美日韩无遮挡| 亚洲天堂av在线免费观看| 亚洲动漫精品| 欧美日韩一区二区免费视频| 亚洲视频在线观看视频| 欧美视频网址| 一色屋精品视频在线看| 久久久久久久激情视频| 伊人激情综合| 欧美日韩不卡| 久久综合色88| 91久久精品日日躁夜夜躁欧美| 女人色偷偷aa久久天堂| 一区二区免费在线视频| 欧美日韩免费精品| 午夜精品99久久免费| 国产一区二区三区日韩| 欧美日韩视频在线第一区| 久久精品国产久精国产爱| 亚洲精品乱码| 国产亚洲欧美一区在线观看| 欧美成人精品在线播放| 一本色道久久综合亚洲91| 国产一区二区日韩精品欧美精品 | 亚洲图色在线| 韩日在线一区| 欧美调教vk| 在线一区二区三区做爰视频网站| 国产乱人伦精品一区二区| 欧美紧缚bdsm在线视频| 欧美在线综合| 午夜在线视频观看日韩17c| 国产视频一区二区在线观看| 欧美日韩1区| 久久久爽爽爽美女图片| 亚洲免费伊人电影在线观看av| 玉米视频成人免费看| 久久综合九色| 午夜一级在线看亚洲| 亚洲国产欧美一区二区三区久久| 国产精品一卡| 久久综合九色99| 久久精品成人| 正在播放欧美视频| 亚洲电影免费观看高清完整版| 激情久久久久久| 国产精品卡一卡二| 国产乱码精品一区二区三区五月婷 | 999在线观看精品免费不卡网站| 国产日韩欧美a| 国产深夜精品| 国产精品卡一卡二| 国产精品久久久久久妇女6080| 免费成人小视频| 免费欧美在线| 另类人畜视频在线| 久久久精品一品道一区| 久久久久久亚洲综合影院红桃 | 久久精品国产清自在天天线| 亚洲综合视频网| 亚洲精品欧美极品| 亚洲国产欧美一区二区三区丁香婷| 亚洲国产日韩在线一区模特| 欧美激情在线有限公司| 久久成人在线| 亚洲欧美日韩另类| 亚洲久色影视| 国产精品无码永久免费888| 欧美成人在线免费观看| 欧美国产日韩一区二区| 欧美ed2k| 欧美日韩系列| 欧美日产一区二区三区在线观看| 99视频有精品| 亚洲日本免费| 一区二区亚洲欧洲国产日韩| 国产欧美一区二区三区久久人妖| 亚洲国产精品久久久| 香蕉av777xxx色综合一区| 免费观看日韩| 久久综合伊人77777| 亚洲在线一区二区| 久久本道综合色狠狠五月| 精品动漫3d一区二区三区免费版 | 99re66热这里只有精品3直播| 夜夜嗨av一区二区三区四季av | 免费影视亚洲| 欧美一区免费| 欧美国产亚洲视频| 国产精品女主播在线观看 | 亚洲高清视频在线观看| 国内精品视频666| 在线看日韩av| 尤物精品在线| 99国内精品| 亚洲成人资源网| 国产精品爽爽ⅴa在线观看| 欧美视频在线观看免费| 在线观看日韩av电影| 在线免费日韩片| 宅男在线国产精品| 亚洲性线免费观看视频成熟| 久久激情五月婷婷| 免费成人黄色| 国产日韩欧美a| 1204国产成人精品视频| 一本综合久久| 久久精品国产亚洲一区二区| 欧美在线亚洲一区| 欧美大片免费久久精品三p | 亚洲精品日韩精品| 麻豆成人小视频| 欧美精品高清视频| 亚洲国产成人av在线| 国产精品免费aⅴ片在线观看| 亚洲精选视频在线| 亚洲视频综合| 欧美日韩在线精品| 欧美性理论片在线观看片免费| 亚洲国产精品一区二区尤物区| 亚洲精品美女在线| 久久婷婷久久| 欧美成人自拍视频| 精品96久久久久久中文字幕无| 亚洲国产美女| 欧美黄色成人网| 欧美日韩大陆在线| 亚洲激情女人| 亚洲主播在线观看| 欧美午夜不卡视频| 国产一区二区精品| 亚洲国产日韩精品| 久久久九九九九| 永久域名在线精品| 亚洲视频播放| 国产精品一区二区在线| 亚洲日本乱码在线观看| 欧美国产亚洲视频| 国产日韩欧美一区二区三区四区| 亚洲在线1234| 国产精品系列在线播放| 亚洲欧美成人网| 午夜视频在线观看一区二区三区| 欧美日本亚洲| 一本久久a久久免费精品不卡| 久久综合999| 国产欧美日韩三区| 国产老女人精品毛片久久| 在线成人激情视频| 欧美亚洲免费电影| 一区在线视频| 午夜精品www| 国产精品一区二区女厕厕| 国产精品私拍pans大尺度在线 | 亚洲欧美电影院| 欧美大片在线看免费观看| 日韩亚洲国产欧美| 欧美激情一区二区三级高清视频| 亚洲一区二区三区在线视频| 欧美三区在线观看| 欧美在线视频一区二区| 国产原创一区二区| 欧美日韩国产探花| 夜夜精品视频| 激情亚洲成人| 欧美激情精品久久久久久免费印度| 午夜精品成人在线| 韩国女主播一区二区三区| 欧美日韩一区二区欧美激情 | 一色屋精品亚洲香蕉网站| 一区二区三区日韩精品| 在线观看欧美亚洲| 国产精品免费看久久久香蕉| 久久综合九色综合久99| 亚洲人精品午夜| 国产欧美在线视频| 欧美日韩在线免费视频| 午夜精品久久久久久久久久久久久 |