麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 課堂 > 小程序 > 正文

微信小程序使用二次貝塞爾曲線畫波浪

2020-03-21 16:04:17
字體:
來源:轉載
供稿:網友

這兩周做一個新的項目,人員比較緊張,除了需求和UI,前端后端一個人來干。

在項目需求確定后,UI隔了幾天設計出了UI界面,拿到UI效果圖后見有一個界面有波浪效果的我當時就蒙圈了,這都啥玩意???轉念想到了最近在IT圈挺火的那個事件:產品要求安卓程序員實現根據用戶手機殼顏色自動更換APP主題的需求后,頓時覺得畫個波浪這個壓根就不是事啊。

二次貝塞爾曲線

在微信官方的二次貝塞爾曲線畫法連接

畫波浪

思路:

在屏幕左邊畫一個波,然后讓它一直向屏幕右邊平移過去。其X的值由負數變為正數依次增大;然后一直重復此操作。

我畫出來的波浪如下(感覺還是有那么一點波浪的感覺):

微信小程序,貝塞爾曲線,波浪

界面代碼為(index.wxml):

<view class="page-body"> <view class="page-body-wrapper">  <canvas canvas-id="myCanvas3" class="canvas3"></canvas> </view></view>

JS代碼為(index.js):

Page({ onReady: function() {  this.position = {    x: 150,    y: 150,    vx: 2,    vy: 2   },   this.obj = {    offset: 0,    baseLine: 40,    direction: 1,    waveDirection: 1   },   // var offset = 5   this.drawQuadraticCurve3()  this.interval = setInterval(this.drawQuadraticCurve3, 1)  console.log(">>>>>>>>>" + this.obj.offset) }, /**  * 畫大波浪  */ drawQuadraticCurve3: function() {  var obj = this.obj  var startX = 20,   itemWidth = 100,   offset = obj.offset,   baseLine = obj.baseLine,   waveHeight = 10,   direction = obj.direction,   waveDirection = obj.waveDirection   const ctx = wx.createCanvasContext('myCanvas3')    function getWaveHeigh(i) {   if (i % 2 == 0) {    // return baseLine + waveHeight   }   return baseLine - waveHeight  }  ctx.beginPath()  ctx.moveTo(-itemWidth * 6, baseLine)  ctx.setFillStyle('#4BF6EE')  for (var i = -6; i < 5; i++) {   startX = i * itemWidth;   var currentX = startX + (itemWidth / 2) + offset   var currentY = getWaveHeigh(i)   var currentEndX = startX + itemWidth + offset   ctx.quadraticCurveTo(currentEndX - 10,    currentY, currentEndX, baseLine)   ctx.stroke()  }  //填充海水  ctx.lineTo(0, 2000)  ctx.setFillStyle('#4BF6EE')  ctx.fill()   ctx.draw()    if (obj.waveDirection == 1) {   obj.offset = obj.offset + 1  } else if (obj.waveDirection == -1) {   obj.offset = obj.offset - 1  }  if (obj.offset == 400) {   obj.offset = 0  }  if (obj.offset == 50 || obj.offset == 1) {   // obj.waveDirection = obj.waveDirection * -1  }    // if (direction == 1) {  //  obj.baseLine = obj.baseLine + 1  // } else if (direction == -1) {  //  obj.baseLine = obj.baseLine - 1  // }  if (obj.baseLine >= 50 || obj.baseLine <= 40) {   console.log("<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<")   //obj.direction = (obj.direction * -1)  } }, onUnload: function() {  clearInterval(this.interval) }})

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲一区二区免费视频 | 成人午夜视频免费在线观看 | 少妇色诱麻豆色哟哟 | 日韩欧美视频一区二区三区 | 成年人黄色免费网站 | 国产美女三级做爰 | 狠狠久久伊人中文字幕 | av电影在线免费 | 日韩av片网站 | 一级大黄毛片免费观看 | 免费观看三级毛片 | 午夜视频在线免费观看 | 亚洲视频观看 | 国产一及毛片 | 欧美性受xxxxxx黑人xyx性爽 | 欧美一级成人一区二区三区 | 久久免费视频精品 | 天天干导航 | 五月天堂av91久久久 | 成人艳情一二三区 | 久久激情小视频 | 91成人免费| 亚洲自拍第一 | 国产成人精品一区在线播放 | 日本一级黄色大片 | 欧美精品久久久久久久久久 | 亚洲精品成人在线视频 | 国产精品自拍av | 一级黄色免费观看 | 国产精品久久久久影院老司 | 蜜桃视频在线播放 | 在线a免费观看 | 特级黄aaaaaaaaa毛片 | 日韩在线毛片 | 国产一国产一级毛片视频在线 | 久青草免费视频 | 欧美成人高清视频 | 国产精品成人免费一区久久羞羞 | 国产精选91| 免费久久久 | 色婷婷久久久亚洲一区二区三区 |