百度云開發注冊與配置
首先需要注冊百度賬號,并登錄百度云,進入管理控制臺,創建文字識別應用,如下圖
創建完應用后,打開應用管理可見APP_ID、API_KEY、SECRET_KEY,需要用在小程序端調用文字識別接口。
小程序服務端開發
由于百度提供了node.js的api,而小程序服務端云函數正是基于node的開發,在小程序開發工具云函數目錄下打開終端導入文字識別api,命令:npm install baidu-aip-sdk,下載完成后,可在云函數目錄看見node_modeules中'baidu-aip-sdk' api。
在云函數目錄下新建conf.js用來存放APP_ID、API_KEY、SECRET_KEY。
然后吊用api中的通用文字識別接口,傳入圖片即可。
// 云函數入口文件
const cloud = require('wx-server-sdk')
let AipOcrClient = require("baidu-aip-sdk").ocr;
const args = require("conf.js");
cloud.init();
// 云函數入口函數
exports.main = async (event, context) => {
// 設置APPID/AK/SK
let APP_ID = args.APP_ID;
let API_KEY = args.API_KEY;
let SECRET_KEY = args.SECRET_KEY;
// 新建一個對象,保存一個對象調用服務接口
let client = new AipOcrClient(APP_ID, API_KEY, SECRET_KEY);
let fileID = event.fileID;
let res = await cloud.downloadFile({
fileID: fileID,
})
let image = res.fileContent.toString("base64");
// 調用通用文字識別, 圖片參數為遠程url圖片
return client.generalBasic(image);
//console.log(result);
// .then(function (result) {
// let result = JSON.stringify(result);
// return result;
// })
}
小程序客戶端開發
圖片來源有兩種途徑,相冊選擇和相機拍攝。
xaingce(e){//相冊響應函數
let tempFiles;
let tempFilePaths;
wx.chooseImage({
count: 1,
sizeType: ['compressed'],
sourceType: ['album', 'camera'],
success:res=>{
// tempFilePath可以作為img標簽的src屬性顯示圖片
tempFiles = res.tempFiles[0].size;
tempFilePaths = res.tempFilePaths[0];
if (tempFiles > 3000000) {//大于3m
wx.showToast({
title: '圖片大小大于3M',
icon: 'none',
duration: 2000
});
return;
}
wx.showLoading({
title: '識別中'
});
this.uplaodF(tempFilePaths);
setTimeout(function () {
wx.hideLoading();
}, 3000);
}
});
},
camera(){//相機響應函數
let ctx = wx.createCameraContext();
ctx.takePhoto({
quality: "normal",
success: (res) => {
let tempFilePaths = res.tempImagePath;
this.setData({
camera: false
});
wx.showLoading({
title: '識別中'
});
this.uplaodF(tempFilePaths);
setTimeout(function () {
wx.hideLoading();
}, 3000);
}
});
},
圖片上傳實現代碼
uplaodF(path){
let result = false;
let name = path.substring(path.lastIndexOf('/') + 1, path.lastIndexOf('.'));
wx.cloud.uploadFile({
cloudPath: name,
filePath: path, // 文件路徑
}).then(res => {
// get resource ID
let id = res.fileID;
//調用云函數識別圖片
wx.cloud.callFunction({
name: 'tongyong',
data: {
fileID: id
}
}).then(res => {
let result = res.result.words_result;
if (result.length > 0) {
let arr = '';
for (let i = 0; i < result.length; i++) {
arr += result[i].words
}
this.setData({
words_result: arr
})
}else{
this.setData({
words_result: ''
})
}
//刪除圖片
wx.cloud.deleteFile({
fileList: [id]
}).then(res => {
// handle success
}).catch(error => {
// handle error
})
}).catch(err => {
console.log(err)
});
}).catch(error => {
});
},
本文為企業推廣,本網站不做任何建議,僅提供參考,作為信息展示!
推薦閱讀:iphone8p上市時間
網友評論
請登錄后進行評論|
0條評論
請文明發言,還可以輸入140字
您的評論已經發表成功,請等候審核
小提示:您要為您發表的言論后果負責,請各位遵守法紀注意語言文明