2020/9/27 0:00:00
泉源:不详
作者:未知
小程序中的绘图一般是需要canvas来制作完成,,,,,,那么怎样合理使用小程序canvas举行绘图,,,,,,并且图片及文本适配呢。。。。。。下面逐一来解答。。。。。。
场景需求
小程序现在不支持直接分享到朋侪圈,,,,,,以是关于有分享到朋侪圈的需求,,,,,,一般是天生一张图片,,,,,,例如,,,,,,天生一张带有小程序码的图片,,,,,,用户可以将这张图片生涯到手机外地,,,,,,然后将这张图片分享到朋侪圈。。。。。。这张图片需要使用canvas画出来。。。。。。
今天我们不讲怎么天生码,,,,,,这个一般是后端封装一个API,,,,,,前端通过挪用API获得一个小程序码的url,,,,,,通过image去画到canvas上,,,,,,跟在canvas上画一个image是一样的逻辑。。。。。。这篇文章主要是讲怎么在canvas上适配图片和文字,,,,,,也就是怎么将图片和文本画到canvas上的准确的位置,,,,,,能在差别的手机上都能准确的展示。。。。。。
效果图展示(以下图片是在微信开发者工具中显示的)
这里演示的Demo是:
“选择图片”button选择一张图片,,,,,,可以居中显示在以下图中的黄色区域,,,,,,即canvas中,,,,,,并在canvas的顶部居中展示文本“你若盛开,,,,,,蝴蝶自来”。。。。。。

代码说明
wxml
-
<button bindtap="chooseImg">选择图片</button>
-
<view class="canvas-box">
-
<canvas class="canvas" canvas-id="shareCanvas" bindlongtap="saveShareImage"></canvas>
-
</view>
$3. scss(wxss) 这里我用的是scss去写样式代码,,,,,,在webStorm中可以通过设置,,,,,,将scss剖析成wxss,,,,,,至于详细怎么设置,,,,,,可以自行百度。。。。。。 PS1:这里界说了一个scss rpx function,,,,,,是由于在webStrom中名堂化代码的时间会将数字和单位rpx中心添加一个空格,,,,,,导致编译报错,,,,,,以是用一个function行止置 PS2:样式说明(设计稿是基于iphone6视觉稿标准): button宽高:700rpx * 92rpx (350px * 46px) 包裹canvas的容器的view(.canvas-box)position:fixed,占有除顶部button的高度之外,,,,,,填满剩余所有空间,,,,,,canvas居中显示,,,,,,宽高:700rpx,,,,,, 100%
-
@function rpx($value) {
-
@return $value*1rpx;
-
}
-
-
page {
-
background-color: #fff6f6;
-
button {
-
width: rpx(700);
-
height: rpx(92);
-
background-color: #ffddab !important;
-
}
-
.canvas-box {
-
position: fixed;
-
top: rpx(92);
-
left: 0;
-
right: 0;
-
bottom: 0;
-
canvas {
-
position: absolute;
-
width: rpx(700);
-
height: 100%;
-
top: 50%;
-
left: 50%;
-
transform: translate(-50%, -50%);
-
}
-
}
-
}
$4. js 1、在data中界说三个变量
-
data: {
-
windowWidth: 0, // 可使用窗口宽度
-
windowHeight: 0, // 可使用窗口高度
-
ratio: 0 // 凭证尺寸动态盘算 1px换算成几多rpx
-
}
2、通过wx.getSystemInfo获得系统信息,,,,,,并且盘算ratio
-
onReady: function (e) {
-
// 获取系统信息
-
wx.getSystemInfo({
-
success: res => {
-
console.log(res);
-
this.setData({
-
windowWidth: res.windowWidth,
-
windowHeight: res.windowHeight,
-
});
-
this.setData({
-
// 屏幕宽度 375px = 750rpx,,,,,,1px=2rpx
-
// 1px = (750 / 屏幕宽度)rpx;;;;;
-
// 1rpx = (屏幕宽度 / 750)px;
-
ratio: 750 / this.data.windowWidth
-
});
-
}
-
});
-
},
3、button的触发事务chooseImg,,,,,,通过wx.chooseImage选择图片,,,,,,通过wx.getImageInfo获取选择的图片的巨细
-
chooseImg: function () {
-
wx.chooseImage({
-
count: 1,
-
success: res => {
-
let imgUrl = res.tempFilePaths[0];
-
// 获取图片巨细
-
wx.getImageInfo({
-
src: imgUrl,
-
success: data => {
-
let imgWidth = data.width;
-
let imgHeight = data.height;
-
-
// 建设canvas,,,,,,凭证选择的图片巨细,,,,,,在canvas上绘制图片和文字
-
this.createCanvasShareImage(imgUrl, imgWidth, imgHeight);
-
}
-
});
-
}
-
});
-
}
4、建设canvas并在canvas上添加图片和文本
-
createCanvasShareImage: function (imgUrl, imgW, imgH) {
-
// 使用wx.createCanvasContext获取绘图上下文 context
-
let context = wx.createCanvasContext('shareCanvas');
-
console.log('context: ', context);
-
-
// 获取canvas的宽度:
-
// 750的设计稿基于iphone6的尺寸(屏幕宽度: 375px)在小程序中的比例是: 1px = 2rpx ==> 375px = 750rpx ==> 屏幕宽度(px) = 750rpx
-
// 以是 1rpx = 屏幕宽度 / 750
-
// 我们这里css中设置的 canvas 的width:700rpx, 以是 canvas的宽度盘算是: [(屏幕宽度 / 750)* 700]rpx,,,,,, 这样就可以做到在差别手机上都可以适配
-
let canvasWidthPx = 700 / this.data.ratio;
-
-
// 设置 canvas 的配景并填充canvas
-
context.fillStyle = '#ffdc22';
-
context.fillRect(0, 0, canvasWidthPx, this.data.windowHeight);
-
-
// 绘制图片:图片居中显示在 canvas 中
-
let imgX = (700 - imgW) / 2;
-
let imgY = (this.data.windowHeight * this.data.ratio - 46 * this.data.ratio - imgH) / 2;
-
let clipWidth = imgW * this.data.ratio;
-
let clipHeight = imgH * this.data.ratio;
-
context.drawImage(imgUrl, -imgX, -imgY, clipWidth, clipHeight, 0, 0, imgW, imgH);
-
-
// 设置字体巨细、文本颜色
-
context.setFontSize(20);
-
context.fillStyle = "#000";
-
-
// 盘算文本的宽度:measureText() 取到文本的 width
-
let txtWidth = context.measureText('你若盛开,,,,,,蝴蝶自来').width;
-
-
// 绘制居中文本:这个地方的 (x, y)的坐标是在文本的左下角位置
-
context.fillText("你若盛开,,,,,,蝴蝶自来", (canvasWidthPx - txtWidth) / 2, 20 * this.data.ratio);
-
-
context.draw();
-
}
5、长按bindlongtapcanva生涯图片或者直接预览图片,,,,,,先通过wx.canvasToTempFilePath将目今画布指定区域的内容导出天生指定巨细的的图片,,,,,,再通过wx.saveImageToPhotosAlbum将图片生涯到外地,,,,,,或者通过wx.previewImage直接预览图片。。。。。。
-
saveShareImage() {
-
wx.canvasToTempFilePath({
-
canvasId: 'shareCanvas',
-
success: (res) => {
-
console.log('canvasToTempFilePath: ', res);
-
// 将图片生涯到相册
-
wx.saveImageToPhotosAlbum({
-
filePath: res.tempFilePath,
-
success: (data) => {
-
console.log(data);
-
}
-
});
-
-
// 直接预览图片
-
wx.previewImage({
-
urls: [res.tempFilePath]
-
})
-
}
-
})
-
}
【本站声明】
1、本站文章中所选用的图片及文字泉源于网络以及用户投稿,,,,,,由于未联系到知识产权人或未发明有关知识产权的挂号,,,,,,若有知识产权人并不肯意我们使用,,,,,,若是有侵权请连忙联系。。。。。。
2、本网站差池文章中所涉及的内容真实性、准确性、可靠性认真,,,,,,仅系客观性形貌,,,,,,如您需要相识该类商品/服务详细的资讯,,,,,,请您直接与该类商品/服务的提供者联系。。。。。。
KESION pp电子软件
KESION pp电子软件是海内领先的在线教育软件及私域社交电商软件服务提供商,,,,,,恒久专注于为企业提供在线教育软件及社交电商SaaS平台解决方案。。。。。。
公司焦点产品云开店SaaS社交电商服务平台、在线教育SaaS服务平台、教育企业数字化SaaS云平台、企微营销助手、私有化自力安排品牌网校和在线教育咨询等。。。。。。KESION 一直通过手艺立异,,,,,,提供产品和服务,,,,,,助力企业向数字化转型,,,,,,通过科技驱动商业刷新,,,,,,让商业变得更智慧!