HTML5 Canvas 学习日志(十一)

HTML5 Canvas 学习日志(十一)
创建马赛克图片

$(document).ready(function(){var canvas = $("#mycanvas");var context = canvas.get(0).getContext("2d");var imageData = context.createImageData(500, 500);              var pixels = imageData.data;//马赛克的个数var numTileRows = 25;var numTileCols = 25;//每个马赛克的尺寸var tileWidth = imageData.width/numTileCols;var tileHeight = imageData.height/numTileRows;//r,c 是每个马赛克块的行和列for (var r=0; r<numTileRows; r++){for (var c=0; c<numTileCols; c++){//为每个马赛克块设置颜色var red = Math.floor(Math.random()*255);var green = Math.floor(Math.random()*255);var blue = Math.floor(Math.random()*255);//tr, tc是每个马赛克块的实际像素所在的行和列for (var tr=0; tr<tileHeight; tr++){for (var tc=0; tc<tileWidth; tc++){/* trueX, trueY是像素的真实位置 当前块的列数(c)乘以块的宽度得到当前块左边的x坐标, 再加上像素的列(tc)得到像素的x坐标, 即trueX。 trueY同理 */var trueX = (c*tileWidth)+tc;var trueY = (r*tileHeight)+tr;var pos = (trueY*(imageData.width*4))+(trueX*4);

                    pixels[pos] = red;
                    pixels[pos+1] = green;
                    pixels[pos+2] = blue;
                    pixels[pos+3] = 255;
                };
            };
        };  
    };

    context.putImageData(imageData, 0, 0);
});

效果如下图
这里写图片描述

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值