JS绘制微信小程序画布时钟


Posted in Javascript onDecember 24, 2016

微信小程序官方组件也提供了画布功能,下面分享一下如何创建微信小程序画布时钟。

总体思路是对pages中的一个小程序页面构建画布时钟逻辑程序,通过app.json公共设置来配置入口。

首先来看一下构建这样一个小程序所需要的目录结构

JS绘制微信小程序画布时钟

从目录结构就可以看出来这个程序是简单的单层页面,画布渲染在pages下面的index页面上。

其中对程序有实际驱动作用的代码分别在index.js,index.wxml,index.wxss和app.json这几个文件中

Index.js文件里面存放着程序的逻辑层数据,是程序的核心。

1)考虑到适应不同的手机大小,定义了两个变量width和height,当页面加载时(onLoad)获取系统窗口的值作为index页面的大小;

2)页面初次渲染后给index添加时钟函数canvasClock(),并设置定时器,每一秒刷新一次画布,呈现出时钟运动的效果

3)在时钟函数canvasClock()中进行绘制时钟页面所需的元素以其其运动函数,并对其进行调用drawClock(),通过调用小程序wx.drawCanvas方法来指定index为绘制页面和绘制行为

4)当程序退出时,清除计时器

代码如下:

// 获取应用实例 
Page({ 
 data:{ 
  width:0, 
  height:0 
 }, 
 //onLoad生命周期函数,监听页面加载 
 onLoad: function(){ 
  //将全局变量Index保存在that中,里面函数调用 
  var that = this 
  //获取系统信息 
  wx.getSystemInfo({ 
   //获取系统信息成功,将系统窗口的宽高赋给页面的宽高 
   success: function(res) { 
    that.width = res.windowWidth 
    that.height = res.windowHeight 
   } 
  }) 
 }, 
 //onReady生命周期函数,监听页面初次渲染完成 
 onReady: function(){ 
  //调用canvasClock函数 
  this.canvasClock() 
  //对canvasClock函数循环调用 
  this.interval = setInterval(this.canvasClock,1000) 
 }, 
 canvasClock: function(){ 
  var context = wx.createContext()//创建并返回绘图上下文(获取画笔) 
  //设置宽高 
  var width = this.width 
  var height = this.height 
  var R = width/2-55;//设置文字距离时钟中心点距离 
  //重置画布函数 
  function reSet(){ 
   context.height = context.height;//每次清除画布,然后变化后的时间补上 
   context.translate(width/2, height/2);//设置坐标轴原点 
   context.save();//保存中点坐标1 
  } 
  //绘制中心圆和外面大圆 
  function circle(){ 
   //外面大圆 
   context.setLineWidth(2); 
   context.beginPath(); 
   context.arc(0, 0, width/2-30, 0, 2 * Math.PI,true); 
   context.closePath(); 
   context.stroke(); 
   //中心圆 
   context.beginPath(); 
   context.arc(0, 0, 8, 0, 2 * Math.PI, true); 
   context.closePath(); 
   context.stroke(); 
  } 
  //绘制字体 
  function num(){ 
   // var R = width/2-60;//设置文字距离时钟中心点距离 
   context.setFontSize(20)//设置字体样式 
   context.textBaseline = "middle";//字体上下居中,绘制时间 
   for(var i = 1; i < 13; i++) { 
    //利用三角函数计算字体坐标表达式 
    var x = R * Math.cos(i * Math.PI / 6 - Math.PI / 2); 
    var y = R * Math.sin(i * Math.PI / 6 - Math.PI / 2); 
    if(i==11||i==12){//调整数字11和12的位置 
     context.fillText(i, x-12, y+9); 
    }else { 
     context.fillText(i, x-6, y+9); 
    } 
   } 
  } 
  //绘制小格 
  function smallGrid(){ 
    context.setLineWidth(1); 
    context.rotate(-Math.PI/2);//时间从3点开始,倒转90度 
    for(var i = 0; i < 60; i++) { 
     context.beginPath(); 
     context.rotate(Math.PI / 30); 
     context.moveTo(width/2-30, 0); 
     context.lineTo(width/2-40, 0); 
     context.stroke(); 
    } 
   } 
   //绘制大格 
   function bigGrid(){ 
   context.setLineWidth(5); 
   for(var i = 0; i < 12; i++) { 
    context.beginPath(); 
    context.rotate(Math.PI / 6); 
    context.moveTo(width/2-30, 0); 
    context.lineTo(width/2-45, 0); 
    context.stroke(); 
   } 
   } 
   //指针运动函数 
  function move(){ 
   var t = new Date();//获取当前时间 
   var h = t.getHours();//获取小时 
   h = h>12?(h-12):h;//将24小时制转化为12小时制 
   var m = t.getMinutes();//获取分针 
   var s = t.getSeconds();//获取秒针 
   context.save();//再次保存2 
   context.setLineWidth(7); 
   //旋转角度=30度*(h+m/60+s/3600) 
   //分针旋转角度=6度*(m+s/60) 
   //秒针旋转角度=6度*s 
   context.beginPath(); 
   //绘制时针 
   context.rotate((Math.PI/6)*(h+m/60+s/3600)); 
   context.moveTo(-20,0); 
   context.lineTo(width/4.5-20,0); 
   context.stroke(); 
   context.restore();//恢复到2,(最初未旋转状态)避免旋转叠加 
   context.save();//3 
   //画分针 
   context.setLineWidth(5); 
   context.beginPath(); 
   context.rotate((Math.PI/30)*(m+s/60)); 
   context.moveTo(-20,0); 
   context.lineTo(width/3.5-20,0); 
   context.stroke(); 
   context.restore();//恢复到3,(最初未旋转状态)避免旋转叠加 
   context.save(); 
   //绘制秒针 
   context.setLineWidth(2); 
   context.beginPath(); 
   context.rotate((Math.PI/30)*s); 
   context.moveTo(-20,0); 
   context.lineTo(width/3-20,0); 
   context.stroke(); 
  } 
  //调用 
  function drawClock(){ 
   reSet(); 
   circle(); 
   num(); 
   smallGrid(); 
   bigGrid(); 
   move(); 
  } 
  drawClock()//调用运动函数 
  // 调用 wx.drawCanvas,通过 canvasId 指定在哪张画布上绘制,通过 actions 指定绘制行为 
  wx.drawCanvas({ 
   canvasId:'myCanvas', 
   actions: context.getActions() 
  }) 
 }, 
 //页面卸载,清除画布绘制计时器 
 onUnload:function(){ 
  clearInterval(this.interval) 
 } 
})

index.wxml中存放着canvas标签,并通过canvas-id和class指定了组件标识符和样式选择器

<canvas canvas-id="myCanvas" class="canvas"></canvas>

index.wxss设置画布样式

.canvas{ 
 width: 100%; 
 height: 100%; 
 position: fixed; 
}

app.json文件设置了页面路径和窗口表现

{ 
 "pages": [ 
  "pages/index" 
 ], 
 "window": { 
 "navigationBarTextStyle": "light", 
 "navigationBarTitleText": "画布时钟", 
 "navigationBarBackgroundColor": "#000", 
 "backgroundColor": "#fbf9fe" 
 } 
}

这样,整个微信小程序画布时钟就简单的创建完成,看一下效果

JS绘制微信小程序画布时钟

guthub下载地址:https://github.com/RidingACodeToStray/weCanvasClock.Git

以上所述是小编给大家介绍的JS绘制微信小程序画布时钟,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
读jQuery之九 一些瑕疵说明
Jun 21 Javascript
jQuery动态创建元素以及追加节点的实现方法
Oct 20 Javascript
jstree单选功能的实现方法
Jun 07 Javascript
JS数组交集、并集、差集的示例代码
Aug 23 Javascript
JS实现颜色的10进制转化成rgba格式的方法
Sep 04 Javascript
React Native中TabBarIOS的简单使用方法示例
Oct 13 Javascript
JavaScript内存泄漏的处理方式
Nov 20 Javascript
在vue中,v-for的索引index在html中的使用方法
Mar 06 Javascript
Angular实现模版驱动表单的自定义校验功能(密码确认为例)
May 17 Javascript
微信小程序用户信息encryptedData详解
Aug 24 Javascript
IntelliJ IDEA编辑器配置vue高亮显示
Sep 26 Javascript
利用JavaScript模拟京东按键输入功能
Dec 01 Javascript
jQuery弹出窗口打开链接的实现代码
Dec 24 #Javascript
DropDownList控件绑定数据源的三种方法
Dec 24 #Javascript
Bootstrap源码学习笔记之bootstrap进度条
Dec 24 #Javascript
js addDqmForPP给标签内属性值加上双引号的函数
Dec 24 #Javascript
Bootstrap php制作动态分页标签
Dec 23 #Javascript
前端JS面试中常见的算法问题总结
Dec 23 #Javascript
Bootstrap源码解读导航条(7)
Dec 23 #Javascript
You might like
PHP 动态随机生成验证码类代码
2010/04/09 PHP
PHP sprintf() 函数的应用(定义和用法)
2012/06/29 PHP
php使用正则验证中文
2016/04/06 PHP
php rmdir使用递归函数删除非空目录实例详解
2016/10/20 PHP
laravel 解决Validator使用中出现的问题
2019/10/25 PHP
Thinkphp 框架扩展之类库扩展操作详解
2020/04/23 PHP
高性能Javascript笔记 数据的存储与访问性能优化
2012/08/02 Javascript
Jqgrid设置全选(选择)及获取选择行的值示例代码
2013/12/28 Javascript
javascritp添加url参数将参数加入到url中
2014/09/25 Javascript
node.js中的http.response.removeHeader方法使用说明
2014/12/14 Javascript
javascript实现控制文字大中小显示
2015/04/28 Javascript
jQuery实现textarea自动增长宽高的方法
2015/12/18 Javascript
jQuery实现区域打印功能代码详解
2016/06/17 Javascript
jQuery解决$符号命名冲突
2016/06/18 Javascript
vue-hook-form使用详解
2017/04/07 Javascript
详解前后端分离之VueJS前端
2017/05/24 Javascript
微信小程序获取手机号授权用户登录功能
2017/11/09 Javascript
微信小程序实现无限滚动列表
2020/05/29 Javascript
js实现网页同时进行多个倒计时功能
2019/02/25 Javascript
使用Vue生成动态表单
2019/11/26 Javascript
原生js实现瀑布流效果
2020/03/09 Javascript
JS实现鼠标按下拖拽效果
2020/07/23 Javascript
vue内置组件keep-alive事件动态缓存实例
2020/10/30 Javascript
[01:27]DOTA2电竞之夜 今夜共饮庆功酒
2014/08/02 DOTA
Pyramid Mako模板引入helper对象的步骤方法
2013/11/27 Python
python执行精确的小数计算方法
2019/01/21 Python
Jupyter Notebook输出矢量图实例
2020/04/14 Python
详解tensorflow之过拟合问题实战
2020/11/01 Python
python 实现aes256加密
2020/11/27 Python
美国最大的袜子制造商和零售商:Renfro Socks
2017/09/03 全球购物
Abbacino官网:包、钱包和女士配饰
2019/04/15 全球购物
公司踏青活动方案
2014/08/16 职场文书
四风问题个人自查剖析材料思想汇报
2014/09/21 职场文书
介绍信范文
2015/01/31 职场文书
2015年行政部工作总结
2015/04/28 职场文书
详解使用 CSS prefers-* 规范提升网站的可访问性与健壮性
2021/05/25 HTML / CSS