微信小程序开发中如何使用canvas绘制坐标图
发表于:2024-09-29 作者:千家信息网编辑
千家信息网最后更新 2024年09月29日,这篇文章主要为大家展示了"微信小程序开发中如何使用canvas绘制坐标图",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"微信小程序开发中如何使用canvas
千家信息网最后更新 2024年09月29日微信小程序开发中如何使用canvas绘制坐标图
这篇文章主要为大家展示了"微信小程序开发中如何使用canvas绘制坐标图",内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下"微信小程序开发中如何使用canvas绘制坐标图"这篇文章吧。
1、线图
function draw(data, ctx) { var width, height = 300, ratioX, ratioY, maxY, stepY; var newArr = new Array(); //-------- 数据处理 ----------- if (data.time == null) {return; } if (data.type == 'day' || data.type == 'month') {var timeList = new Array();for (var i = 0; i < data.time.length; i++) { if ((i % 4 == 0 && data.type == 'day') || (i % 5 == 0 && data.type == 'month')) { timeList.push(data.time[i].substr(data.time[i].length - 5, 5)); } } data.time = timeList; } else {for (var i = 0; i < data.time.length; i++) { data.time[i] = data.time[i].substr(data.time[i].length - 5, 5); } }//这里是后台返回的数据,处理后展示在页面 // ---------- 获取屏宽 --------------- wx.getSystemInfo({ success: function (res) { width = res.windowWidth; } }) ratioX = parseInt((width - 60) / (data.time.length - 1)); ratioY = parseInt((height - 45) / 6); //求value的最大值 for (var i = 0; i < data.list.length; i++) { newArr.push(Math.max.apply(Math, data.list[i].value)); } maxY = Math.max.apply(Math, newArr); stepY = Math.ceil(maxY / 4); // ------- 绘制坐标线 ------ ctx.beginPath(); for (var i = 0; i < 5; i++) { ctx.save(); ctx.setStrokeStyle("#dde2e3"); ctx.setFillStyle("#848198"); ctx.setFontSize('8'); ctx.fillText(i * stepY, 0, 220 - i * ratioY); ctx.moveTo(22, 215 - i * ratioY); ctx.lineTo((width - 30), 215 - i * ratioY); ctx.stroke(); ctx.restore(); } //--------- 绘制图例 ------------ for (var i = 0; i < data.list.length; i++) { ctx.save(); ctx.translate(15, 215); ctx.beginPath(); ctx.setStrokeStyle(color[i]); ctx.setLineCap("round"); ctx.setLineWidth(10); ctx.moveTo(22 + i * 38, 46); ctx.lineTo(38 + i * 38, 46); ctx.stroke(); ctx.setFontSize('8'); ctx.setFillStyle("#000000"); ctx.fillText(data.list[i].title, 21 + i * 38, 66); ctx.restore(); } // ------ 绘制横坐标 ------ for (var i = 0; i < data.time.length; i++) { ctx.save(); ctx.translate(15, 215); ctx.setFontSize('8'); ctx.setFillStyle('#848198'); ctx.fillText(data.time[i], i * (ratioX), 20); ctx.restore(); } //------ 绘制折线 --------- for (var i = 0; i < data.list.length; i++) { ctx.beginPath(); ctx.save(); ctx.translate(22, 215); ctx.setStrokeStyle(color[i]); ctx.moveTo(0, -data.list[i].value[0] / (stepY / ratioY));//console.log(data.list[i].value);for (var j = 0; j < data.list[i].value.length; j++) { ctx.lineTo(j * (parseFloat((width - 53) / (data.list[i].value.length - 1))), -(data.list[i].value[j] / (stepY / ratioY))); ctx.stroke(); } ctx.restore(); } ctx.draw();}
2、饼图
function draw(data, ctx) { var start = 0,x,y = 140,r = 90,total=0, end,width; var ratio = new Array(); wx.getSystemInfo({success: function (res) { width = res.windowWidth; } }); x = width / 2 - 15; for(var i=0;i3、柱状图
function draw(data, ctx) { var width,height = 260; var newArr = new Array(); wx.getSystemInfo({success: function (res) { width = res.windowWidth; } }) var ratioX = (width - 55) / data.length; var ratioY = parseInt((height - 45) / 5); //求NUM的最大值 for (var i = 0; i < data.length; i++) { newArr.push(data[i].num); } var maxY = Math.max.apply(Math, newArr); var stepY = Math.ceil(maxY / 4); // ------- 绘制坐标线 ------ ctx.beginPath(); for (var i = 0; i < 5; i++) { ctx.save(); ctx.setStrokeStyle("#dde2e3"); ctx.setFillStyle("#848198"); ctx.setFontSize('8'); ctx.moveTo(15, 215 - i * ratioY); ctx.lineTo(380, 215 - i * ratioY); ctx.fillText(i * stepY, 0, 220 - i * ratioY); ctx.stroke(); ctx.restore(); }
以上是"微信小程序开发中如何使用canvas绘制坐标图"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!
小程
标图
开发
内容
篇文章
最大
数据
最大值
标线
处理
学习
帮助
后台
图例
折线
数据处理
易懂
更多
条理
横坐标
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
我眼中的网络安全小报高质量
pg数据库增删改查语句
软件开发属于什么职位类别
网络安全扫码器是什么
黄浦区智能化软件开发管理系统
csgo匹配出现韩国服务器
服务器拒绝接受发件
安徽网络安全非标机箱哪里好
职高数据库计划
用什么软件开发游戏
车迷数据库
gbase数据库官网
竹山信息软件开发案例
数据库外文复习资料
服务器主板坏了怎么打开磁盘
新闻网络技术与传播
服务器托管吧
索引数据库怎么删除
房卡游戏需要什么配置的服务器
jdbc 数据库配置
网络安全征求立法计划规划座谈会
数据库取出的数据 生成txt
软件开发天马行空
联通企业光纤网络技术优势
德惠先进网络技术服务推荐咨询
沧州昊宇网络技术有限公司好吗
承德隆科网络技术有限公司
火龙果软件开发
手机怎么切换网络安全等级
重庆清逸居互联网科技有限公司