代码实例:

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<title>图片反色</title>
<style type="text/css">
body{ background:black;}
#c1{ background:white;}
</style>
<script type="text/javascript">
window.onload=function()
{
var oC=document.getElementById('c1');
var oGC=oC.getContext('2d');
var oImg=new Image();
oImg.onload=function()//图片预加载后才可以操作
{
draw(this);
}
oImg.src='1.PNG';
function draw(obj)
{
oC.width=obj.width;//将画布设为图片宽的一倍
oC.height=obj.height*2;//将画布设为图片高的两倍,以用来倒影 oGC.drawImage(obj,0,0);//将图片画在画布上
var newImg=oGC.getImageData(0,0,obj.width,obj.height);//得到图片数据
var ONewImg = oGC.createImageData(obj.width,obj.height);
//重要。要创建新的图片数据再将原来的反色后色数据赋值,
// 如果直接在原数据上操作数据会导致数据覆盖而得不到结果
for(var i=0;i<newImg.height;i++)
{
for(var j=0;j<newImg.width;j++)
{
var color = getXY(newImg,j,i);//得到原来图片数据,一个像素有四个值,分别代表rgba
var result = [];
result[0] = 255 - color[0];
result[1] = 255 - color[1];
result[2] = 255 - color[2];
result[3] = 255*i/newImg.height;
setXY(ONewImg,j,newImg.height-i,result);//设置到新的数据里面
}
}
oGC.putImageData(ONewImg,0,obj.height);//将图片数据设置到画布中 }
//获取rgba
function getXY(obj,x,y)
{
var w=obj.width;
var h=obj.height;
var data=obj.data;
var color=[]; color.push(data[(y*w+x)*4]);
color.push(data[(y*w+x)*4+1]);
color.push(data[(y*w+x)*4+2]);
color.push(data[(y*w+x)*4+3]); return color;
}
//设置rgba
function setXY(obj,x,y,color)
{
var w=obj.width;
var h=obj.height;
var data=obj.data;
data[(y*w+x)*4]=color[0];
data[(y*w+x)*4+1]=color[1];
data[(y*w+x)*4+2]=color[2];
data[(y*w+x)*4+3]=color[3];
}
}
</script>
</head> <body>
<canvas id="c1" width="500" height="500"></canvas>
</body>
</html>

  图片:

效果:

2017-09-09   22:40:39

canvas 图片反色的更多相关文章

  1. html5 canvas图片反色

    <!doctype html> <html> <head> <meta charset="utf-8"> <title> ...

  2. php对图片反色处理

    今天有个需求用php对图片进行反色,和转灰,之前不知道可不可行,后来看到了imagefilter()函数,用来转灰绰绰有余,好强大: imagefilter($im, IMG_FILTER_GRAYS ...

  3. C# 图片反色处理 图片夜间模式

    项目属性-->生成-->允许不安全代码勾上. 代码: /// <summary> /// 反色处理 /// </summary> private Bitmap In ...

  4. Mac 把图片反色

    黑色图变白色 1:用预览打开 2:打开"调整颜色" 3:把"自动色阶"两边的按钮, 拖动换位置,就可以看到效果了.

  5. canvas简单处理图片(反色处理)

    用canvas可以简单地处理图像,比如切割 灰色处理等,今天记下的是图像的反色处理. <!DOCTYPE html> <html> <head> <meta ...

  6. [js高手之路] html5 canvas系列教程 - 像素操作(反色,黑白,亮度,复古,蒙版,透明)

    接着上文[js高手之路] html5 canvas系列教程 - 状态详解(save与restore),相信大家都应该玩过美颜功能,而我们今天要讲的就是canvas强大的像素处理能力,通过像素处理,实现 ...

  7. html、canvas、视频灰度、反色

    效果图: 代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  8. 批量生成反色图片,用PHOTOSHOP批处理功能。

    http://zhidao.baidu.com/link?url=Iz46PDPnEITummTEwo2GtUrK6AeAjlidJ7HtCPJ6NYZJbbllRwNg2iBAcNwF2TYjccP ...

  9. 小技巧!CSS 提取图片主题色功能探索

    本文将介绍一种利用 CSS 获取图片主题色的小技巧.一起看看~ 背景 起因是微信技术群里有个同学发问,有什么方法能够获取图片的主色呢?有一张图片,获取他的主色调: 利用获取到的这个颜色值,来实现类似这 ...

随机推荐

  1. WORD 图片能粘到百度编辑器吗

    在之前在工作中遇到在富文本编辑器中粘贴图片不能展示的问题,于是各种网上扒拉,终于找到解决方案,在这里感谢一下知乎中众大神以及TheViper. 通过知乎提供的思路找到粘贴的原理,通过TheViper找 ...

  2. .net core跨平台

    https://www.cnblogs.com/artech/p/7812811.html .net简介:https://baike.baidu.com/item/.NET/156737?fr=ala ...

  3. flutter中的按钮组件

    Flutter 里有很多的 Button 组件很多,常见的按钮组件有:RaisedButton.FlatButton.IconButton.OutlineButton.ButtonBar.Floati ...

  4. phpjm解密程序,也适用于其他混淆加密的破解

    <?php $file = 'plugin.php'; //要破解的文件 $fp = fopen($file, 'r'); $str = fread($fp, filesize($file)); ...

  5. Winner

    Winner 南昌邀请赛 暴力模拟 #include<bits/stdc++.h> using namespace std; struct Nod { int i; int a,b,c; ...

  6. 2017华南理工华为杯H bx值(容斥问题)

    题目描述 对于一个nnn个数的序列 a1,a2,⋯,ana_1,a_2,\cdots,a_na​1​​,a​2​​,⋯,a​n​​,从小到大排序之后为ap1,ap2,⋯,apna_{p_1},a_{p ...

  7. 微信小程序的事件

    事件,视图层到逻辑层的一种通讯方式,或者将用户的行为返回到逻辑层,当我们在组件绑定事件之后,当我们触发事件,就会执行逻辑层绑定的事件,处理回调函数,当页面的事件触发之后 页面上元素一些额外事件,通过事 ...

  8. python 数值系列-进制转换

    进制转换 前语: 如果您不通二进制,八进制,十六进制,请移步:http://www.360doc.com/content/17/0211/21/40101294_628326994.shtml 问题 ...

  9. 牛客提高D4t3 清新题

    分析 树上从下往上线性基合并即可 并不需要启发式/xyx 代码 #include<iostream> #include<cstdio> #include<cstring& ...

  10. ubuntu更换源

    1.备份源 cd  /etc/apt/ sudo cp sources.list sources.list.bak 2.更换阿里源 sudo vim /etc/apt/sources.list   中 ...