微信小程序使用二次贝塞尔曲线画波浪


Posted in Javascript onDecember 25, 2018

这两周做一个新的项目,人员比较紧张,除了需求和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)
 }
})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js+FSO遍历文件夹下文件并显示
Mar 07 Javascript
javascript最常用与实用的创建类的代码
Aug 12 Javascript
Jquery实现显示和隐藏的4种简单方式
Aug 28 Javascript
Js实现网页键盘控制翻页的方法
Oct 30 Javascript
JS基于myFocus库实现各种功能的tab选项卡切换效果
Sep 19 Javascript
三种AngularJS中获取数据源的方式
Feb 02 Javascript
Ajax使用原生态JS验证用户名是否存在
May 26 Javascript
select下拉框插件jquery.editable-select详解
Jan 22 Javascript
COM组件中调用JavaScript函数详解及实例
Feb 23 Javascript
react-native 完整实现登录功能的示例代码
Sep 11 Javascript
React/Redux应用使用Async/Await的方法
Nov 16 Javascript
Layui表格行工具事件与数据回填方法
Sep 13 Javascript
微信小程序开发问题之wx.previewImage
Dec 25 #Javascript
微信小程序使用for循环动态渲染页面操作示例
Dec 25 #Javascript
JavaScript简单实现动态改变HTML内容的方法示例
Dec 25 #Javascript
使用gulp构建前端自动化的方法示例
Dec 25 #Javascript
JavaScript实现的级联算法示例【省市二级联动功能】
Dec 25 #Javascript
详解vuex commit保存数据技巧
Dec 25 #Javascript
bootstrap table实现合并单元格效果
Dec 24 #Javascript
You might like
PHP 配置文件中open_basedir选项作用
2009/07/19 PHP
DedeCMS dede_channeltype表字段注释
2010/04/07 PHP
PHP imagecreatefrombmp 从BMP文件或URL新建一图像
2012/07/16 PHP
php基础教程 php内置函数实例教程
2012/08/21 PHP
将php数组输出html表格的方法
2014/02/24 PHP
配置eAccelerator和XCache扩展来加速PHP程序的执行
2015/12/22 PHP
PHP入门教程之面向对象基本概念实例分析
2016/09/11 PHP
PHP实现字母数字混合验证码功能
2019/07/11 PHP
javascript  Error 对象 错误处理
2008/05/18 Javascript
DOM下的节点属性和操作小结
2009/05/14 Javascript
在IE和VB中支持png图片透明效果的实现方法(vb源码打包)
2011/04/01 Javascript
jquery高级编程的最佳实践详解
2014/03/23 Javascript
删除条目时弹出的确认对话框
2014/06/05 Javascript
js 实现的可折叠留言板(附源码下载)
2014/07/01 Javascript
js读取cookie方法总结
2014/10/31 Javascript
如何用javascript计算文本框还能输入多少个字符
2015/07/29 Javascript
javascript中sort排序实例详解
2016/07/24 Javascript
详解如何在angular2中获取节点
2017/11/23 Javascript
Node Puppeteer图像识别实现百度指数爬虫的示例
2018/02/22 Javascript
Vue中的验证登录状态的实现方法
2019/03/09 Javascript
微信小程序如何使用globalData的方法
2019/06/06 Javascript
Vue.js标签页组件使用方法详解
2019/10/19 Javascript
vue 扩展现有组件的操作
2020/08/14 Javascript
Python3安装psycopy2以及遇到问题解决方法
2019/07/03 Python
Python面向对象之Web静态服务器
2019/09/03 Python
Python3.7基于hashlib和Crypto实现加签验签功能(实例代码)
2019/12/04 Python
Django之form组件自动校验数据实现
2020/01/14 Python
pycharm运行程序时看不到任何结果显示的解决
2020/02/21 Python
利用Python如何制作贪吃蛇及AI版贪吃蛇详解
2020/08/24 Python
python实现杨辉三角的几种方法代码实例
2021/03/02 Python
解决img标签上下出现间隙的方法
2016/12/14 HTML / CSS
求职简历自荐信范文
2013/10/21 职场文书
人力资源专业推荐信
2013/11/29 职场文书
身份证丢失证明
2015/06/19 职场文书
致三级跳运动员加油稿
2015/07/21 职场文书
读《庄子》有感:美而不自知
2019/11/06 职场文书