亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

主頁 > 知識庫 > Html5 Canvas動畫基礎碰撞檢測的實現(xiàn)

Html5 Canvas動畫基礎碰撞檢測的實現(xiàn)

熱門標簽:智能電銷機器人被禁用了么 欣鼎電銷機器人 效果 高德地圖標注商戶怎么標 黃石ai電銷機器人呼叫中心 電話機器人技術 惡搞電話機器人 ok電銷機器人 如何查看地圖標注 地圖標注軟件打印出來

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

1、基于矩形的碰撞檢測

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

1、創(chuàng)建Rect對象

這里我們新建Rect.js,建立Rect對象并為其添加原型方法draw,該方法將根據(jù)當前對象的屬性(位置、大小)繪制到傳入的畫布對象(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需要跟隨鼠標移動所以我們需要檢測鼠標在畫布的當前位置。創(chuàng)建Capturemouse函數(shù)檢測鼠標在傳入的文檔節(jié)點(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是否發(fā)生重疊,在討論是否發(fā)生重疊時我們可以先看看沒有重疊的四種情況,如下圖:

以下是對這四種狀態(tài)的判斷:

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

知道如何判斷沒有重疊的狀態(tài),那發(fā)生重疊的狀態(tài)該如何判斷呢?沒錯“取反”!,我們創(chuàng)建函數(shù)Interaect并添加到Init.js中,該函數(shù)傳入兩個Rect對象參數(shù),當兩Rect對象發(fā)生重疊將返回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、動畫循環(huán)

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

在循環(huán)體中將做以下兩件事:

  • “清空”當前canvas中內(nèi)容,為繪制下一幀做準備。
  • 檢測A,B是否發(fā)生重疊,若重疊則在控制臺輸出interact!!!
  • 檢測當前鼠標在canvas上的移動并將鼠標位置更新到B的位置屬性中。
  • 根據(jù)新的位置屬性重新繪制A,B(當然,A的位置不會更新但因為每次循環(huán)將清空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,最后開啟動畫循環(huán)。

代碼如下:

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、基于圓形的碰撞檢測

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

1、創(chuàng)建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、檢測圓形碰撞

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

如下圖:

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

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

現(xiàn)在我們更新Interaect函數(shù)。

代碼如下:

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、動畫循環(huán)

更新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,最后開啟動畫循環(huán)。

代碼如下:

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、檢測碰撞

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

如下圖:

以下是對這四種狀態(tài)的判斷:

  • 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函數(shù),將沒有重疊的狀態(tài)“取反”,向該函數(shù)傳入Rect對象和Circle對象,當Rect對象與Circle對象發(fā)生重疊將返回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、動畫循環(huán)

更新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對象,最后開啟動畫循環(huán)。

代碼如下:

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();
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

標簽:赤峰 金昌 聊城 中山 阿壩 萍鄉(xiāng) 盤錦 綏化

巨人網(wǎng)絡通訊聲明:本文標題《Html5 Canvas動畫基礎碰撞檢測的實現(xiàn)》,本文關鍵詞  Html5,Canvas,動畫,基礎,碰撞,;如發(fā)現(xiàn)本文內(nèi)容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Html5 Canvas動畫基礎碰撞檢測的實現(xiàn)》相關的同類信息!
  • 本頁收集關于Html5 Canvas動畫基礎碰撞檢測的實現(xiàn)的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    国产欧美精品午夜在线播放| 精品国产三级a∨在线观看| 国产a视频精品免费观看| 97视频免费在线观看| 久久精品免视看国产明星| 精品国产三级a∨在线观看| 97视频免费在线观看| 久久99中文字幕| 国产一区精品| 精品国产亚一区二区三区| 99久久视频| 国产韩国精品一区二区三区| 成人免费观看的视频黄页| 四虎久久精品国产| 九九久久国产精品| 日韩在线观看免费| 亚洲精品中文字幕久久久久久| 日韩在线观看免费| 国产一级强片在线观看| 午夜久久网| 久久99中文字幕| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 精品国产亚洲人成在线| 91麻豆精品国产高清在线| 日本在线不卡免费视频一区| 久久国产精品永久免费网站| 国产91丝袜在线播放0| 国产精品免费精品自在线观看| 九九久久国产精品大片| 欧美国产日韩精品| a级毛片免费全部播放| 亚洲精品影院| 九九免费精品视频| 久久精品人人做人人爽97| 成人影视在线播放| 色综合久久天天综线观看| 欧美另类videosbestsex视频| 成人影院久久久久久影院| 午夜在线亚洲| 久久国产一区二区| 国产麻豆精品视频| 高清一级淫片a级中文字幕| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 超级乱淫黄漫画免费| 国产麻豆精品hdvideoss| 99久久精品费精品国产一区二区| 国产精品免费久久| 国产网站在线| 国产一区精品| 国产视频一区在线| 国产精品自拍亚洲| 韩国三级视频网站| 国产不卡在线看| 午夜激情视频在线播放| 精品视频在线观看免费| 久久精品免视看国产明星| 国产美女在线一区二区三区| 成人免费高清视频| 欧美另类videosbestsex视频| 国产网站在线| 久久精品成人一区二区三区| 一 级 黄 中国色 片| 99热精品一区| 成人a级高清视频在线观看| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 国产精品1024永久免费视频| 久久福利影视| 精品国产一区二区三区久| 亚洲天堂免费观看| 国产a视频精品免费观看| 久久久久久久久综合影视网| 九九精品久久| 亚洲 欧美 成人日韩| 中文字幕97| 成人高清视频在线观看| 香蕉视频久久| 香蕉视频一级| 国产成人精品影视| 精品久久久久久中文| 日本在线www| 久久成人综合网| 久久精品道一区二区三区| 亚洲爆爽| 国产不卡在线观看视频| 欧美1区| 亚洲第一色在线| 九九精品影院| 高清一级做a爱过程不卡视频| 色综合久久天天综合| 久久精品免视看国产明星| 国产综合91天堂亚洲国产| 国产网站在线| 精品在线观看国产| 天天做日日爱| 亚洲第一色在线| a级毛片免费全部播放| 国产亚洲男人的天堂在线观看| 麻豆系列 在线视频| 国产一级强片在线观看| 亚洲 男人 天堂| 午夜家庭影院| 精品国产一区二区三区久| 欧美国产日韩在线| 韩国毛片基地| 成人高清护士在线播放| 黄色免费网站在线| 成人高清视频免费观看| 国产精品自拍一区| 毛片电影网| 精品国产一区二区三区久久久狼| 四虎久久影院| 国产麻豆精品高清在线播放| 国产精品自拍在线| 亚欧成人毛片一区二区三区四区 | 成人高清免费| 精品国产一区二区三区精东影业| 色综合久久天天综合观看| 天堂网中文在线| 国产综合91天堂亚洲国产| 亚洲精品久久玖玖玖玖| 91麻豆精品国产综合久久久| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 可以免费在线看黄的网站| 国产a视频| 国产不卡福利| 国产美女在线观看| 国产91素人搭讪系列天堂| 在线观看成人网| 四虎影视库| 亚洲爆爽| 黄色短视频网站| 日本伦理片网站| 台湾毛片| 国产视频久久久| 精品视频在线观看视频免费视频| 国产不卡高清在线观看视频| 韩国毛片免费| 国产视频久久久| 中文字幕一区二区三区精彩视频| 久久国产影视免费精品| 亚洲 国产精品 日韩| 欧美激情伊人| 午夜精品国产自在现线拍| 毛片高清| 亚洲 激情| 黄色免费三级| 美女免费黄网站| 毛片成人永久免费视频| 久久国产影视免费精品| 九九九国产| 九九九国产| 国产成a人片在线观看视频| 精品国产亚洲一区二区三区| 中文字幕一区二区三区精彩视频| 国产视频一区二区在线播放| 国产网站免费| 国产精品免费精品自在线观看| 日韩专区一区| 黄视频网站在线看| 国产精品1024永久免费视频| 日韩在线观看免费完整版视频| 日本在线不卡视频| 欧美电影免费| a级毛片免费观看网站| 91麻豆精品国产自产在线| 国产网站免费| 九九久久国产精品| 精品视频在线观看免费| 国产视频一区二区在线观看 | 韩国毛片免费大片| 久久久久久久久综合影视网| 91麻豆精品国产片在线观看| 黄色短视频网站| 国产韩国精品一区二区三区| 成人免费高清视频| 欧美激情伊人| 日韩中文字幕在线观看视频| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产a毛片| 久久久久久久久综合影视网| 国产一级生活片| 国产极品精频在线观看| 99久久网站| 午夜在线影院| 国产不卡高清| 国产综合成人观看在线| 九九干| 99久久视频| 国产不卡在线看| 91麻豆国产| 高清一级淫片a级中文字幕| 国产不卡高清| 精品国产香蕉在线播出| 精品国产三级a∨在线观看| 精品视频在线观看免费| 亚欧乱色一区二区三区| 亚洲爆爽| 久久国产精品自线拍免费| 亚欧成人毛片一区二区三区四区 | 欧美激情伊人|