前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >当微信小程序遇上TensorFlow:小程序实现

当微信小程序遇上TensorFlow:小程序实现

作者头像
云水木石
发布2019-07-01 17:41:49
8950
发布2019-07-01 17:41:49
举报
文章被收录于专栏:大龄程序员的人工智能之路

首先要吐槽一下微信小程序开发工具没有Linux版本,为了开发微信小程序,我不得不搬出我的娱乐机iMac。对着硕大的屏幕,看着如蚂蚁般的文字,真心想问一下,那些使用iMac做开发机的朋友们不会肩周发炎,双眼发涩么?

言归正传,在前面的两篇文章《当微信小程序遇上TensorFlow:Server端实现》和《 当微信小程序遇上TensorFlow:Server端实现补充》中,谈到了服务端的实现,本文将继续探讨小程序的实现。

我之前一直从事浏览器引擎的开发工作,对于HTML、CSS、Javascript并不陌生,但没有过多使用前端技术。好在微信小程序在很多地方借鉴了HTML、CSS,也用到了JS,上手起来很快。在浏览了一下入门手册之后,就在微信小程序模板的基础上开发出了一个简单的原型程序。

本微信小程序的主要实现功能点在于:

  1. 调用相机拍照或选择相册中的图片;
  2. 图片缩放,获取图像的RGB数据,;
  3. 组成JSON数据,通过HTTP POST发送到服务器端,并接收返回的响应数据
调用相机拍照或选择相册

由于微信为小程序封装了拍照和选择相册功能,提供了wx.chooseImage API,所以这个功能实现起来非常简单:

代码语言:javascript
复制
  // 拍照
 doTakePhoto: function () {
   // 选择图片
   wx.chooseImage({
     count: 1,
     sizeType: ['compressed'],
     sourceType: ['camera'],
     success: function (res) {
       ...
     },
     fail: e => {
       console.error(e);
     }
   })
 }
图片缩放

网上有相关的资料,具体说来其方法是在小程序page中放一个Canvas,然后调用Canvas Context的drawImage绘制图像,最后调用 wx.canvasGetImageData 得到图片的像素信息,代码如下:

代码语言:javascript
复制
// 获取图像RGB数据
var getImageRGB = function (canvasId, imgUrl, callback, imgWidth, imgHeight) {
 const ctx = wx.createCanvasContext(canvasId);
 ctx.drawImage(imgUrl, 0, 0, imgWidth || 299, imgHeight || 299);
 ctx.draw(false, () => {
   // API 1.9.0 获取图像数据
   wx.canvasGetImageData({
     canvasId: canvasId,
     x: 0,
     y: 0,
     width: imgWidth || 299,
     height: imgHeight || 299,
     success(res) {
       var result = res;
       console.log([result.data.buffer]);       var i, j;
       rows = [];
       for (i = 0; i < result.width; i++) {
         cols = [];
         for (j = 0; j < result.height; j++) {
           rgb = [];
           index = i * result.width + j * 4;         // 每个点包含RGBA 4个分量
           rgb.push(result.data[index] / 255);       // r
           rgb.push(result.data[index + 1] / 255);   // g
           rgb.push(result.data[index + 2] / 255);   // b
           // 忽略alpha值           cols.push(rgb);
         }
         rows.push(cols);
       }       callback(rows);
     },
     fail: e => {
       console.error(e);
     },
   })
 })
};

这段代码很容易理解,获取到图像的RGB数据后,将其存放入JSON数组中。

HTTP POST

微信为小程序原生提供了wx.request API,所以在功能实现上不费吹灰之力:

代码语言:javascript
复制
getImageRGB('dogCanvas', filePath, function (rgbData) {
 //  在此处得到的RGB数据
 json_data = {
   "model_name": "default", "data": { "image": [] }
 }
 json_data["data"]["image"] = [rgbData]; wx.request({
   url: "https://ilego.club:8500",
   method: "POST",
   data: json_data,
   success: function (respose) {
     prediction = respose.data["prediction"];
     console.log(prediction);
   }
 });
});
小结

微信小程序开发起来还是比较简单的,原生提供的功能组件能够极大的简化开发工作,微信小程序开发工具提供了很好的模拟调试环境。如果有过前端开发经验,入手会更加简单。当然,这只是针对入门而言,如果要开发一个产品,需要设计更加复杂的界面,考虑更多的用户交互,那并不是一件简单的事情。

目前这个微信小程序仍然只是一个雏形,后续会持续进行完善,有兴趣的可以访问:https://github.com/mogoweb/aiexamples/ ,同时敬请关注我的微信公众号:云水木石。

参考
  1. 微信小程序图片压缩及base64化上传
  2. javascript加载图片查看具体某一点RGB值
  3. 微信小程序API: https://developers.weixin.qq.com/miniprogram/dev/api/
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-10-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 云水木石 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 调用相机拍照或选择相册
  • 图片缩放
  • HTTP POST
  • 小结
  • 参考
相关产品与服务
云开发 CloudBase
云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档