2020/9/27 0:00:00
來源:不詳
作者:未知
小程序中的繪圖一般是需要canvas來制作完成,那么如何合理利用小程序canvas進行繪圖,并且圖片及文本適配呢。下面一一來解答。
場景需求
小程序目前不支持直接分享到朋友圈,所以對于有分享到朋友圈的需求,一般是生成一張圖片,例如,生成一張帶有小程序碼的圖片,用戶可以將這張圖片保存到手機本地,然后將這張圖片分享到朋友圈。這張圖片需要使用canvas畫出來。
今天我們不講怎么生成碼,這個一般是后端封裝一個API,前端通過調(diào)用API得到一個小程序碼的url,通過image去畫到canvas上,跟在canvas上畫一個image是一樣的邏輯。這篇文章主要是講怎么在canvas上適配圖片和文字,也就是怎么將圖片和文本畫到canvas上的正確的位置,能在不同的手機上都能正確的展示。
效果圖展示(以下圖片是在微信開發(fā)者工具中顯示的)
這里演示的Demo是:
“選擇圖片”button選擇一張圖片,可以居中顯示在以下圖中的黃色區(qū)域,即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中格式化代碼的時候會將數(shù)字和單位rpx中間添加一個空格,導(dǎo)致編譯報錯,所以用一個function去處理 PS2:樣式說明(設(shè)計稿是基于iphone6視覺稿標準): button寬高:700rpx * 92rpx (350px * 46px) 包裹canvas的容器的view(.canvas-box)position:fixed,占據(jù)除頂部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 // 根據(jù)尺寸動態(tài)計算 1px換算成多少rpx
-
}
2、通過wx.getSystemInfo獲得系統(tǒng)信息,并且計算ratio
-
onReady: function (e) {
-
// 獲取系統(tǒng)信息
-
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的觸發(fā)事件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;
-
-
// 創(chuàng)建canvas,根據(jù)選擇的圖片大小,在canvas上繪制圖片和文字
-
this.createCanvasShareImage(imgUrl, imgWidth, imgHeight);
-
}
-
});
-
}
-
});
-
}
4、創(chuàng)建canvas并在canvas上添加圖片和文本
-
createCanvasShareImage: function (imgUrl, imgW, imgH) {
-
// 使用wx.createCanvasContext獲取繪圖上下文 context
-
let context = wx.createCanvasContext('shareCanvas');
-
console.log('context: ', context);
-
-
// 獲取canvas的寬度:
-
// 750的設(shè)計稿基于iphone6的尺寸(屏幕寬度: 375px)在小程序中的比例是: 1px = 2rpx ==> 375px = 750rpx ==> 屏幕寬度(px) = 750rpx
-
// 所以 1rpx = 屏幕寬度 / 750
-
// 我們這里css中設(shè)置的 canvas 的width:700rpx, 所以 canvas的寬度計算是: [(屏幕寬度 / 750)* 700]rpx, 這樣就可以做到在不同手機上都可以適配
-
let canvasWidthPx = 700 / this.data.ratio;
-
-
// 設(shè)置 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);
-
-
// 設(shè)置字體大小、文本顏色
-
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保存圖片或者直接預(yù)覽圖片,先通過wx.canvasToTempFilePath將當(dāng)前畫布指定區(qū)域的內(nèi)容導(dǎo)出生成指定大小的的圖片,再通過wx.saveImageToPhotosAlbum將圖片保存到本地,或者通過wx.previewImage直接預(yù)覽圖片。
-
saveShareImage() {
-
wx.canvasToTempFilePath({
-
canvasId: 'shareCanvas',
-
success: (res) => {
-
console.log('canvasToTempFilePath: ', res);
-
// 將圖片保存到相冊
-
wx.saveImageToPhotosAlbum({
-
filePath: res.tempFilePath,
-
success: (data) => {
-
console.log(data);
-
}
-
});
-
-
// 直接預(yù)覽圖片
-
wx.previewImage({
-
urls: [res.tempFilePath]
-
})
-
}
-
})
-
}
【本站聲明】
1、本站文章中所選用的圖片及文字來源于網(wǎng)絡(luò)以及用戶投稿,由于未聯(lián)系到知識產(chǎn)權(quán)人或未發(fā)現(xiàn)有關(guān)知識產(chǎn)權(quán)的登記,如有知識產(chǎn)權(quán)人并不愿意我們使用,如果有侵權(quán)請立即聯(lián)系。
2、本網(wǎng)站不對文章中所涉及的內(nèi)容真實性、準確性、可靠性負責(zé),僅系客觀性描述,如您需要了解該類商品/服務(wù)詳細的資訊,請您直接與該類商品/服務(wù)的提供者聯(lián)系。
KESION 科汛軟件
KESION 科汛軟件是國內(nèi)領(lǐng)先的在線教育軟件及私域社交電商軟件服務(wù)提供商,長期專注于為企業(yè)提供在線教育軟件及社交電商SaaS平臺解決方案。
公司核心產(chǎn)品云開店SaaS社交電商服務(wù)平臺、在線教育SaaS服務(wù)平臺、教育企業(yè)數(shù)字化SaaS云平臺、企微營銷助手、私有化獨立部署品牌網(wǎng)校和在線教育咨詢等。KESION 不斷通過技術(shù)創(chuàng)新,提供產(chǎn)品和服務(wù),助力企業(yè)向數(shù)字化轉(zhuǎn)型,通過科技驅(qū)動商業(yè)革新,讓商業(yè)變得更智慧!