微信小程序使用canvas
创始人
2024-12-01 00:34:10
0

引用:https://blog.csdn.net/skyblacktoday/article/details/83214546

小程序不能直接将网络图片画到canvas上,,需要使用wx.getImageInfo将图片存到本地,,然后再画入canvas ,

  
 generateCard(){      const {canvasWidth} = this.data     const ctx = wx.createCanvasContext('canvas')     ctx.width = canvasWidth     ctx.drawImage("../../assets/recommend_scene/certificate.jpg",0,0,canvasWidth,300)     ctx.setFontSize(24)     ctx.setFillStyle("#000")     ctx.fillText(this.data.userinfo.username,170,218)        // 绘制圆角矩形路径并裁剪      const imgX = 190; // 图片的X坐标      const imgY = 156; // 图片的Y坐标      const imgWidth = 40; // 图片的宽度      const imgHeight = 40; // 图片的高度      const borderRadius = 20; // 圆角半径        ctx.save(); // 保存当前的绘图上下文       // 创建圆角矩形路径       ctx.beginPath();       ctx.moveTo(imgX + borderRadius, imgY);       ctx.arcTo(imgX + imgWidth, imgY, imgX + imgWidth, imgY + imgHeight, borderRadius);       ctx.arcTo(imgX + imgWidth, imgY + imgHeight, imgX, imgY + imgHeight, borderRadius);       ctx.arcTo(imgX, imgY + imgHeight, imgX, imgY, borderRadius);       ctx.arcTo(imgX, imgY, imgX + imgWidth, imgY, borderRadius);       ctx.closePath();       ctx.clip(); // 裁剪路径       wx.getImageInfo({         src: this.data.userinfo.avatar,         success:(res)=>{           console.log(res,"123")           ctx.drawImage(res.path,imgX,imgY,imgWidth,imgHeight)           ctx.restore(); // 恢复之前保存的绘图上下文           ctx.draw(false,(res)=>{             wx.canvasToTempFilePath({               canvasId:"canvas",               success:(res)=>{                 this.setData({                   imageData:res.tempFilePath                 })               },               fail:(err)=>{                 wx.showToast({                   title: '生成图片失败',                   icon:"none"                 })               }             })           })         }       })           }, 
  saveCard(){     const { imageData } = this.data     if(imageData){       wx.saveImageToPhotosAlbum({         filePath: imageData,         success:()=>{           wx.showToast({             title: '卡片已保存到相册',           })         },         fail:(err)=>{           wx.showToast({             title: '保存失败',             icon:"none"           })         }       })     }else{       wx.showToast({         title: '请先生成卡片',       })     }   }, 

相关内容

热门资讯

HouseCrafter:平面... 在室内设计、房地产展示和影视布景设计等领域,将平面草稿图快速转换为立体的3D场景一直是一个迫切的需求...
go语言编程 小试牛刀 gor... (一)goroutine package _case import "...
1分钟秒懂!星悦广东麻将有挂!... 1分钟秒懂!星悦广东麻将有挂!(透视)外挂透视辅助透视挂(2020已更新)-哔哩哔哩;星悦广东麻将有...
MongoDB教程(九):ja... 💝💝💝首先,欢迎各位来到我的博客&#x...
七分钟了解!(雀友会广东潮汕麻... 自定义新版雀友会广东潮汕麻将系统规律,只需要输入自己想要的开挂功能,一键便可以生成出雀友会广东潮汕麻...
第两了解!德扑之心外挂透明挂辅... 第两了解!德扑之心外挂透明挂辅助开挂,wepoke有科技的(确实有挂)-哔哩哔哩;AI智能教程细节普...
八分钟掌握!九九麻将有挂的!(... 八分钟掌握!九九麻将有挂的!(透视)外挂透视辅助脚本(2020已更新)-哔哩哔哩是一款可以让一直输的...
9分钟了解!(52洛阳麻将)外... 9分钟了解!(52洛阳麻将)外挂辅助作弊!(透视)详细教程(2021已更新)(哔哩哔哩);一、52洛...
第7了解!德扑之星软件透明挂辅... 第7了解!德扑之星软件透明挂辅助插件,微扑克的辅助工具苹果(有挂助手)-哔哩哔哩;德扑锦标赛是一项德...
9分钟掌握!乐友棋牌有挂!(透... 9分钟掌握!乐友棋牌有挂!(透视)外挂开挂辅助软件(2020已更新)-哔哩哔哩是一款可以让一直输的玩...