微信小程序 wxapp画布 canvas详细介绍


Posted in Javascript onOctober 31, 2016

微信小程序 wxapp画布 canvas :最近学习微信小程序的知识,这里记录下小程序 waxpp画布canvas 的知识:

canvas

属性名 类型 默认值 说明
hidden Boolean false 设置画布的显示/隐藏,hidden值为true表示隐藏,值为false表示显示
canvas-id String   canvas组件的唯一标识符
binderror EventHandle   当发生错误时触发error事件,detail = { errMsg: 'something wrong' }

注:

1.canvas标签默认宽度300px、高度225px

2.同一页面中的canvas-id不可重复,如果使用一个已经出现过的canvas-id,该canvas标签对应的画布将被隐藏并不再正常工作

示例代码:下载

<!-- canvas.wxml -->
<canvas style="width: 300px; height: 200px;" canvas-id="firstCanvas"></canvas>
<!-- 当使用绝对定位时,文档流后边的canvas的显示层级高于前边的canvas-->
<canvas style="width: 400px; height: 500px;" canvas-id="secondCanvas"></canvas>
<!-- 因为canvas-id与前一个canvas重复,该canvas不会显示,并会发送一个错误事件到AppService -->
<canvas style="width: 400px; height: 500px;" canvas-id="secondCanvas" binderror="canvasIdErrorCallback"></canvas>
// canvas.js
Page({
 canvasIdErrorCallback: function (e) {
  console.error(e.detail.errMsg);
 },
 onReady: function (e) {

  //使用wx.createContext获取绘图上下文context
  var context = wx.createContext();

  context.setStrokeStyle("#00ff00");
  context.setLineWidth(5);
  context.rect(0,0,200,200);
  context.stroke()
  context.setStrokeStyle ("#ff0000") ;
  context.setLineWidth (2)
  context.moveTo(160,100)
  context.arc(100,100,60,0,2*Math.PI,true);
  context.moveTo(140,100);
  context.arc(100,100,40,0,Math.PI,false);
  context.moveTo(85,80);
  context.arc(80,80,5,0,2*Math.PI,true);
  context.moveTo(125,80);
  context.arc(120,80,5,0,2*Math.PI,true);
  context.stroke();

  //调用wx.drawCanvas,通过canvasId指定在哪张画布上绘制,通过actions指定绘制行为
  wx.drawCanvas({
   canvasId: 'firstCanvas',
   actions: context.getActions() //获取绘图动作数组
  });
 }
});

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
浅谈document.write()输出样式
May 07 Javascript
微信js-sdk上传与下载图片接口用法示例
Oct 12 Javascript
node.js学习之base64编码解码
Oct 21 Javascript
一个炫酷的Bootstrap导航菜单
Dec 28 Javascript
详解使用fetch发送post请求时的参数处理
Apr 05 Javascript
微信小程序后台解密用户数据实例详解
Jun 28 Javascript
vue+jquery+lodash实现滑动时顶部悬浮固定效果
Apr 28 jQuery
详解Angular中实现自定义组件的双向绑定的两种方法
Nov 23 Javascript
使用Three.js实现太阳系八大行星的自转公转示例代码
Apr 09 Javascript
vue路由守卫+登录态管理实例分析
May 21 Javascript
Element Tooltip 文字提示的使用示例
Jul 26 Javascript
javascript实现拼图游戏
Jan 29 Javascript
微信小程序 wxapp视图容器 view详解
Oct 31 #Javascript
详解JavaScript跨域总结与解决办法
Oct 31 #Javascript
JS中用三种方式实现导航菜单中的二级下拉菜单
Oct 31 #Javascript
微信小程序 获取微信OpenId详解及实例代码
Oct 31 #Javascript
JavaScript事件用法浅析
Oct 31 #Javascript
js中通过getElementsByName访问name集合对象的方法
Oct 31 #Javascript
JavaScript递归操作实例浅析
Oct 31 #Javascript
You might like
无线电的诞生过程
2021/03/01 无线电
PHP配置把错误日志以邮件方式发送方法(Windows系统)
2015/06/23 PHP
php生成4位数字验证码的实现代码
2015/11/23 PHP
PHP Cookie学习笔记
2016/08/23 PHP
PHP设计模式之工厂模式(Factory Pattern)的讲解
2019/03/21 PHP
mongodb和php的用法详解
2019/03/25 PHP
php array 转json及java 转换 json数据格式操作示例
2019/11/13 PHP
PHP高并发和大流量解决方案整理
2019/12/24 PHP
悄悄用脚本检查你访问过哪些网站的代码
2010/12/04 Javascript
js 获取(接收)地址栏参数值的方法
2013/04/01 Javascript
js和jquery设置disabled属性为true使按钮失效
2014/08/07 Javascript
JavaScript的作用域和块级作用域概念理解
2014/09/21 Javascript
jQuery的图片滑块焦点图插件整理推荐
2014/12/07 Javascript
JavaScript制作简易的微信打飞机
2015/03/31 Javascript
基于jquery实现ajax无刷新评论
2020/08/19 Javascript
JavaScript的Vue.js库入门学习教程
2016/05/23 Javascript
再次谈论Javascript中的this
2016/06/23 Javascript
jQuery实现的无限级下拉菜单功能示例
2016/09/12 Javascript
Angular.JS判断复选框checkbox是否选中并实时显示
2016/11/30 Javascript
js利用for in循环获取 一个对象的所有属性以及值的实例
2017/03/30 Javascript
NodeJS父进程与子进程资源共享原理与实现方法
2018/03/16 NodeJs
[42:24]完美世界DOTA2联赛循环赛 LBZS vs DM BO2第一场 11.01
2020/11/02 DOTA
Python操作使用MySQL数据库的实例代码
2017/05/25 Python
python中requests库session对象的妙用详解
2017/10/30 Python
Python3 hashlib密码散列算法原理详解
2020/03/30 Python
python如何实现图片压缩
2020/09/11 Python
HTML5样式控制示例代码
2013/11/27 HTML / CSS
欧尚俄罗斯网上超市:Auchan俄罗斯
2018/05/03 全球购物
OSPF有什么优点?为什么OSPF比RIP收敛快?
2013/02/13 面试题
合作意向书范本
2014/03/31 职场文书
民主生活会对照检查材料
2014/09/22 职场文书
2014年检验员工作总结
2014/11/19 职场文书
三峡大坝导游词
2015/01/31 职场文书
电影圆明园观后感
2015/06/03 职场文书
PySwarms(Python粒子群优化工具包)的使用:GlobalBestPSO例子解析
2021/04/05 Python
Python多个MP4合成视频的实现方法
2021/07/16 Python