js:使用canvas检测图片亮度

测试

<!DOCTYPE html>
<html>
  <head>
    <title>图片亮度测试</title>
    <style type="text/css"></style>
  </head>

  <body>
    <div>
      <img
        src=""
      />
      <img
        src=""
      />
      <img
        src="https://fuss10.elemecdn.com/a/3f/3302e58f9a181d2509f3dc0fa68b0jpeg.jpeg"
      />
      <pre>
        Click on image for brightness value
      </pre>
    </div>
  </body>

  <script type="text/javascript">
    function getImageBrightness(imageSrc, callback) {
      var img = document.createElement("img");
      img.src = imageSrc;
      // 解决跨域问题
      img.setAttribute('crossOrigin', 'anonymous');
      img.style.display = "none";
      document.body.appendChild(img);

      var colorSum = 0;

      img.onload = function () {
        // create canvas
        var canvas = document.createElement("canvas");
        canvas.width = this.width;
        canvas.height = this.height;

        var ctx = canvas.getContext("2d");
        ctx.drawImage(this, 0, 0);

        var imageData = ctx.getImageData(0, 0, canvas.width, canvas.height);
        console.log('imageData', imageData)
        var data = imageData.data;
        var r, g, b, avg;

        for (var x = 0, len = data.length; x < len; x += 4) {
          r = data[x];
          g = data[x + 1];
          b = data[x + 2];

          avg = Math.floor((r + g + b) / 3);
          colorSum += avg;
        }

        var brightness = Math.floor(colorSum / (this.width * this.height));
        callback(brightness);
      };
    }

    /// debug code

    var imgs = document.body.getElementsByTagName("img");

    for (var x = 0; x < imgs.length; x++) {
      imgs[x].onclick = function () {
        getImageBrightness(this.src, function (brightness) {
          document.getElementsByTagName("pre")[0].innerHTML =
            "Brightness: " + brightness;
        });
      };
    }
  </script>
</html>

效果

js:使用canvas检测图片亮度_第1张图片

在小程序中使用

在小程序中使用 camera 组件可以实时获取图片的实时帧数据。
https://developers.weixin.qq.com/miniprogram/dev/api/media/camera/CameraContext.onCameraFrame.html

// 节流函数
const throttle = (() => {
  let canRun = true // 通过闭包保存一个标记
  return function(fn, time) {
    if (!canRun) return // 在函数开头判断标记是否为true,不为true则return
    canRun = false // 立即设置为false
    setTimeout(() => { // 将外部传入的函数的执行放在setTimeout中
      fn && fn()
      // 最后在setTimeout执行完毕后再把标记设置为true(关键)表示可以执行下一次循环了。当定时器没有执行的时候标记永远是false,在开头被return掉
      canRun = true
    }, time || 1000)
  }
})()

// 根据图像 buffer 获取亮度
function getImageBrightness({ data, width, height }) {
  let colorSum = 0
  let r = null
  let g = null
  let b = null
  let avg = null
  for (let x = 0, len = data.length; x < len; x += 4) {
    r = data[x]
    g = data[x + 1]
    b = data[x + 2]

    avg = Math.floor((r + g + b) / 3)
    colorSum += avg
  }

  var brightness = Math.floor(colorSum / (width * height))
  return brightness
}

// 打开相机的同时调用此函数
listenBrightness () {
  const fun = (frame) => {
    const width = frame.width
    const height = frame.height
    const data = new Uint8Array(frame.data)
    const brightness = getImageBrightness({data, width, height})
    console.log('当前亮度:', brightness)
    this.setData({
      brightness: brightness
    })
  }

  const context = wx.createCameraContext()
  this.setData({
    listener: context.onCameraFrame((frame) => {
      throttle(fun.bind(this, frame), 500)
    })
  })
  this.data.listener && this.data.listener.start()
}

// 关闭相机的同时调用此函数
this.data.listener && this.data.listener.stop()

js:使用canvas检测图片亮度_第2张图片
可以灵活根据当前亮度进行开发

参考文档

https://blog.csdn.net/weixin_43972437/article/details/96139645

你可能感兴趣的:(#,js,javascript,前端,开发语言)