亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

微信小程序canvas開(kāi)發(fā)水果老虎機(jī)的思路詳解

 更新時(shí)間:2020年02月07日 11:40:39   作者:天天修改  
這篇文章主要介紹了微信小程序canvas開(kāi)發(fā)水果老虎機(jī)的思路,本文通過(guò)思路代碼分步驟給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

在這個(gè)超長(zhǎng)假期中,無(wú)聊。。。,所以動(dòng)手做一個(gè)早就計(jì)劃要做的小玩意, 水果老虎機(jī) ,嗯,這是一個(gè)小程序而不是小游戲...

 

使用結(jié)構(gòu)還是canvas?

使用模板結(jié)構(gòu)(view)生成水果盤(pán)的好處一是用戶可自定義產(chǎn)出 n x n 的定制化老虎機(jī),二是容易通過(guò)算法樣式生成布局,三是通過(guò) wx.selectQueryAll 的方法能夠很方便的抓到定位數(shù)據(jù)。但,問(wèn)題是動(dòng)畫(huà)性能過(guò)于孱弱,如圖構(gòu)建一個(gè) 7x7 的水果盤(pán),動(dòng)畫(huà)性能估計(jì)會(huì)慘不忍睹,而且純粹模板結(jié)構(gòu)無(wú)論使用 animation 動(dòng)畫(huà)方法還是 css 的keyframe的動(dòng)畫(huà)方法得到的動(dòng)畫(huà)效果都非常差(測(cè)試過(guò)的結(jié)論),還有是已知的動(dòng)畫(huà)方法可控性很差

使用canvas來(lái)生成水果盤(pán)好處是動(dòng)畫(huà)性能很好(canvas2d),但是定制性和擴(kuò)展性比較差

so綜上考慮,使用模板(view)布局,使用canvas來(lái)實(shí)現(xiàn)動(dòng)畫(huà)。既保證了組件的性能,同時(shí)定制型,擴(kuò)展性也很好

準(zhǔn)備計(jì)時(shí)器方法

動(dòng)畫(huà)的生成離不開(kāi)計(jì)時(shí)器方法,settimeout/setinterval這兩兄弟真的不夠看啊,問(wèn)題還多,做過(guò)web開(kāi)發(fā)的一定都知道 window.requestAnimationFrame ,這貨在小程序的計(jì)時(shí)器方法中不存在,好在 canvas2d 中可以使用 Canvas.requestAnimationFrame(function callback) 方法來(lái)實(shí)現(xiàn)

準(zhǔn)備運(yùn)動(dòng)算法

在水果老虎機(jī)中,激活狀態(tài)會(huì)沿著四方的水果盤(pán)做非線性運(yùn)動(dòng)(easeInOut比較好用),需要基礎(chǔ)的運(yùn)動(dòng)算法來(lái)計(jì)算實(shí)際的運(yùn)動(dòng)距離。在 animation 動(dòng)畫(huà)方法中,我們可以使用 ease-in/ease-out 等緩動(dòng)算法來(lái)實(shí)現(xiàn)動(dòng)畫(huà)效果,但在這里必須要借助 tween.js 中的緩動(dòng)算法來(lái)實(shí)現(xiàn)運(yùn)動(dòng)效果(因?yàn)樾枰刂七\(yùn)動(dòng)節(jié)點(diǎn))。

你會(huì)不會(huì)想到用css的keyframe動(dòng)畫(huà)來(lái)做這個(gè)運(yùn)動(dòng)效果,經(jīng)過(guò)我的測(cè)試,css的動(dòng)畫(huà)和animation的動(dòng)畫(huà)會(huì)在每一條邊上實(shí)現(xiàn)一次(ease)緩動(dòng)運(yùn)動(dòng)(很奇怪的效果)

推薦這篇文章

使用其中一個(gè),節(jié)省代碼量

/*
 * Tween.js
 * t: current time(當(dāng)前時(shí)間);
 * b: beginning value(初始值);
 * c: change in value(變化量);
 * d: duration(持續(xù)時(shí)間)。
 */
// Quart 四次方的緩動(dòng)
const easeInOutQuart = function (t, b, c, d) {
 if ((t /= d / 2) < 1) return c / 2 * t * t * t * t + b;
 return -c / 2 * ((t -= 2) * t * t * t - 2) + b;
}

tween算法是以時(shí)間為基準(zhǔn)(時(shí)間比率 = 距離比率)來(lái)計(jì)算單位時(shí)間的實(shí)際運(yùn)動(dòng)距離

布局

以上面的圖為例,我們需要做一個(gè) 7 x 7 的水果盤(pán),實(shí)際有效的獎(jiǎng)品格子數(shù)為 7*4-4 共24個(gè)有效格子

有效格子算法

js

// 0-6 第一行所有格子全部有效 
// 21-27 最后一行所有格子全部有效 
// 中間部分 i%7===0 和 i%7 === (7-1) 有效
// 算法源碼有點(diǎn)無(wú)聊,依據(jù)上述思路,即可遍歷28個(gè)格子并標(biāo)識(shí)獎(jiǎng)品格子valide=true
// 可以擴(kuò)展想一想 6x6 5x5,思路是一樣的

wxml

<view class="fruits-container" >
  <view class="fruits-table" >
    <block wx:for="{{ary}}" wx:key="index" >
      <view wx:if="{{item.valide}}" class="valide">{{item.title}}</view>
      <view wx:else class="in-valide"></view>
    </block>
  </view>
  <canvas type="2d" .... />
</view>

樣式

只節(jié)選關(guān)鍵樣式,目的是讓canvas覆蓋在水果盤(pán)上,長(zhǎng)寬一致

.fruits-container {
  position: relative;
  width: 400px;
  height: 400px;
  ...
}

.fruits-table {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  ...
}

抓取位置信息

canvas的繪制需要X軸, Y軸的精確信息,可以使用 wx.createSelectorQuery 方式抓取類名為‘valide'的 view (獎(jiǎng)品格子)的位置信息

let query = wx.createSelectorQuery().in(this)
query.selectAll(`.fruits-table .valide`).boundingClientRect(ret => {
  ....
  console.log(ret[0]) // top, left, right, bottom, width, height
  console.log(ret[1]) // top, left, right, bottom, width, height
  ...
  ...
  console.log(ret[23]) // top, left, right, bottom, width, height
})

得到每一個(gè)獎(jiǎng)品格子的位置信息后,就可以使用canvas的 fillRect 方法來(lái)繪制激活狀態(tài)了。

繪制一個(gè)激活狀態(tài)

let query = wx.createSelectorQuery().in(this)
query.selectAll(`.fruits-table .valide`).boundingClientRect(ret => {
  ....
  let {top, left, right, bottom, width, height} = ret[0]
  const canvasQuery = wx.createSelectorQuery()
  canvasQuery.select('#fruit-canvas')
  .fields({ node: true, size: true })
  .exec((res) => {
    const canvas = res[0].node
    const ctx = canvas.getContext('2d') 
    let x = top
    let y = left
    let dx = width
    let dy = height
    ctx.shadowOffsetX = 2
    ctx.shadowOffsetY = -2
    ctx.shadowColor = 'red'
    ctx.shadowBlur = 50
    ctx.lineWidth = 5
    ctx.strokeStyle = 'red'
    ctx.clearRect(0, 0, canvas.width, canvas.height)
    ctx.strokeRect(x, y, dx, dy)
  })
})

跑起來(lái)

已經(jīng)繪制了一個(gè)激活狀態(tài),接下來(lái)使它能夠簡(jiǎn)單動(dòng)起來(lái)

// 抽象激活方法 
functon rect(point, canvas){
  let {x, y, dx, dy} = getPosition(point)
  ctx.shadowOffsetX = 2
  ctx.shadowOffsetY = -2
  ...
  ...
  ctx.clearRect(0, 0, canvas.width, canvas.height) // 擦除整個(gè)水果盤(pán)
  ctx.strokeRect(x, y, dx, dy) // 繪制激活區(qū)域
}

function run(){
  setTimeout(()=>{
    if (ret.length) {
      let point = ret.shift()
      rect(point, canvas)
      run()
    }
  }, 100)
}

執(zhí)行run方法后可以看到水果盤(pán)的激活狀態(tài)一步一步的往前走(100毫秒),拖拉機(jī)終于可以啟動(dòng)了

配上運(yùn)動(dòng)算法

經(jīng)過(guò)上面的試驗(yàn)我們終于可以看到基本的運(yùn)動(dòng)效果了,接下來(lái)配上運(yùn)動(dòng)算法和計(jì)時(shí)器方法

// Quart 四次方的緩動(dòng)
const easeInOutQuart = function (t, b, c, d) {
 if ((t /= d / 2) < 1) return c / 2 * t * t * t * t + b;
 return -c / 2 * ((t -= 2) * t * t * t - 2) + b;
}

let start = 0 // 開(kāi)始時(shí)間
let begin = 0 // 開(kāi)始獎(jiǎng)品位置
let end = 23 // 終點(diǎn)位置,這里跑一圈
let during = 5000 // 運(yùn)動(dòng)總時(shí)間

// 1000/60 ≈ 17,
// 17毫秒即表示屏幕60幀刷新率每秒 ≈ requestAnimationFrame計(jì)數(shù)頻率(一般情況) 
const steper = () => {
 // left為位移距離
 // 老虎機(jī)的運(yùn)動(dòng)位移是節(jié)點(diǎn)位移,不是精確位移
 // 所以這里用parseInt處理,只取整數(shù)部分
 // 數(shù)據(jù)變化為 0,1,2,3,4,5...23
 // 間隔時(shí)間/距離由easeInOutQuart算法計(jì)算
 var left = easeInOutQuart(start, begin, end, during);
 let idx = parseInt(left)
 start = start + 17; 
 if (idx <= end) {
  let point = this.ret[idx] // 取節(jié)點(diǎn)位置信息
  this.rect(point) // 繪制
 }
 // 時(shí)間遞增
 if (start <= during) {
  this.ctx.requestAnimationFrame(steper); // 計(jì)時(shí)器
 } else {
  // 動(dòng)畫(huà)結(jié)束,這里可以插入回調(diào)...
  // callback()...
 }
};
steper(); // 啟動(dòng)

總結(jié)

以上所述是小編給大家介紹的微信小程序canvas開(kāi)發(fā)水果老虎機(jī)的思路詳解,希望對(duì)大家有所幫助!

相關(guān)文章

  • js如何修改對(duì)象數(shù)組的key值

    js如何修改對(duì)象數(shù)組的key值

    這篇文章主要介紹了js如何修改對(duì)象數(shù)組的key值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • [JS]實(shí)現(xiàn)動(dòng)態(tài)增加框架!未完成

    [JS]實(shí)現(xiàn)動(dòng)態(tài)增加框架!未完成

    [JS]實(shí)現(xiàn)動(dòng)態(tài)增加框架!未完成...
    2007-03-03
  • 為數(shù)據(jù)添加append,remove功能

    為數(shù)據(jù)添加append,remove功能

    為數(shù)據(jù)添加append,remove功能...
    2006-10-10
  • 淺談js中的延遲執(zhí)行和定時(shí)執(zhí)行

    淺談js中的延遲執(zhí)行和定時(shí)執(zhí)行

    下面小編就為大家?guī)?lái)一篇淺談js中的延遲執(zhí)行和定時(shí)執(zhí)行。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-05-05
  • OpenLayers3實(shí)現(xiàn)鼠標(biāo)移動(dòng)顯示坐標(biāo)

    OpenLayers3實(shí)現(xiàn)鼠標(biāo)移動(dòng)顯示坐標(biāo)

    這篇文章主要為大家詳細(xì)介紹了OpenLayers3實(shí)現(xiàn)鼠標(biāo)移動(dòng)顯示坐標(biāo),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • JQuery 前臺(tái)切換網(wǎng)站的樣式實(shí)現(xiàn)

    JQuery 前臺(tái)切換網(wǎng)站的樣式實(shí)現(xiàn)

    本文說(shuō)的是在WordPress中怎樣利用JQuery在網(wǎng)站的前臺(tái)切換樣式的方法?;蛘哌@篇文章的方法大家可能不是太需要,因?yàn)槲矣X(jué)得這是解決我被主題樣式折騰到差不多分裂的原因及結(jié)果的最后手段。
    2009-06-06
  • JavaScript ES6中類與模塊化管理超詳細(xì)講解

    JavaScript ES6中類與模塊化管理超詳細(xì)講解

    JavaScript中的模塊化是指將每個(gè)js文件會(huì)被認(rèn)為單獨(dú)一個(gè)的模塊。模塊之間是互相不可見(jiàn)的。如果一個(gè)模塊需要使用另一個(gè)模塊,那么需要通過(guò)指定語(yǔ)法來(lái)引入要使用的模塊,而且只能使用引入模塊所暴露的內(nèi)容
    2023-01-01
  • 教你用幾十行js實(shí)現(xiàn)很炫的canvas交互特效

    教你用幾十行js實(shí)現(xiàn)很炫的canvas交互特效

    HTML5中的大部分動(dòng)畫(huà)都是通過(guò)Canvas實(shí)現(xiàn),因?yàn)镃anvas就像一塊畫(huà)布,我們可以通過(guò)調(diào)用腳本在Canvas上繪制任意形狀,甚至是制作動(dòng)畫(huà),這篇文章主要給大家介紹了關(guān)于用幾十行js實(shí)現(xiàn)很炫的canvas交互特效的相關(guān)資料,需要的朋友可以參考下
    2021-11-11
  • JS分頁(yè)效果示例

    JS分頁(yè)效果示例

    JS實(shí)現(xiàn)分頁(yè)在網(wǎng)上可以搜到很多的相關(guān)文章,在本文也要為大家介紹下具體的實(shí)現(xiàn),感興趣的朋友不要錯(cuò)過(guò)
    2013-10-10
  • JS將制定內(nèi)容復(fù)制到剪切板示例代碼

    JS將制定內(nèi)容復(fù)制到剪切板示例代碼

    這篇文章主要介紹了JS將制定內(nèi)容復(fù)制到剪切板的方法,需要的朋友可以參考下
    2014-02-02

最新評(píng)論