成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[phaser3學(xué)習(xí)]使用phaser3做一款飛刀小游戲

BothEyes1993 / 3275人閱讀

摘要:前言作為一款流行的游戲動(dòng)畫框架受到很多開發(fā)者的青睞最近筆者在逛意大利開發(fā)者論壇的時(shí)候發(fā)現(xiàn)了這款小游戲所以就照著說明做了一下在這里記錄下來開發(fā)準(zhǔn)備插件腳本飛刀和靶子的圖像或者這個(gè)項(xiàng)目里面有的腳本和需要的圖像文件開始制作搭建基本的項(xiàng)目創(chuàng)建一個(gè)

前言

phaser作為一款流行的游戲/動(dòng)畫框架,受到很多web開發(fā)者的青睞,最近筆者在逛意大利開發(fā)者:emanueleferonato論壇的時(shí)候發(fā)現(xiàn)了這款小游戲,所以就照著說明做了一下,在這里記錄下來.

開發(fā)準(zhǔn)備

nodejs+npm
http-server插件
phaser腳本
飛刀和靶子的圖像

或者

git clone https://github.com/YexChen/canvas_game.git

這個(gè)項(xiàng)目里面有phaser的腳本和需要的圖像文件

開始制作 搭建基本的phaser項(xiàng)目

創(chuàng)建一個(gè)基本的html文件,引入phaser文件




  
  
  
  Document
  


  



別忘了在當(dāng)前目錄下啟動(dòng)http-server,啟動(dòng)服務(wù)器.打開localhost:8080(或其他端口)來查看項(xiàng)目

那么現(xiàn)在,我們需要干什么呢?
我們現(xiàn)在需要在頁面加載時(shí)加載一個(gè)游戲?qū)嵗?代碼如下:

let game,knifeGroup
let gameConfig = {
  rotateSpeed : 5,
  throwSpeed : 150,
  minAngle : 10
}
window.onload = function(){
    game = new Phaser.Game({
        type: Phaser.CANVAS,
        width: 600,
        height: 700,
        backgroundColor: 0xffffdffffd,
        scene: [playGame]
    })
}

Phaser.Game 是phaser游戲的構(gòu)建函數(shù),定義了實(shí)例的類型,寬高,背景顏色,場(chǎng)景等信息,大家可以console.log(Phaser)看一下定義.
playGame是接下來的場(chǎng)景.
gameConfig 是游戲的參數(shù),方便修改

接下來我們定義一下我們的場(chǎng)景:

class playGame extends Phaser.Scene{
      constructor(){
        super("playGame")
      }

      preload(){

      }

      create(){

      }

      update(){

      }
    }

場(chǎng)景在游戲中相當(dāng)于戲曲中的每一幕,通過Phaser.Scene.start來進(jìn)行調(diào)用.

在Phaser游戲中,場(chǎng)景創(chuàng)建時(shí)會(huì)先運(yùn)行preload函數(shù),用來預(yù)加載圖片模型.然后運(yùn)行create函數(shù),執(zhí)行初始化代碼,最后在每一步中調(diào)用update函數(shù)更新

預(yù)加載圖片
preload(){
        this.load.image("target","image/target.png")
        this.load.image("knife","image/knife.png")
}

在preload中加入以上代碼,把圖片注冊(cè)進(jìn)來.

加載物體
create(){
    this.target = this.add.image(game.config.width/2,game.config.height/5 *2,"target").setScale(0.5,0.5)
    this.target.depth = 1
    this.knife = this.add.image(game.config.width/2,game.config.height/5*4,"knife").setScale(0.5,0.5)
    this.knifeGroup = this.add.group()
    console.log(this)
}

this.add.image通過提供的寬高和上一步中提供的url來生成Image類型的對(duì)象(和原生的不一樣!),
對(duì)象的原型鏈上的setScale(x,y)函數(shù)可以調(diào)整圖像的縮放.
knifeGroup 是空的group對(duì)象,用來存放之后的飛刀集合

讓我們的圖像動(dòng)起來

修改update函數(shù):

update(){
        this.target.angle += gameOptions.rotateSpeed
}

好的,至此我們的項(xiàng)目基礎(chǔ)就結(jié)束了,接下來來做飛刀的邏輯吧

扔飛刀邏輯

我們首先需要監(jiān)聽用戶的鼠標(biāo)事件,可以使用Phaser內(nèi)置的函數(shù)來實(shí)現(xiàn),在created中加入:

    this.canThrow = true
    this.input.on("pointerdown",this.throwKnife,this)

throwKnife 是我們?nèi)语w刀的處理函數(shù),我們寫在update后面:

throwKnife(){
    if(!this.canThrow){
      return
    }
    this.canThrow = false
    this.tweens.add({
      targets: [this.knife],
      y: this.target.y+this.knife.height/8 * 3,
      duration: gameOptions.throwSpeed,
      callbackScope: this,
      onComplete: function(tween){
        
      },
    })
  }

我們?cè)谟脩舭聪率髽?biāo)左鍵時(shí),檢測(cè)是否可扔,如果可扔的話就讓我們的飛刀做一個(gè)tweens動(dòng)畫,this.tweens是一個(gè)tweens管理器,官方文檔比較殘廢,部分參數(shù)如下:

target : tweens動(dòng)畫目標(biāo)
y : 目標(biāo)的y坐標(biāo),
duration: 動(dòng)畫時(shí)間
callbackScope: 回調(diào)函數(shù)的this值
onComplete: 完成時(shí)的回調(diào)函數(shù)

飛刀插上去以后,我們要判斷這個(gè)飛刀是不是和其它飛刀的重合,筆者這里的判斷方式是在每一個(gè)飛刀插到盤面上時(shí)把當(dāng)前輪盤的角度保存下來,當(dāng)下一次投擲的時(shí)候判斷當(dāng)前盤面旋轉(zhuǎn)度和以往的旋轉(zhuǎn)度距離是否小于最小值,如果小于最小值就游戲結(jié)束,否則就插一次飛刀.

我們?cè)谏厦娴膐nComplete函數(shù)里面寫下代碼:

let isLegal = true
let children = this.knifeGroup.getChildren()
for(var i=0;i

我們判斷之前所有飛刀的impactAngle值,如果沒有和當(dāng)前角度相差10度的,我們就插入新的飛刀,否則播放動(dòng)畫以后重啟游戲.

更新每一把飛刀的位置

好的,我們?nèi)语w刀的邏輯已經(jīng)完成了,接下來我們只需要遍歷每一個(gè)knifeGroup里面的子飛刀的位置,并在update更新函數(shù)里面更新他們的位置,游戲就算做完了.
在update函數(shù)里面添加:

update(){
    this.target.angle += gameOptions.rotateSpeed
    let children = this.knifeGroup.getChildren()
    for(var i=0;i< children.length;i++){
      let child = children[i]
      child.angle += gameOptions.rotateSpeed
      let ang = Phaser.Math.DegToRad(child.angle)
      child.x = this.target.x - Math.sin(ang) * this.target.width/4
      child.y = this.target.y + Math.cos(ang) * this.target.width/4
    }
  }

我們?cè)陲w刀移動(dòng)時(shí)計(jì)算每一步偏移的角度,從而判斷出子飛刀child的x,y位移.

我們的小游戲就做完了,完整代碼如下,順便做了下記分牌:




  
  
  
  Document
  


  


文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/95975.html

相關(guān)文章

  • [phaser3入門探坑]使用phaser3制作山寨馬里奧

    摘要:前言是一個(gè)優(yōu)秀的前端庫,封裝了很多底層的實(shí)現(xiàn),可以用來制作游戲,場(chǎng)景等。今年月新發(fā)布了,到今天為止已經(jīng)更新到了。聲明本游戲來自于小站的官方教程,加入了一些個(gè)人的注釋,本文旨在幫助各位觀眾老爺快速上手。 前言 phaser是一個(gè)優(yōu)秀的前端canvas庫,封裝了很多底層的實(shí)現(xiàn),可以用來制作游戲,h5場(chǎng)景等。今年1月新發(fā)布了phaser3,到今天為止已經(jīng)更新到了3.30。 聲明 本游戲來自于...

    szysky 評(píng)論0 收藏0
  • Phaser3游戲三角學(xué)應(yīng)用--一只跟隨屏幕點(diǎn)擊位置游動(dòng)的魚

    摘要:資源圖代碼中為初始化代碼三角函數(shù)得出魚要旋轉(zhuǎn)的角度判斷魚是否需要反轉(zhuǎn)點(diǎn)擊的位置和魚頭相同不反轉(zhuǎn)點(diǎn)擊的位置和魚頭相同不反轉(zhuǎn)判斷魚是否需要反轉(zhuǎn)點(diǎn)擊的位置和魚頭相反反轉(zhuǎn)點(diǎn)擊的位置和魚頭相反反轉(zhuǎn)讓魚移動(dòng)到點(diǎn)擊的位置更多游戲教學(xué)為游戲開發(fā) showImg(https://segmentfault.com/img/remote/1460000017023462); showImg(https://...

    wangbinke 評(píng)論0 收藏0
  • Phaser3游戲三角學(xué)應(yīng)用--一只跟隨屏幕點(diǎn)擊位置游動(dòng)的魚

    摘要:資源圖代碼中為初始化代碼三角函數(shù)得出魚要旋轉(zhuǎn)的角度判斷魚是否需要反轉(zhuǎn)點(diǎn)擊的位置和魚頭相同不反轉(zhuǎn)點(diǎn)擊的位置和魚頭相同不反轉(zhuǎn)判斷魚是否需要反轉(zhuǎn)點(diǎn)擊的位置和魚頭相反反轉(zhuǎn)點(diǎn)擊的位置和魚頭相反反轉(zhuǎn)讓魚移動(dòng)到點(diǎn)擊的位置更多游戲教學(xué)為游戲開發(fā) showImg(https://segmentfault.com/img/remote/1460000017023462); showImg(https://...

    CoderDock 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<