微信小程序> 【小程序】小程序图像处理:图片配色分析

【小程序】小程序图像处理:图片配色分析

浏览量:851 时间: 来源:weixin_34220179

背景

小程序的canvas是微信基于原生组件自行封装的,因此接口跟web的canvas有不少区别,早期更是没有支持像素级的处理能力。
在18年初的小程序基础库1.9.0版本更新中,出现了wx.canvasGetImageData和wx.canvasPutImageData两个重要的API,补全了像素处理能力,因此,小程序在客户端进行图片处理成为了可能。
具体可以参考:
偷偷迭代的重磅功能---小程序的像素处理能力
wx.canvasGetImageData

图片配色分析小程序:小色卡

为了尝试小程序的图像处理能力,我做了个用于图片配色分析的小程序-小色卡。
功能主要是:用户选择一张图片,程序会分析图片的配色,并把配色展示为一张色卡给用户。用户可以保存、编辑、复制自己的色卡。这个功能对初级的UI设计师有一定的帮助(可能吧...)。
源码:github:mini-color-card
体验小程序:
小程序

原理

小程序实现配色分析主要步骤如下:

  1. 用户选择图片,拿到imgPath后绘制到canvas上。
  2. 通过wx.canvasGetImageData这个接口读取图片数据
  3. 对图片数据进行预处理,剔除alpha比较小并且不是白色的点。(非必要)
  4. 对图片像素数据进行聚类。每个像素的颜色可以作为一个三维向量来看。

基本逻辑如下:

wx.chooseImage({  count: 1,  sizeType: ['original', 'compressed'],  sourceType: ['album', 'camera'],  success: (res) = {    wx.getImageInfo({      src: res.tempFilePaths[0],      success: (imgInfo) = {        let {          width,          height,          imgPath        } = imgInfo;        let ctx = wx.createCanvasContext(this.canvasID);        ctx.drawImage(imgPath,0,0,width,height);        ctx.draw(false,()={          wx.canvasGetImageData({            canvasId: this.canvasID,            x: 0,            y: 0,            width: width,            height: height,            success(res) {              var pixels = res.data;              var pixelCount = width*height;              var pixelArray = [];              // 对像素数据进行预处理              for (var i = 0, offset, r, g, b, a; i  pixelCount; i = i + quality) {                offset = i * 4;                r = pixels[offset + 0];                g = pixels[offset + 1];                b = pixels[offset + 2];                a = pixels[offset + 3];                if (a = 125) {                  if (!(r  250 && g  250 && b  250)) {                    pixelArray.push([r, g, b]);                  }                }              }              var cmap = MMCQ.quantize(pixelArray, colorCount);//聚类,MMCQ是个用于图像分析的库              var palette = cmap ? cmap.palette() : null;              console.log('配色为:',palette);            }          })        })      }    })  }})

小结

一开始我是不想把canvas显示出来的,只想用它获取图像内容,但是实践下来是不可行的。小程序的canvas并不允许离屏渲染,想要用它进行图片处理,就要老老实实用它进行展示。
这里只实践了wx.canvasGetImageData读取数据进行图像分析,不过结合wx.canvasPutImageData,滤镜之类的图像处理应该都是可以做了。小程序的想象空间还是挺大的。

版权声明

即速应用倡导尊重与保护知识产权。如发现本站文章存在版权问题,烦请提供版权疑问、身份证明、版权证明、联系方式等发邮件至197452366@qq.com ,我们将及时处理。本站文章仅作分享交流用途,作者观点不等同于即速应用观点。用户与作者的任何交易与本站无关,请知悉。

产品经理

手机 : 13312967497

擅长 : 小程序流量变现

扫码领取礼包

热门模板

  • 头条
  • 搜狐
  • 微博
  • 百家
  • 一点资讯
  • 知乎