图片色彩反转与灰度


http://www.hui12.com/nbin/canvas/c1.html

https://nbin2008.github.io/demo/mosaic/index.html


<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>图片色彩反转-灰度</title>
	</head>
	<body>
		<canvas id="c1" width="200" height="200"></canvas>
		<canvas id="c2" width="200" height="200"></canvas>
		<button id="btn1">灰度</button>
		<button id="btn2">反转</button>
		<script type="text/javascript">
			var c1 = document.getElementById('c1');
			var c2 = document.getElementById('c2');
			var ctx1 = c1.getContext('2d');
			var ctx2 = c2.getContext('2d');
			var btn1 = document.getElementById('btn1');
			var btn2 = document.getElementById('btn2');
			
			var img = new Image();
			img.src = 'images/a1.jpg';
			img.onload = function(){
				ctx1.drawImage(img,0,0,200,200);
				btn1.onclick = function(){
					fnCopy(1);
				};
				btn2.onclick = function(){
					fnCopy(2);
				};
				fnCopy(1);
			};
			function fnCopy(type){
				ctx2.clearRect(0,0,200,200);
				var imageData = ctx1.getImageData(0,0,200,200);
				var data = imageData.data;
				if( type == 1 ){
					for( var i=0; i<data.length; i+=4 ){
						var average = (data[i] + data[i+1] + data[i+2])/3;
						data[i] = average;
						data[i+1] = average;
						data[i+2] = average;
					};
				}else if( type == 2 ){
					for( var i=0; i<data.length; i+=4 ){
						data[i] = 255 - data[i];
						data[i+1] = 255 - data[i+1];
						data[i+2] = 255 - data[i+2];
					};
				};
				ctx2.putImageData(imageData,0,0)
			};
		</script>
	</body>
</html>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值