微信小程序 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 相关文章推荐
基于jQuery的消息提示插件之旅 DivAlert(三)
Apr 01 Javascript
5秒后跳转到另一个页面的js代码
Oct 12 Javascript
Bootstrap精简教程
Nov 27 Javascript
Angularjs 滚动加载更多数据
Mar 17 Javascript
基于JS实现弹出一个隐藏的div窗口body页面变成灰色并且不可被编辑
Dec 14 Javascript
HTML5开发Kinect体感游戏的实例应用
Sep 18 Javascript
使用原生js+canvas实现模拟心电图的实例
Sep 20 Javascript
vue使用Element组件时v-for循环里的表单项验证方法
Jun 28 Javascript
利用jqgrid实现上移下移单元格功能
Nov 07 Javascript
Vue的编码技巧与规范使用详解
Aug 28 Javascript
Vue+ElementUI使用vue-pdf实现预览功能
Nov 26 Javascript
微信小程序开发(二):页面跳转并传参操作示例
Jun 01 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
在PHP中使用灵巧的体系结构
2006/10/09 PHP
php入门教程 精简版
2009/12/13 PHP
PHP使用Session实现上传进度功能详解
2019/08/06 PHP
php使用redis的有序集合zset实现延迟队列应用示例
2020/02/20 PHP
jQuery+PHP实现图片上传并提交功能
2020/07/27 PHP
JAVASCRIPT keycode总结
2009/02/04 Javascript
ASP 过滤数组重复数据函数(加强版)
2010/05/31 Javascript
从盛大通行证上摘下来的身份证验证js代码
2011/01/11 Javascript
JS 有趣的eval优化输入验证实例代码
2013/09/22 Javascript
浅析JavaScript中的typeof运算符
2013/11/30 Javascript
javascript 闭包详解
2015/02/15 Javascript
在JavaScript中call()与apply()区别
2016/01/22 Javascript
jQuery设置聚焦并使光标位置在文字最后的实现方法
2016/08/02 Javascript
JavaScript定义全局对象的方法示例
2017/01/12 Javascript
js实现带缓动动画的导航栏效果
2017/01/16 Javascript
详解node如何让一个端口同时支持https与http
2017/07/04 Javascript
webpack4.0 入门实践教程
2018/10/08 Javascript
在node中使用jwt签发与验证token的方法
2019/04/03 Javascript
JavaScript如何处理移动端拍摄图片旋转问题
2019/11/16 Javascript
JS实现百度搜索框关键字推荐
2020/02/17 Javascript
解决vue 退出动画无效的问题
2020/08/09 Javascript
Python3从零开始搭建一个语音对话机器人的实现
2019/08/23 Python
python应用Axes3D绘图(批量梯度下降算法)
2020/03/25 Python
python 使用while循环输出*组成的菱形实例
2020/04/12 Python
教你如何用python操作摄像头以及对视频流的处理
2020/10/12 Python
Django restful framework生成API文档过程详解
2020/11/12 Python
xml有哪些解析技术?区别是什么
2016/04/26 面试题
幼儿园老师辞职信
2014/01/20 职场文书
根叔历年演讲稿
2014/05/20 职场文书
项目投资合作意向书
2014/07/29 职场文书
2014年综合治理工作总结
2014/11/20 职场文书
杭州黄龙洞导游词
2015/02/10 职场文书
秋季运动会加油词
2015/07/18 职场文书
女方家长婚礼致辞
2015/07/27 职场文书
MySQL Threads_running飙升与慢查询的相关问题解决
2021/05/08 MySQL
python blinker 信号库
2022/05/04 Python