时鲜技术:图像的像素化处理

这篇文章发布于 2010年11月4日,星期四,21:17,归类于 Canvas相关。 阅读 83072 次, 今日 3 次 4 条评论

 

一、开门见山

受美国肖像画家Chuck Close的启发,此脚本通过使用HTML5 canvas元素把图像转换成像素形式,这基本上是一个为canvas imageData功能的简单演示。

此脚本现存于GitHub上,您可以在那里下载到脚本和示例。

在GitHub上查看像素化资源

二、贡献者

三、选项

此方法接受一个对象数组,每个对象都拥有一组选项。

  • resolution : 渲染像素间的像素距离,必须的。
  • shape : 像素的形状。 接受的选项有:square, circle, 以及diamond。可选,默认是square
  • size : 渲染像素的像素大小值,可选,默认值是resolution
  • offset : 偏移像素。可选,默认是0。可以是一个单独的值15实现对角线偏移,或者是个数组或X/Y关键字的对象实现偏移: [ 15, 5 ]{ x: 15, y: 5 }
  • alpha : 小数值,指渲染的透明度。 可选,默认是1

四、效果预览(IE6/7/8建议回家看QQ PK 360)

像素化示例图片 张鑫旭-鑫空间-鑫生活

五、代码示例

要想让图片像素化,首先调用如下脚本:

<script type="text/javascript" src="http://www.zhangxinxu.com/study/201011/close-pixelate/close-pixelate.js"></script>

然后调用方法closePixelate,更具体的是:

图片dom.closePixelate(选项参数)

此脚本可以应用于各类图片。根据HTML5规范,浏览器禁止任何外部托管图片上使用getImageData (),但是,多亏了John Schulz的巨大贡献,通过使用Max Novakovic的getImageData API,进一步像素化具有内置的方法来解决这个安全特征。

<img id="pixelExample2" src="/study/201011/close-pixelate/img/pixel-example.jpg" width="300" height="426" />

在你的脚本中使用closePixelate方法与图片上,你可以通过一组数组选项控制图片输出。如下示例代码:

document.getElementById('pixelExample2').closePixelate( [ 
    { resolution: 24 }
  ] );

这就是上面第二张老人头的像素化效果。

注意:貌似图片地址跨域会没有效果~~

六、最后些东东

您可以狠狠地点击这里:绚烂大图像素化demo

下图就是大图像素化demo的截图:
大图像素化demo截图 张鑫旭-鑫空间-鑫生活

参考文章:Close Pixelate

(本篇完)

分享到:


发表评论(目前4 条评论)

  1. 小贺说道:

    报错,原因我不知怎么解决了。。
    Security error” code: “1000
    [在此错误处中断] imgData = ctx.getImageData(0, 0, w, h).data,
    就是直接把github 上的demo 运行下就报error了

  2. 非主流说道:

    拜读楼主大作,感谢分享好东西!

  3. leavingme说道:

    离线的马赛克~付费后清除~

  4. Glow说道:

    很棒的技术,但是不知道图像的像素化处理在实际的网页制作中有什么应用呢?