html5 jpeg,HTML5:从画布编码8位灰度JPEG

alphaJPEG方法使用两个图像:一个正常的PNG-24和一个带alpha通道的PNG-24。它会生成一张带有透明度的8位JPEG。改为使用inverse alpha mask生成灰度8位JPEG。

image.jpg

ajpeg.js

(function() {

var create_alpha_jpeg = function(img) {

var alpha_path = img.getAttribute('data-alpha-src')

if(!alpha_path) return

// Hide the original un-alpha'd

img.style.visiblity = 'hidden'

// Preload the un-alpha'd image

var image = document.createElement('img')

image.src = img.src

image.onload = function() {

// Then preload alpha mask

var alpha = document.createElement('img')

alpha.src = alpha_path

alpha.onload = function() {

var canvas = document.createElement('canvas')

canvas.width = image.width

canvas.height = image.height

img.parentNode.replaceChild(canvas, img)

// For IE7/8

if(typeof FlashCanvas != 'undefined') FlashCanvas.initElement(canvas)

// Canvas compositing code

var context = canvas.getContext('2d')

context.clearRect(0, 0, image.width, image.height)

context.drawImage(image, 0, 0, image.width, image.height)

context.globalCompositeOperation = 'xor'

context.drawImage(alpha, 0, 0, image.width, image.height)

}

}

}

// Apply this technique to every image on the page once DOM is ready

// (I just placed it at the bottom of the page for brevity)

var imgs = document.getElementsByTagName('img')

for(var i = 0; i < imgs.length; i++)

create_alpha_jpeg(imgs[i])

})();

In the head element I linked to FlashCanvas:

... and I threw in this to avoid a flicker of the un-alpha’d JPEG:

参考

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值