JavaScript实现256色转灰度图


Posted in Javascript onFebruary 22, 2017

一幅完整的图像,是由红色、绿色、蓝色三个通道组成的。红色、绿色、蓝色三个通道的缩览图都是以灰度显示的。用不同的灰度色阶来表示" 红,绿,蓝"在图像中的比重。通道中的纯白,代表了该色光在此处为最高亮度,亮度级别是255。

灰度化方法:

        1.浮点算法:Gray = R*0.299 + G*0.587 + B*0.114

        2.整数方法:Gray = (R*299 + G*587 + B*114 + 500) / 1000 

        3.移位方法:Gray =(R*28+G*151+B*77)>>8;

        4.平均值法:Gray=(R+G+B)/3;

        5.仅取绿色:Gray=G;

        只要将原来的RGB(R,G,B)中的R,G,B统一用Gray替换,形成新的RGB(Gray,Gray,Gray)就完成灰度化了;

效果图:

JavaScript实现256色转灰度图

代码如下:

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title>ImgBase</title>
 <style type="text/css">
 .scream{
 width:400px;
 height:300px;
 position: absolute;
 top:60px;
 border: 1px solid;
 }
 #canvas{
 position: absolute;
 top:60px;
 left:500px;
 border: 1px dashed;
 }
 </style>
 </head>
 <body>
 <input type="file" onchange="loadImg()"/>
 <input type="button" value="灰度化" onclick="Convert256toGray()"/>
 <br/><br/>
 <div class="scream">
 <img id="scream" width="400px" height="300px" alt="Image preview...">
 </div>
 <canvas id="canvas" width="400px;" height="300px;">
 your browser does not support canvas!
 </canvas>
 <script>
 function Convert256toGray(){
 var c=document.getElementById("canvas");
 var ctx=c.getContext("2d");
 var imgData = ctx.getImageData(0,0,c_w,c_h);
 for (var i=0;i<imgData.data.length;i+=4)
  {
  var R = imgData.data[i]; //R(0-255)
  var G = imgData.data[i+1]; //G(0-255)
  var B = imgData.data[i+2]; //G(0-255)
  var Alpha = imgData.data[i+3]; //Alpha(0-255)
  //浮点算法
  var gray = R*0.299 + G*0.587 + B*0.114;
  //整数算法
//  var gray = (R*299 + G*587 + B*114 + 500) / 1000; 
  //移位算法
//  var gray =(R*76+G*151+B*28)>>8;
  //平均值算法
//   var gray = (R+G+B)/3;
  //仅取绿色
//  var gray=G;
   imgData.data[i] = gray;
   imgData.data[i+1] = gray; 
   imgData.data[i+2] = gray; 
   imgData.data[i+3] = Alpha; 
  }
 ctx.putImageData(imgData,0,0);
 }
 </script>
 <!--base-->
 <script>
 //canvas图像的宽高 
 var c_w = 400; var c_h = 300;
 //加载img图像
 function loadImg(){
 var img = document.getElementById("scream");
 var file = document.querySelector('input[type=file]').files[0];
 if(!/image\/\w+/.test(file.type)){
   alert("文件必须为图片!");
   return false;
  }
 var reader = new FileReader();
 reader.addEventListener("load", function () {
  img.src = reader.result;
 }, false);
 if(file) {
  reader.readAsDataURL(file);
  loadCanvas();
 }
 }
 //加载canvas图像
 function loadCanvas(){
 var c=document.getElementById("canvas");
 var ctx=c.getContext("2d");
 var img = document.getElementById("scream");
 img.onload = function() {
  ctx.drawImage(img,0,0,c_w,c_h);
 } 
 }
 </script>
 </body>
</html>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
js函数名与form表单元素同名冲突的问题
Mar 07 Javascript
浅谈Javascript中的Function与Object
Jan 26 Javascript
分享两段简单的JS代码防止SQL注入
Apr 12 Javascript
AngularJS过滤器filter用法分析
Dec 11 Javascript
jQuery弹出层插件popShow用法示例
Jan 23 Javascript
微信小程序 弹框和模态框实现代码
Mar 10 Javascript
Js中async/await的执行顺序详解
Sep 22 Javascript
vue 指定组件缓存实例详解
Apr 01 Javascript
小程序云开发初探(小结)
Oct 24 Javascript
JS apply用法总结和使用场景实例分析
Mar 14 Javascript
如何用JS模拟实现数组的map方法
Jul 30 Javascript
vue绑定class的三种方法
Dec 24 Vue.js
在javascript中,null>=0 为真,null==0却为假,null的值详解
Feb 22 #Javascript
微信小程序 扎金花简单实例
Feb 21 #Javascript
angular中的http拦截器Interceptors的实现
Feb 21 #Javascript
微信小程序 PHP生成带参数二维码
Feb 21 #Javascript
vue-resource 拦截器使用详解
Feb 21 #Javascript
微信小程序 template模板详解及实例
Feb 21 #Javascript
Bootstrap 3 按钮标签实例代码
Feb 21 #Javascript
You might like
我的论坛源代码(三)
2006/10/09 PHP
php class类的用法详细总结
2013/10/17 PHP
Codeigniter框架的更新事务(transaction)BUG及解决方法
2014/07/25 PHP
PHP使用strtotime获取上个月、下个月、本月的日期
2015/12/30 PHP
详解yii2实现分库分表的方案与思路
2017/02/03 PHP
深入理解JavaScript系列(4) 立即调用的函数表达式
2012/01/15 Javascript
js replace替换所有匹配的字符串
2014/02/13 Javascript
js过滤HTML标签完整实例
2015/11/26 Javascript
jquery插件jquery.confirm弹出确认消息
2015/12/22 Javascript
微信小程序 后台https域名绑定和免费的https证书申请详解
2016/11/10 Javascript
Vue表单验证插件的制作过程
2017/04/01 Javascript
js基于FileSaver.js 浏览器导出Excel文件的示例
2017/08/15 Javascript
微信小程序下拉刷新界面的实现
2017/09/28 Javascript
React组件中的this的具体使用
2018/02/28 Javascript
vue2.0使用v-for循环制作多级嵌套菜单栏
2018/06/25 Javascript
微信小程序实现文字无限轮播效果
2018/12/28 Javascript
图解javascript作用域链
2019/05/27 Javascript
关于在LayUI中使用AJAX提交巨坑记录
2019/10/25 Javascript
JavaScript实现alert弹框效果
2020/11/19 Javascript
微信小程序实现分页加载效果
2020/11/19 Javascript
Python学习之Anaconda的使用与配置方法
2018/01/04 Python
Python MySQLdb 使用utf-8 编码插入中文数据问题
2018/03/13 Python
python中subprocess批量执行linux命令
2018/04/27 Python
python编写猜数字小游戏
2019/10/06 Python
浅谈在JupyterNotebook下导入自己的模块的问题
2020/04/16 Python
opencv 图像滤波(均值,方框,高斯,中值)
2020/07/08 Python
详解python UDP 编程
2020/08/24 Python
美味咖啡的顶级烘焙师:Cafe Britt
2018/03/15 全球购物
毕业生的自我评价分享
2013/12/18 职场文书
副总经理任命书
2014/06/05 职场文书
医院党的群众路线教育实践活动学习心得体会
2014/10/30 职场文书
安娜卡列尼娜观后感
2015/06/11 职场文书
奥巴马开学演讲观后感
2015/06/12 职场文书
python 解决微分方程的操作(数值解法)
2021/05/26 Python
使用SQL实现车流量的计算的示例代码
2022/02/28 SQL Server
Elasticsearch 聚合查询和排序
2022/04/19 Python