html5中让图片重叠在一起,HTML5 Canvas图形叠加(合成)

本文介绍的组合其实就是两个或以上的图形绘制在一起(或“合成”)时所产生的效果。默认的情况是,最后绘制的图形覆盖先前绘制的图形。

在Canvas中有12个组合类型,这些类型用属性globalCompositeOperation来设置,下面给出了所有值在Canvas上的含义说明。

globalCompositeOperation属性值及其含义

"copy" 只绘制新图形,删除其他所有内容

"darker" 图形重叠的地方的颜色由两个颜色值相减后的值决定

"destination-atop" 已有的内容只有在它和新图形重叠的地方保留。新图形绘制于内容之后。和"source-atop"一样

"destination-in" 在新图形以及已有画布重叠的地方,已有内容都保留,所有其他内容成为透明的。和"source-in"一样

"destination-out" 在已有内容和新图形不重叠的地方,已有内容保留,所有其他内容成为透明。和"source-out"一样

"destination-over" 新图形绘制于已有内容的后面。和"source-over"一样

"lighter" 图形重叠的地方的颜色由两种颜色值相加后的值来决定

"source-atop" 只有在新图形和已有内容重叠的地方,才绘制新图形

"source-in" 在新图形以及已有内容重叠的地方,才绘制新图形,所有其他内容成为透明的

"source-out" 只有在与已有图形不重叠的地方,才绘制新图形

"source-over" 新图形绘制于已有图形的顶部,这是默认的行为

"xor" 在重叠和正常绘制的其他地方,图形都成为透明的

本文中出现的"source"指的是将要绘制到画布上的颜色,而"destination"指的是画布上已经存在的颜色。globalCompositeOperation的默认值是

"source-over"。

参考代码如下:

ctx.fillStyle = 'red';

ctx.fillRect(0, 0, 40, 20);

ctx.globalCompositeOperation="destination-out"

//此处的类型值更换后将出现不同的情况,读者可以自行尝试

ctx.fillStyle = 'blue';

ctx.fillRect(8,7, 20, 20);

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值