微信小程序开发:如何用二次贝塞尔曲线画波浪
两周后接新项目,人员比较紧张。除了需求和用户界面之外,前后台各有一个人负责。
确定项目需求后,几天之内就设计出了用户界面。收到UI效果图后,我看到其中一个界面有波浪效果。我当时很困惑。这是什么?然后我想到了最近IT界很流行的一个案例:产品要求Android根据用户手机壳的颜色自动更换APP主题后,我突然觉得拉一波根本不是问题。 。 † 一直平移到屏幕右侧。
我绘制的波浪的值如下(感觉还是波浪):
![]()
接口代码为(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)
}
}) 版权声明
本文仅代表作者观点,不代表Code前端网立场。
本文系作者Code前端网发表,如需转载,请注明页面地址。
上一篇:微信新功能:如何开附近餐厅 下一篇:小组件与公众号联动流量引流:10大好处加起来
code前端网




发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。