这两个星期做了一个新项目,工作人员比较紧张,除了需求和UI,前端和后端一个人要做。
确定项目要求后,UI设计了几天相隔的UI界面。当我得到UI效果图时,我看到有一个波形效果的界面。刚才那是干什么啊?想想IT界最近的热门事件:Android程序员需要根据用户手机外壳的颜色自动更改APP的主题,并立即觉得绘制波浪根本不是问题。
二次贝塞尔曲线
关于微信官方第二贝塞尔曲线图的连接
画波浪
思路:
在屏幕左侧绘制一个波形并将其直接移动到屏幕右侧。X的值依次从负值增加到正值; 这个操作一直在重复。
我画的波浪如下。
接口代码是(index.wxml):
<view>
<view>
<canvas canvas-id="myCanvas3"></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)
},
/**
* Draw big waves
*/
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()
}
// Filling seawater
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)
}
})
以上是
南京小程序开发今天写的全部内容。我希望它对每个人的学习都有所帮助。
本文地址:
http://www.njanyou.cn/web/2567.html
Tag:
专业服务:
南京网站制作,
南京网站制作公司,
南京网站建设公司
联系电话:025-65016872
上一篇:
南京网站制作提示2019年推动内容营销的博客
下一篇:
网站建设:内容营销是否乱扔垃圾?