微信小程序?qū)崿F(xiàn)拍照畫布指定區(qū)域生成圖片
最近寫識別行駛證功能,點擊拍照把指定區(qū)域截取,生成圖片功能。
系統(tǒng)相機。該組件是原生組件,使用時請注意相關(guān)限制。 掃碼二維碼功能,需升級微信客戶端至6.7.3。
我們看下效果:

1、首先生成一個CanvasContext:
/**
* 生命周期函數(shù)--監(jiān)聽頁面加載
*/
onLoad: function(options) {
requireJs.adaptionIphoneX(this);
this.ctx = wx.createCameraContext()
},
2、相機的 wxml樣式

<camera wx:if='{{isShowCamera}}' device - position="width" flash="off" style="width:{{windowWidth}}px; height:{{windowHeight}}px;">
<cover-view class='camerabgImage-view'>
<cover-image class='bgImage' src='{{isIphoneX==true?"../../myImage/vehicle/biankuang_x.png":"../../myImage/vehicle/biankuang.png"}}'> </cover-image>
<cover-view class='cameratop-view1'>中華人民共和國機動車行駛證</cover-view>
<cover-view class='cameratop-view2'>(行駛證主頁)</cover-view>
<cover-view class='cameracenter-view' style='top:{{isIphoneX==true?"52%":"62%"}}'>請對準(zhǔn)左下角發(fā)證機關(guān)印章</cover-view>
<!-- 拍照按鈕 -->
<cover-view class='camerabotton-view' style='bottom:{{isIphoneX==true?"75px":"0px"}}'>
<cover-image class='cancelphoto' src='../../myImage/vehicle/quxiao.png' bindtap='cancelPhotoAction'></cover-image>
<cover-image class='takephoto' src='../../myImage/vehicle/paizhao.png' bindtap='takePhotoAction'></cover-image>
<cover-view class='skipphoto' bindtap='skipphotoAction'>{{skipphotoStatus==1?"跳過":""}}
</cover-view>
</cover-view>
</cover-view>
</camera>
<canvas wx:if='{{isShowImage}}' canvas-id="image-canvas" style='width:{{windowWidth}}px; height:{{windowHeight}}px;'></canvas>
3、相機的 wxss樣式
.camerabgImage-view{
height: 100%;
width: 100%;
position:absolute;
}
.bgImage{
width: 100%;
height: 100%;
position: absolute;
}
.cameratop-view1{
margin-top: 174rpx;
}
.cameratop-view2{
margin-top: 220rpx;
}
.cameratop-view1, .cameratop-view2{
width: 100%;
display: flex;
justify-content: center;
position: absolute;
font-family: PingFangSC-Medium;
font-size: 36rpx;
color: #FFFFFF;
letter-spacing: 0;
text-align: center;
}
.cameracenter-view{
height: 44rpx;
width: 100%;
position: absolute;
font-family: PingFangSC-Medium;
font-size: 32rpx;
color: #FFFFFF;
letter-spacing: 0;
text-align: center;
}
/* 底部 */
.camerabotton-view{
height: 200rpx;
width: 100%;
position:absolute;
display: flex;
justify-content: space-around;
align-items: center;
}
.cancelphoto{
width: 50rpx;
height: 50rpx;
}
.takephoto{
width: 132rpx;
height: 132rpx;
}
.skipphoto{
font-family: PingFangSC-Regular;
font-size: 32rpx;
color: #FFFFFF;
letter-spacing: 0;
text-align: center;
}
4、js 中訪問原生組件 camera 主要針對相機權(quán)限處理
onShow: function() {
var that = this
wx.authorize({
scope: 'scope.camera',
success: function (res) {
that.setData({
isShowCamera: true,
})
},
fail: function (res) {
console.log("" + res);
wx.showModal({
title: '請求授權(quán)您的攝像頭',
content: '如需正常使用此小程序功能,請您按確定并在設(shè)置頁面授權(quán)用戶信息',
confirmText: '確定',
success: res => {
if (res.confirm) {
wx.openSetting({
success: function (res) {
console.log('成功');
console.log(res);
if (res.authSetting['scope.camera']) { //設(shè)置允許獲取攝像頭
console.log('設(shè)置允許獲取攝像頭')
wx.showToast({
title: '授權(quán)成功',
icon: 'success',
duration: 1000
})
that.setData({
isShowCamera: true,
})
} else { //不允許
wx.showToast({
title: '授權(quán)失敗',
icon: 'none',
duration: 1000
})
wx.redirectTo({
url: 'addCarInfo/addCarInfo',
})
}
}
})
} else { //取消
wx.showToast({
title: '授權(quán)失敗',
icon: 'none',
duration: 1000
})
wx.redirectTo({
url: 'addCarInfo/addCarInfo',
})
}
}
})
}
})
},
5、頁面初始化數(shù)據(jù)
/**
* 頁面的初始數(shù)據(jù)
*/
data: {
isShowCamera: false,
width: 10,
height: 10,
src: "",
image: "",
skipphotoStatus: "0",// 1跳過 0沒有跳過
isShowImage: false
},
6、點擊拍照 設(shè)置照片, 返回拍照圖片
/**
* 拍照
*/
takePhotoAction: function() {
var that = this
that.ctx.takePhoto({
quality: 'high', //高質(zhì)量
success: (res) => {
this.loadTempImagePath(res.tempImagePath);
},
})
},
7、針對原圖片截取尺寸 與 截取后的圖片
loadTempImagePath: function(options) {
var that = this
that.path = options
wx.getSystemInfo({
success: function(res) {
// 矩形的位置
var image_x = 15;
var image_y = 150;
var image_width = that.data.width - 2 * 15;
var image_height = 238;
wx.getImageInfo({
src: that.path,
success: function(res) {
that.setData({
isShowImage: true,
})
that.canvas = wx.createCanvasContext("image-canvas", that)
//過渡頁面中,圖片的路徑坐標(biāo)和大小
that.canvas.drawImage(that.path, 0, 0, that.data.width, that.data.height)
wx.showLoading({
title: '數(shù)據(jù)處理中...',
icon: 'loading',
duration: 10000
})
// 這里有一些很神奇的操作,總結(jié)就是MD拍出來的照片規(guī)格居然不是統(tǒng)一的過渡頁面中,對裁剪框的設(shè)定
that.canvas.setStrokeStyle('black')
that.canvas.strokeRect(image_x, image_y, image_width, image_height)
that.canvas.draw()
setTimeout(function() {
wx.canvasToTempFilePath({ //裁剪對參數(shù)
canvasId: "image-canvas",
x: image_x, //畫布x軸起點
y: image_y, //畫布y軸起點
width: image_width, //畫布寬度
height: image_height, //畫布高度
destWidth: image_width, //輸出圖片寬度
destHeight: image_height, //輸出圖片高度
success: function(res) {
that.setData({
image: res.tempFilePath,
})
//清除畫布上在該矩形區(qū)域內(nèi)的內(nèi)容。
// that.canvas.clearRect(0, 0, that.data.width, that.data.height)
// that.canvas.drawImage(res.tempFilePath, image_x, image_y, image_width, image_height)
// that.canvas.draw()
wx.hideLoading()
console.log(res.tempFilePath);
//在此可進行網(wǎng)絡(luò)請求
PublicJS.drivinglicenseUpload(res.tempFilePath, that.uploadFile);
},
fail: function(e) {
wx.hideLoading()
wx.showToast({
title: '出錯啦...',
icon: 'loading'
})
if (this.data.skipphotoStatus == 1) {
wx.redirectTo({
url: 'addCarInfo/addCarInfo',
})
} else {
wx.navigateBack({
delta: 1
});
}
}
});
}, 1000);
}
})
}
})
},
// 接口返回結(jié)果
uploadFile: function(data) {}
1.canvas組件是由客戶端創(chuàng)建的原生組件,它的層級是最高的。
2.請勿在scroll-view中使用canvas組件。
3.css動畫對canvas組件無效。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
再談javascript圖片預(yù)加載技術(shù)(詳細演示)
由于javascript無法獲取img文件頭數(shù)據(jù),必須等待其加載完畢后才能獲取真實的大小,所以lightbox類效果為了讓圖片居中顯示,導(dǎo)致其速度體驗要比直接輸出的差很多。2011-03-03
為什么說JavaScript預(yù)解釋是一種毫無節(jié)操的機制詳析
這篇文章主要給大家介紹了關(guān)于為什么說JavaScript預(yù)解釋是一種毫無節(jié)操的機制的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧2018-11-11
JavaScrip實現(xiàn)圖片壓縮與分辨率等比例縮放
這篇文章主要為大家詳細介紹了如何使用JavaScrip實現(xiàn)圖片壓縮與分辨率等比例縮放,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-03-03
JS數(shù)組降維的實現(xiàn)Array.prototype.concat.apply([], arr)
這篇文章主要介紹了JS數(shù)組降維的實現(xiàn)Array.prototype.concat.apply([], arr),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
Javascript 數(shù)組添加一個 indexOf 方法的實現(xiàn)代碼
Javascript 的字符串有個 indexOf 的方法,能夠返回字符在指定的字符串中的位置,非常有用,本文介紹了如何給 Javascript 數(shù)組也添加一個類似的方法。2009-09-09

