前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >利用Canvas写一个图片灰度处理的小工具,附源码

利用Canvas写一个图片灰度处理的小工具,附源码

作者头像
德顺
发布2020-04-08 15:19:10
1.4K0
发布2020-04-08 15:19:10
举报
文章被收录于专栏:前端资源前端资源前端资源

前两天放假在家没事,写了一个把彩色图片变成灰度(黑白)图片的小工具,“选择图片”确定会自动输出处理后的黑白图片。

直达链接:图片一键变灰

详细代码:

<!doctype html>
<html>
<head>
  <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
  <meta name="keywords" content="w3h5,图片变灰,图片处理,图片变灰色,图片处理成灰色,图片一键变灰,图片灰色">
  <meta name="description" content="一键将彩色图片转换成灰色,支持 .jpeg , .png , .gif 等格式。">
  <title>图片一键变灰 - Web前端资源网</title>
  <meta charset='utf-8'/>
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css"
        integrity="sha384-Vkoo8x4CGsO3+Hhxv8T/Q5PaXtkKtu6ug5TOeNV6gBiFeWPGFN9MuhOf23Q9Ifjh" crossorigin="anonymous">
  <style>
    img, canvas {
      max-width: 100%;
    }

    .container {
      margin-top: 5%;
      margin-bottom: 5%;
    }

    .mt {
      margin-top: 20px;
    }
  </style>
</head>
<body>
<div class="container text-center">
  <h1>图片一键变灰</h1>
  <p>点击选择图片,一键将彩色图片转换成灰色,支持 .jpeg , .png , .gif 等格式。 .gif 图片只能处理第一帧。</p>
  <div class="row justify-content-md-center mt">
    <div class='col-md-8'>
      <p>原图:</p>
      <p id="text-show" style="display: none">处理中...</p>
      <img src="" alt="" id="img-show">
      <p class="mt">灰度模式:</p>
      <canvas id="canvas" style="display: none"></canvas>
      <img src="" alt="" id="img-gray">
    </div>
  </div>
  <div>
    <p>电脑右击另存为图片,手机长按保存图片。</p>
    <label for="upload-img">
      <input type="file" id="upload-img" style="display: none">
      <span class="btn btn-success mt">选择图片</span>
    </label>
    <a href="/" class="btn btn-outline-primary mt">返回首页</a>
  </div>

</div>
<script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
<script>
  $(function () {
    $('#upload-img').change(function () { //判断按钮变化
      $('#text-show').show(); //提示处理中...
      let _URL = window.URL || window.webkitURL, file, img;
      if ((file = this.files[0])) {
        img = new Image();
        img.onload = function () { //图片加载完
          $('#text-show').hide();
          $('#img-show').attr('src', this.src);
          huidu(this.src); //灰度处理
          $('#img-gray').attr('src', canvas.toDataURL()) //显示图片
        };
        img.src = _URL.createObjectURL(file);
      }
    })

    /*
      *function
      *函数名称:huidu
      *功能:把图片转换为灰度图
      *参数:src(原图的url)
      *返回值:(转换完成后的图片url)
    */
    function huidu(src) {
      /*创建一个canvas*/
      // var canvas = document.createElement('canvas');
      var canvas = document.getElementById('canvas');
      var ctx = canvas.getContext('2d');
      var img = new Image();
      img.src = src;
      canvas.height = img.height;
      canvas.width = img.width;
      ctx.drawImage(img, 0, 0);
      var imgdata = ctx.getImageData(0, 0, canvas.width, canvas.height);
      var data = imgdata.data;
      /*灰度处理:求r,g,b的均值,并赋回给r,g,b*/
      for (var i = 0, n = data.length; i < n; i += 4) {
        var average = (data[i] + data[i + 1] + data[i + 2]) / 3;
        data[i] = average;
        data[i + 1] = average;
        data[i + 2] = average;
      }
      ctx.putImageData(imgdata, 0, 0);
      /*返回处理之后的src*/
      return canvas.toDataURL();
    }

    var _hmt = _hmt || [];
    (function() {
      var hm = document.createElement("script");
      hm.src = "https://hm.baidu.com/hm.js?65389d6f23278dbcaa0c5d2db8139c7d";
      var s = document.getElementsByTagName("script")[0];
      s.parentNode.insertBefore(hm, s);
    })();
});
</script>
</body>
</html>

我把代码上传到了 GitHub 上面,需要的可以自取:直达链接

声明:本文由w3h5原创,转载请注明出处:《利用Canvas写一个图片灰度处理的小工具,附源码》 https://cloud.tencent.com/developer/article/1610688

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
图片处理
图片处理(Image Processing,IP)是由腾讯云数据万象提供的丰富的图片处理服务,广泛应用于腾讯内部各产品。支持对腾讯云对象存储 COS 或第三方源的图片进行处理,提供基础处理能力(图片裁剪、转格式、缩放、打水印等)、图片瘦身能力(Guetzli 压缩、AVIF 转码压缩)、盲水印版权保护能力,同时支持先进的图像 AI 功能(图像增强、图像标签、图像评分、图像修复、商品抠图等),满足多种业务场景下的图片处理需求。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档