亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

Html5 Canvas動畫基礎碰撞檢測的實現

2024-08-26 00:21:11
字體:
來源:轉載
供稿:網友

在Canvas中進行碰撞檢測,大家往往直接采用游戲引擎(Cocos2d-JS、Egret)或物理引擎(Box2D)內置的碰撞檢測功能,好奇的你有思考過它們的內部運行機制嗎?下面將針對基本的碰撞檢測技術進行講解:

1、基于矩形的碰撞檢測

所謂碰撞檢測就是判斷物體間是否發生重疊,這里我們假設討論的碰撞體都是矩形物體。下面示例中我們將創建兩個rect對象A和B(以下簡稱A,B),其中A位置固定,B跟隨鼠標移動,當A,B重疊時控制臺將提示intercect??!

1、創建Rect對象

這里我們新建Rect.js,建立Rect對象并為其添加原型方法draw,該方法將根據當前對象的屬性(位置、大小)繪制到傳入的畫布對象(context)中。

代碼如下 :

function Rect(x,y,width,height) {    this.x = x;    this.y = y;    this.width = width;    this.height = height;}Rect.prototype.draw = function(context){    context.save();    context.translate(this.x,this.y);    context.fillRect(0,0,this.width,this.height);    context.restore();}

2、獲取鼠標位置

因為B需要跟隨鼠標移動所以我們需要檢測鼠標在畫布的當前位置。創建Capturemouse函數檢測鼠標在傳入的文檔節點(element)上的移動并返回一個mouse對象(其中包含了鼠標的x,y坐標)。

代碼如下:

function Capturemouse (element) {    var mouse={x:null,y:null};    element.addEventListener('mousemove',function (event) {        var x, y;        if(event.pageX || event.pageY){            x = event.pageX;            y = event.pageY;        }else{            x = event.clientX+document.body.scrollLeft+                document.documentElement.scrollLeft;            y = event.clientY+document.body.scrollTop+                document.documentElement.scrollTop;        }        x -=element.offsetLeft;        y -=element.offsetTop;        mouse.x = x;        mouse.y = y;    },false);    return mouse;}

3、碰撞檢測

檢測A,B是否發生重疊,在討論是否發生重疊時我們可以先看看沒有重疊的四種情況,如下圖:

Html5,Canvas,動畫,碰撞檢測

以下是對這四種狀態的判斷:

1、rectB.y+rectB.height < rectA.y
2、rectB.y > rectA.x +rectA.width
3、rectB.y > rectA.y + rectA.height
4、rectB.x+rectB.width < rectA.x

知道如何判斷沒有重疊的狀態,那發生重疊的狀態該如何判斷呢?沒錯“取反”!,我們創建函數Interaect并添加到Init.js中,該函數傳入兩個Rect對象參數,當兩Rect對象發生重疊將返回true。

代碼如下:

function Intersect(rectA,rectB) {    return !(rectB.y+rectB.height < rectA.y || rectB.y > rectA.x +rectA.width ||        rectB.y > rectA.y + rectA.height|| rectB.x+rectB.width < rectA.x)}

4、動畫循環

新建animationjs,設置requestAnimationFrame()動畫函數。

在循環體中將做以下兩件事:

  • “清空”當前canvas中內容,為繪制下一幀做準備。
  • 檢測A,B是否發生重疊,若重疊則在控制臺輸出interact?。?!
  • 檢測當前鼠標在canvas上的移動并將鼠標位置更新到B的位置屬性中。
  • 根據新的位置屬性重新繪制A,B(當然,A的位置不會更新但因為每次循環將清空canvas所以需要重新繪制)

代碼如下:

function drawAnimation() {    window.requestAnimationFrame(drawAnimation);    context.clearRect(0, 0, canvas.width, canvas.height);    if(Intersect(rectA,rectB)){     console.log('interact!!!!');    }    if(mouse.x){        rectB.x = mouse.x;        rectB.y = mouse.y;    }    rectA.draw(context);    rectB.draw(context);}

3、初始化

新建Init.js ,獲取canvas元素并綁定鼠標移動檢測,初始化Rect對象A和B,最后開啟動畫循環。

代碼如下:

window.onload = function () {    canvas = document.getElementById('collCanvas');    context = canvas.getContext('2d');    Capturemouse(canvas);    rectA = new Rect(canvas.width/2,canvas.height/2,100,100);    rectB = new Rect(100,100,100,100);    drawAnimation();}

2、基于圓形的碰撞檢測

說完矩形碰撞,我們再來聊聊圓形碰撞,同樣我們將創建兩個Circle對象A和B(以下簡稱A,B),其中A位置固定,B跟隨鼠標移動,當A,B重疊時控制臺將提示intercect!!

1、創建circle對象

function Circle(x,y,radius) {    this.x = x;    this.y = y;    this.radius = radius;}Circle.prototype.draw = function(context){    context.save();    context.translate(this.x,this.y);    context.beginPath();    context.arc(0,0,this.radius,0,Math.PI*2,false);    context.fill();    context.restore();}

2、檢測圓形碰撞

圓形間碰撞檢測可以簡單地通過兩圓心間距離與兩圓半徑之和的比較做判斷,當兩圓心距離小于兩圓半徑之和時則發生碰撞。

如下圖:

Html5,Canvas,動畫,碰撞檢測

所以我們首先需要做的是計算出兩圓心間的距離,這里我們將用到兩點間的距離公式,如下:

Html5,Canvas,動畫,碰撞檢測

當取得兩圓心間的距離之后將與兩圓半徑之和比較,如果距離小于半徑之和則返回true。

現在我們更新Interaect函數。

代碼如下:

function Intersect(circleA,circleB) {    var dx = circleA.x-circleB.x;    var dy = circleA.y-circleB.y;    var distance = Math.sqrt(dx*dx+dy*dy);    return distance < (circleA.radius + circleB.radius);}

3、動畫循環

更新animation.js,這里我們替換Rect對象為Circle對象。

代碼如下:

function drawAnimation() {    window.requestAnimationFrame(drawAnimation);    context.clearRect(0, 0, canvas.width, canvas.height);    if(Intersect(circleA,circleB)){     console.log('interact!!!!');    }    if(mouse.x){        circleB.x = mouse.x;        circleB.y = mouse.y;    }    circleA.draw(context);    circleB.draw(context);}

4、初始化

更新Init.js ,初始化Circle對象A和B,最后開啟動畫循環。

代碼如下:

window.onload = function () {    canvas = document.getElementById('collCanvas');    context = canvas.getContext('2d');    Capturemouse(canvas);    circleA = new Circle(canvas.width/2,canvas.height/2,100);    circleB = new Circle(100,100,100);    drawAnimation();}

3、基于矩形與圓形間的碰撞檢測

前面講解都是單一形狀間的碰撞檢測,下面我們將檢測矩形和圓形間的碰撞。

1、檢測碰撞

和矩形檢測一樣,我們先看看沒有發生碰撞的四種情況。

如下圖:

Html5,Canvas,動畫,碰撞檢測

以下是對這四種狀態的判斷:

  • Circle.y + Circle.radius < Rect.y
  • Circle.x - Circle.radius > Rect.x + Rect.width
  • Circle.y - Circle.radius > Rect.y + Rect.height
  • Circle.x + Circle.radius < Rect.x

更新Interaect函數,將沒有重疊的狀態“取反”,向該函數傳入Rect對象和Circle對象,當Rect對象與Circle對象發生重疊將返回true。

代碼如下:

function Intersect(Rect,Circle) {    return !(Circle.y + Circle.radius < Rect.y ||             Circle.x - Circle.radius > Rect.x + Rect.width ||             Circle.y - Circle.radius > Rect.y + Rect.height ||             Circle.x + Circle.radius < Rect.x)}

2、動畫循環

更新animation.js,這里我們將circle對象跟隨鼠標運動,并檢測與固定位置的rect對象的碰撞。

代碼如下:

function drawAnimation() {    window.requestAnimationFrame(drawAnimation);    context.clearRect(0, 0, canvas.width, canvas.height);    if(Intersect(rect,circle)){     console.log('interact!!!!');    }    if(mouse.x){        circle.x = mouse.x;        circle.y = mouse.y;    }    circle.draw(context);    rect.draw(context);}

3、初始化

更新Init.js ,初始化Circle對象和Rect對象,最后開啟動畫循環。

代碼如下:

window.onload = function () {    canvas = document.getElementById('collCanvas');    context = canvas.getContext('2d');    Capturemouse(canvas);    circle = new Circle(100,100,100);    rect = new Rect(canvas.width/2,canvas.height/2,100,100);    drawAnimation();}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人三级视频网站| 国产精品视频网站| 高清在线视频日韩欧美| 国产精品久久久久久婷婷天堂| 97在线视频一区| 国产日韩在线精品av| 久久69精品久久久久久久电影好| 日韩精品在线观看网站| 91视频国产一区| 欧美精品18videos性欧美| 欧美视频国产精品| 国产精品第1页| 欧美日韩国产精品专区| 国产精品观看在线亚洲人成网| 美女少妇精品视频| 色99之美女主播在线视频| 亚洲第一页在线| 国产91精品久久久久| 精品视频偷偷看在线观看| 在线观看国产精品日韩av| 国产精品久久国产精品99gif| 亚洲另类欧美自拍| 热门国产精品亚洲第一区在线| 成人精品视频在线| 日韩小视频在线| 中文字幕精品—区二区| 亚洲精品国产精品国自产观看浪潮| 亚洲 日韩 国产第一| 亚洲欧美国产制服动漫| 国产精品久久久av久久久| 国产亚洲欧美另类中文| 亚洲精品网站在线播放gif| 久久九九国产精品怡红院| 青青久久av北条麻妃黑人| 69久久夜色精品国产7777| 青草青草久热精品视频在线观看| 中文字幕久久亚洲| 欧洲亚洲免费视频| 欧美三级免费观看| 久久久久久久影视| 国产不卡一区二区在线播放| 国产专区精品视频| 欧美亚洲在线观看| 国产精品久久久久久久久免费看| 亚洲成人久久久久| 一区二区三区精品99久久| 欧美日韩国产精品一区二区三区四区| 久久99精品久久久久久琪琪| 亚洲成人在线网| 欧美性资源免费| 亚洲一品av免费观看| 欧美国产日韩一区二区三区| 日韩高清欧美高清| 日韩精品中文字幕有码专区| 日韩在线免费av| 亚洲免费av电影| 日韩电影大全免费观看2023年上| 欧美中文字幕视频| 国产精品都在这里| 亚洲欧美日韩一区二区在线| 色婷婷综合久久久久中文字幕1| 久久中文字幕视频| 欧美日韩一区二区免费视频| 国产aaa精品| 欧美黑人视频一区| 国产成人一区三区| 亚洲国产一区二区三区在线观看| 日韩的一区二区| 国产一区二区三区视频| 久久99精品久久久久久琪琪| 亚洲精品国产免费| 国产精品手机播放| 国产精欧美一区二区三区| 国产亚洲一区二区在线| 国产亚洲欧美日韩一区二区| 国产精品中文在线| 亚洲男人天堂2019| 久国内精品在线| 成人久久久久久久| 国产欧美精品久久久| 国产精品成人一区二区三区吃奶| 中文字幕亚洲一区在线观看| 国产精品久久色| 日韩电影第一页| 永久免费看mv网站入口亚洲| 2019亚洲日韩新视频| 成人黄色短视频在线观看| 日韩高清a**址| 亚洲电影免费在线观看| 日韩中文字幕在线视频播放| 亚洲专区国产精品| 欧美另类69精品久久久久9999| 亚洲人永久免费| 亚洲伊人一本大道中文字幕| 欧美黑人视频一区| 成人免费观看49www在线观看| 91久久精品在线| 精品亚洲一区二区三区| 18性欧美xxxⅹ性满足| 日韩av观看网址| 欧美丝袜一区二区| 视频一区视频二区国产精品| 国产精品久久久久久久9999| 日韩在线视频一区| 亚洲国产黄色片| 亚洲第一精品夜夜躁人人爽| 在线播放国产一区中文字幕剧情欧美| 精品国内自产拍在线观看| 久久久97精品| 九九视频直播综合网| 欧美成人一二三| 国产精品视频在线观看| 亚洲国产精品999| 国产精品露脸自拍| 久久久亚洲精品视频| 日韩av综合中文字幕| 高清一区二区三区日本久| 日韩一区二区欧美| 国产一区二区三区视频在线观看| 在线午夜精品自拍| 亚洲在线免费视频| 国产免费成人av| 亚洲天堂第二页| 91亚洲精品久久久| 91香蕉国产在线观看| 一区二区亚洲精品国产| 亚洲精品国产精品乱码不99按摩| 57pao成人国产永久免费| 91精品综合久久久久久五月天| 欧美视频专区一二在线观看| 国产精品一区二区av影院萌芽| 亚洲成人激情小说| 91香蕉嫩草神马影院在线观看| 久久99精品久久久久久青青91| 久久91精品国产91久久久| 欧美日韩另类在线| 日韩资源在线观看| 欧美日韩一区二区精品| 国产丝袜视频一区| 日韩精品丝袜在线| 在线观看日韩www视频免费| 97婷婷大伊香蕉精品视频| 久久99久久亚洲国产| 国产精品热视频| 久久精品国产亚洲精品2020| 久久久久在线观看| 久久精品成人欧美大片| 动漫精品一区二区| 国产成人免费91av在线| 国产精品v日韩精品| 欧美日韩中文字幕日韩欧美| 午夜精品久久久久久99热软件| 岛国av午夜精品| 中文字幕亚洲欧美在线| 久久国产精品久久精品| 中文字幕亚洲欧美日韩高清| 亚洲视频axxx| 免费97视频在线精品国自产拍| 国产主播欧美精品| 福利视频一区二区| 欧美日韩一二三四五区| 精品五月天久久| 久久国产精品久久久| 日韩在线免费视频|