小程序從相機(jī)或者相冊(cè)選取圖片

從相機(jī)或者相冊(cè)選取圖片

wx.chooseImage?

wx.chooseImage({

? ? count:1,

????sizeType: ['original', 'compressed'], // original 原圖,compressed 壓縮圖,默認(rèn)二者都有 ????sourceType: ['album', 'camera'],

? ? success:function(res){

????},

? ? fail:function(e){

????}

})

返回路徑為臨時(shí)路徑,在微信開(kāi)發(fā)模擬器上顯示為

http://.......

在真實(shí)手機(jī)上顯示為

wxfile://

接下來(lái)你可能需要顯示圖片,或者是進(jìn)行一些其他的操作

我在做人臉識(shí)別的時(shí)候,選擇圖片后,轉(zhuǎn)base64的時(shí)候遇到一個(gè)問(wèn)題,在這和大家分享一下兒,希望對(duì)大家有幫助

我在 chooseImage后直接進(jìn)行了轉(zhuǎn)base64的操作,代碼如下:

wx.request({

????url:that.src, //文件路徑

????method:'GET',

????responseType: 'arraybuffer',

????success:res =>{

????????let base64 = wx.arrayBufferToBase64(res.data);

????????let userImageBase64 = 'data:image/jpg;base64,' + base64;?????

????????//將base64編碼的圖片傳給后臺(tái)

? ? }, fail:function(e){ }

});

但是遇到了一個(gè)問(wèn)題,就是在模擬器上是顯示正常的,但是在真機(jī)上顯示會(huì)報(bào)request: url invalid ,原因應(yīng)該wxfile格式的文件不能被 wx.request 解析

后來(lái)找到了兩種解決辦法,分享給大家

第一種:將本地文件上傳給服務(wù)器,服務(wù)器返回服務(wù)器路徑

wx.uploadFile({

????url: 'http://10.100.102.111:5000/uploadFile',

? ? filePath: that.src,

? ? name: ‘file’,

????formData:{

????????'data': that.src

????},

????success: function(res){

????????console.log(res);

????????var data = res.data

????}?

})

第二種:使用canvas轉(zhuǎn)化

首選準(zhǔn)備一個(gè)canvas

<canvas canvas-id="canvas" style="width:{{oricanvas.width}};height:{{oricanvas.height}}"></canvas>

在chooseImage的success回調(diào)中你要先調(diào) wx.getImageInfo獲取圖片的實(shí)際寬高信息,之后調(diào)getBase64Image

imgpath:圖片路徑

width:圖片實(shí)際的寬度

height:圖片實(shí)際的高度

callback :獲取base64之后的回調(diào)函數(shù),你可以寫(xiě)你獲取base64后的邏輯

getBase64Image(imgpath,width,height,callback){

????console.log(imgpath,width,height)

????let canvas = wx.createCanvasContext('canvas')

????this.oricanvas.width = width; this.oricanvas.height = height;

????this.setData({ ['oricanvas.width']:width, ['oricanvas.height']:height }) // 1. 繪制圖片至canvas ????canvas.drawImage(imgpath, 0, 0, width, height) // 繪制完成后執(zhí)行回調(diào),API 1.7.0 ????canvas.draw(false,function(){

????????console.log('aaa'); // 2. 獲取圖像數(shù)據(jù), API 1.9.0

????????wx.canvasGetImageData({ canvasId: 'canvas', x: 0, y: 0, width: width, height: height, ????????????success(res) {

????????????????// 3. png編碼

????????????????let pngData = upng.encode([res.data.buffer], res.width, res.height)

????????????????// 4. base64編碼

????????????????let base64 = wx.arrayBufferToBase64(pngData)

????????????????callback && callback(base64);

????????????}

????????})

????})

}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容