博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
微信小程序使用二次贝塞尔曲线画波浪
阅读量:6700 次
发布时间:2019-06-25

本文共 2203 字,大约阅读时间需要 7 分钟。

这两周做一个新的项目,人员比较紧张,除了需求和UI,前端后端一个人来干。

在项目需求确定后,UI隔了几天设计出了UI界面,拿到UI效果图后见有一个界面有波浪效果的我当时就蒙圈了,这都啥玩意啊?转念想到了最近在IT圈挺火的那个事件:产品要求安卓程序员实现根据用户手机壳颜色自动更换APP主题的需求后,顿时觉得画个波浪这个压根就不是事啊。

二次贝塞尔曲线

在微信官方的

画波浪

思路:

在屏幕左边画一个波,然后让它一直向屏幕右边平移过去。其X的值由负数变为正数依次增大;然后一直重复此操作。

我画出来的波浪如下(感觉还是有那么一点波浪的感觉):

界面代码为(index.wxml):

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) }})

以上就是本文的全部内容,希望对大家的学习有所帮助

转载地址:http://viwlo.baihongyu.com/

你可能感兴趣的文章
php课程 6-21 HTML标签相关函数
查看>>
Spring Boot的Tomcat 启动详解
查看>>
Elasticsearch 2.3.3 JAVA api说明文档
查看>>
zTree怎么判断树有节点展开或者完全关闭的
查看>>
如何删除一个标签,但是保留里面的内容?
查看>>
设计模式-行为型模式,python访问者模式
查看>>
命令模式
查看>>
如何自定义长连接策略
查看>>
平衡二叉树与自平衡二叉树(红黑树)的区别
查看>>
读取JPG图片的Exif属性(一) - Exif信息简介
查看>>
【译文】追求生产极简主义
查看>>
FTP服务器原理(转)
查看>>
精选30道Java笔试题解答
查看>>
特殊符号 UNICODE编码
查看>>
C#图解教程 第八章 表达式和运算符
查看>>
解决NavicatPremium导入CSV文件中文乱码的问题
查看>>
Python基础:语法基础(3)
查看>>
杭电2097
查看>>
Set default value for column[转]
查看>>
个人管理:从影片《横空出世》中学到...
查看>>