当前位置:主页 > 聚焦 >

小程序调用百度云接口实现人脸识别

时间:2020-12-17 13:11:06

  小程序开发教程栏目介绍不一样的实现人脸识别方法

 

  相关免费学习:小程序开发教程

  一 准备好百度云的开发者账号

  登录进入控制台人工智能------图像识别创建应用

  获取接口需要的参数

  查看官网API文档

  二 页面布局

  文件ai.wxml:

  <view class="c1"> <view class="c1-1"> </view> <button type="primary" size="mini" bindtap="chooseImage">选择图片</button> <view class="c1-2"> <image src="{{img}}" mode="widthFix"></image> <text>颜值:{{face.beauty}}</text> <text>年龄:{{face.age}}</text> <text>性别:{{face.gender.type}}</text> <text>情绪:{{face.emotion.type}}</text> </view> </view>

  编写样式文件ai.wxss

  .c1{ padding: 50rpx; } .c1-1{ height: 800rpx; margin-bottom: 20rpx; display: flex; justify-content: center; font-size: 30rpx; box-shadow: 0px 0px 10px gray; } .c1-2{ }

  页面布局如下:

  ai.js

  //获取app.js对象 var app = getApp(); Page({ data: { face: {},//检测结果 img: '', //选择的图片 showResult: false //检测是由有结果 }, onLoad: function (options) { //console.log('获取全局变量数据:' + app.globalData.access_token); }, //选择图片事件 chooseImage(){ var that = this; wx.chooseImage({ count: 1, sizeType: ['original', 'compressed'], sourceType: ['album', 'camera'], success (res) { const tempPath = res.tempFilePaths[0];//获取选择的图片的地址 //准备好了access_token和图片后,就可以开始请求百度的人脸检测接口了该接口需要的参数是access_token,图片的base64值 //图片的base64值的处理 var base64 = wx.getFileSystemManager().readFileSync(tempPath,'base64'); //提示 wx.showLoading({ title: '人脸检测中...', mask: true }); //开始请求百度的人脸检测接口 wx.request({ url: '检测结果正确 //将选择的图片回显到页面 //that.setData({img: tempPath}); that.setData(); //植物识别要传入键值对 //取出检测的结果进行页面显示 var face = res.data.result.face_list[0]; console.log(face); that.setData({face: face,showResult: true}); //隐藏加载窗口 wx.hideLoading(); }else{ wx.showToast({ title: '检测失败'+res.data.error_msg, duration: 5000 }); } } }) } }) }, /** * 用户点击右上角分享 */ onShareAppMessage: function () { } })

  app.js

  //app.js App({ onLaunch: function () { var access_token = wx.getStorageSync('access_token'); var expire_in = wx.getStorageSync('expire_in'); // var access_token = parse; var access_token_date = parseInt(wx.getStorageSync('access_token_date')); var now = new Date().getTime(); if(!access_token){ this.requestToken(); } else if(now > access_token_date + expire_in){ this.requestToken(); }else{ } // 展示本地存储能力 var logs = wx.getStorageSync('logs') [] logs.unshift(Date.now()) wx.setStorageSync('logs', logs) // 登录 wx.login({ success: res => { // 发送e 到后台换取 openId, sessionKey, unionId } }) // 获取用户信息rInfo']) { // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框 wx.getUserInfo({ success: res => { // 可以将 res 发送给后台解码出 unionId this.globalData.userInfo = res.userInfo // 由于 getUserInfo 是网络请求,可能会在 Page.onLoad 之后才返回 // 所以此处加入 callback 以防止这种情况 if (this.userInfoReadyCallback) { this.userInfoReadyCallback(res) } } }) } } }) }, globalData: { userInfo: null }, requestToken() { var that = this; wx.request({ url: '那里填写自己的百度key值 client_id: 'aaa', client_secret: 'aaa' }, //header: {'content-type': 'application/json'}, header: {'content-type': 'application/x-www-form-urlencoded'}, success (res) { if(res.statusCode == 200){ wx.setStorageSync("access_token", res.data.access_token); wx.setStorageSync("expires_in", res.data.expires_in); //wx.setStorageSync("access_token_date", res.data.access_token_date); wx.setStorageSync("access_token_date", new Date().getTime()); that.globalData.access_token = res.data.access_token; } } }) } })

  识别结果如下:

热点推荐
1 美国廉航公司向特朗普政府寻求25亿美元

包括边疆航空和阿维洛航空在内的一组美国廉价航空公司正寻求25亿美元的政府援助,作为交换...

2 Arthur Hayes:15万亿信贷将催生百万美元B

消息,BitMEX创始人Arthur Hayes在韩国区块链周发表演讲,剖析了美联储与美国财政部潜在的印钞...

3 Bybit CEO:MICA许可证不足以盈利,需额外许

Bybit首席执行官周焱表示,虽然获得市场加密资产许可证在欧洲运营是重要的,但仅凭此许可证...

4 币界晚讯 Arbitrum请求释放7100万美元冻结以

1. Arbitrum请求释放7100万美元冻结以太坊用于Kelp恢复计划。 2. AAVE与Kelp寻求7100万美元ETH释放以救...

5 KuCoin调整ORCAUSDT永续合约资金费率

消息,KuCoin将于2026年4月26日09:00调整ORCAUSDT永续合约的资金费率结算周期。调整前为每四小时结...

6 实体转入3461万枚$ASTER,$ASTER闪跌5%

去年9月从aster提出的实体,今天凌晨将3461万枚$ASTER转入aster,随后$ASTER价格闪跌5%,从0.66美元...

7 比特币价格接近8万美元,ETF资金流入约

比特币价格接近8万美元,为今年1月以来首次,主要受空头回补、Strategy Inc持续买入以及ETF资金...

8 伊朗外交部长:对巴基斯坦访问成功,分

消息,伊朗外交部长近期连续发表以下观点:一、对巴基斯坦的访问非常成功二、分享了伊朗...

9 Chainlink:正式部署全栈基础设施以代币化

Bridgetower Capital正式部署Chainlink的全栈基础设施,以代币化与DOM X亚利桑那铜金矿项目相关的证...

10 国际海事组织:波斯湾被困海员疏散计划

消息,国际海事组织秘书长多明格斯表示,该组织正同多方共同规划波斯湾被困海员疏散计划...

成都来彰科技 蜀ICP备2025134723号-1

资讯来源互联网,如有版权问题请联系管理员删除。