HTML5 Canvas 学习日志(十二)

本文介绍如何使用HTML5Canvas实现图片像素化的技术,通过绘制图像、获取像素数据并重新组织来实现像素化效果。此教程适合前端开发者深入理解Canvas API并应用于图像处理场景。

HTML5 Canvas 学习日志(十二)
图片像素化

<script type="text/javascript"> $(document).ready(function(){ var canvas = $("#mycanvas"); var context = canvas.get(0).getContext("2d"); var image = new Image(); image.src = "face.png"; $(image).load(function(){ context.drawImage(image, 0, 0, 500, 500); var imageData = context.getImageData(0, 0, canvas.width(), canvas.height()); var pixels = imageData.data; context.clearRect(0, 0, canvas.width(), canvas.height()); var numTileRows = 50; var numTileCols = 50; var tileWidth = imageData.width/numTileCols; var tileHeight = imageData.height/numTileRows; for (var r=0; r<numTileRows; r++){ for (var c=0; c<numTileCols; c++){ var x = (c*tileWidth)+(tileWidth/2); var y = (r*tileHeight)+(tileHeight/2); var pos = (Math.floor(y)*(imageData.width*4))+(Math.floor(x)*4); var red = pixels[pos]; var green = pixels[pos+1]; var blue = pixels[pos+2]; context.fillStyle = "rgb("+red+", "+green+", "+blue+")"; //context.fillRect(x-(tileWidth/2), y-(tileHeight/2), tileWidth, tileHeight); context.beginPath(); context.arc(x, y, tileWidth/2, 0, Math.PI*2, false); context.closePath(); context.fill(); }; }; }); }); </script>

这里写图片描述

转载于:https://my.oschina.net/yuewawa/blog/609913

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值