`
elementstorm
  • 浏览: 24476 次
  • 性别: Icon_minigender_1
  • 来自: 河南
最近访客 更多访客>>
社区版块
存档分类
最新评论

Canvas globalCompositeOperation浏览器兼容性测试

阅读更多
Canvas里的globalCompositeOperation是个很少用到的函数,不太熟悉程序绘图的同学们估计压根都不知道这玩意是干什么的.

简单来说,Composite(组合),就是对你在绘图中,后绘制的图形与先绘制的图形之间的组合显示效果,比如在国画中,你先画一笔红色,再来一笔绿色,相交的部分是一种混色,而在油画中,绿色就会覆盖掉相交部分的红色,这在程序绘图中的处理就是Composite,Canvas API中对应的函数就是globalCompositeOperation,跟globalAlpha一样,这个属性是全局的,所以在使用的时候要注意save和restore.

我在练习这个函数的时候,用的是chrome浏览器,但是测试结果却跟实际应该出现的结果不太一致,开始我以为是写错了,检查数遍却没有问题,疑惑之下换了各种浏览器来测试,真是囧啊,每个浏览器居然都不一样,连同核心的chrome和safari都不一样...下面是测试结果.


chrome


firefox


opera


safari


firefox官方网站给的实际效果图

下面是每一个选项的说明(我表达的可能不太明白,看图吧):

source-over 默认,相交部分由后绘制图形的填充(颜色,渐变,纹理)覆盖,全部浏览器通过

source-in 只绘制相交部分,由后绘制图形的填充覆盖,其余部分透明,webkit两兄弟没有通过

source-out 只绘制后绘制图形不相交的部分,由后绘制图形的填充覆盖,其余部分透明,webkit两兄弟没有通过

source-atop 后绘制图形不相交的部分透明,相交部分由后绘制图形的填充覆盖,全部浏览器通过

destination-over 相交部分由先绘制图形的填充(颜色,渐变,纹理)覆盖,全部浏览器通过

destination-in 只绘制相交部分,由先绘制图形的填充覆盖,其余部分透明,webkit两兄弟没有通过

destination-out 只绘制先绘制图形不相交的部分,由先绘制图形的填充覆盖,其余部分透明,全部浏览器通过

destination-atop 先绘制图形不相交的部分透明,相交部分由先绘制图形的填充覆盖,webkit两兄弟没有通过

lighter 相交部分由根据先后图形填充来增加亮度,全部浏览器通过

darker 相交部分由根据先后图形填充来降低亮度,chrome通过,firefox官方说Firefox 3.6 / Thunderbird 3.1 / Fennec 1.0以后版本移除这个效果-0-,why?safari看似可以,但是无论你什么颜色,它都给填充成黑色,opera无效果

copy 只绘制后绘制图形,只有opera通过

xor 相交部分透明,全部浏览器通过

结果太令人无语了,特别是firefox那个新版本移除,我靠,为嘛啊?chrome和safari难兄难弟,成绩一塌糊涂,难道是webkit核心的问题?safari那个填充黑色很有IE6-中png透明问题的风范...opera表现很抢眼,只有一个效果未实现,继续努力!

评分及浏览器版本:
Chrome dev 7.0.503.0      : 7/12
Firefox 3.6.6                    : 10/12
Opera 10.53                    : 11/12
Safari 4.0.3(531.9.1)          : 6/12
分享到:
评论
6 楼 cloudgamer 2010-09-09  
在发展阶段的东西这很正常
5 楼 lib 2010-09-09  
html5说:先把我和谐了,否则,其他的事情免谈!
4 楼 kjj 2010-09-08  
html5说,不要迷恋哥,哥只是个传说................
3 楼 西门吹牛 2010-09-08  
再一次证明 html5现在还只是个玩具
2 楼 elementstorm 2010-09-07  
对于IE,哥也笑而不语
1 楼 kimmking 2010-09-07  
对于没有IE,微软笑而不语。

相关推荐

    2.40 Canvas与浏览器兼容性|Canvas高级内容2|Canvas图形、动画、游戏开发从入门到精通全系列课程

    2.40_Canvas与浏览器兼容性|Canvas高级内容2|Canvas图形、动画、游戏开发从入门到精通全系列课程

    canvas是浏览器提供的绘图机制

    canvas制图 canvas是浏览器提供的绘图机制,使用canvas 标签和js脚本绘图想要绘制的图形

    中文输入法以及浏览器兼容的问题1

    在IT领域,尤其是在Web开发中,经常会遇到与中文输入法和浏览器兼容性相关的问题。本文主要探讨了在使用Canvas元素实现文本监听输入时所遇到的bug及其解决方案。 首先,Canvas元素本身并不支持直接记录文字内容,...

    canvas学习(十二):图形透明及交叠效果设置

    通过这些知识点,开发者可以在canvas上创造出复杂的动画效果,如渐变透明、层叠图像等,大大增强了网页的交互性和视觉吸引力。在实际应用中,可以根据需要结合`globalAlpha`和`globalCompositeOperation`,以达到...

    浏览器兼容性常见问题解决

    在开发过程中,利用工具如BrowserStack、Can I Use等进行实时测试和特性查询,能有效预防和解决浏览器兼容性问题。同时,保持代码的模块化和可维护性,以及定期更新和优化,都是确保项目长期稳定的关键。

    解决浏览器兼容

    在IT行业中,浏览器兼容性是前端开发者经常面临的一大挑战。不同的浏览器由于内核实现和标准支持的差异,可能会导致相同代码在不同浏览器上表现出不一致的行为。本篇将深入探讨如何解决浏览器兼容问题,帮助您确保...

    IE FIREFOX兼容性测试

    本文将深入探讨“IE FIREFOX兼容性测试”这一主题,旨在帮助开发者更好地理解和解决不同浏览器间存在的兼容性问题。 首先,我们来理解标题“IE FIREFOX兼容性测试”的含义。这指的是针对Internet Explorer(IE)和...

    用于各个浏览器(IE)html2canvas不工作解决方案

    用于各个浏览器(IE)html2canvas不工作解决方案 html2canvas在火狐、Chrome等浏览器好用,但是IE浏览器无效,导入这个js后就OK啦

    多浏览器兼容性比较好的flash对联广告.zip

    尽管如此,理解Flash对联广告在历史上的应用和它如何实现跨浏览器兼容性仍然有价值。 "多浏览器兼容性比较好的Flash对联广告"是指一种设计用于在多种网络浏览器上正常显示的Flash格式广告,通常出现在网页两侧,...

    各种浏览器的兼容性

    在IT领域,浏览器兼容性是开发...总的来说,理解和解决浏览器兼容性问题对于任何Web开发者来说都是必备技能,通过合理的代码编写、工具辅助以及持续的测试,可以确保网页或应用在各种浏览器上都能提供一致的用户体验。

    canvas 画布在主流浏览器中的尺寸限制详细介绍

    同时,定期更新和测试在不同浏览器和设备上的兼容性,以确保应用能在各种环境下正常运行。 总结来说,canvas画布在主流浏览器中的尺寸限制是一个重要的考虑因素,开发者需要根据具体目标平台和性能需求来合理设定...

    ie下的canvas兼容显示

    然而,由于浏览器的差异性,尤其是在IE(Internet Explorer)这种历史悠久且有着复杂版本历史的浏览器上,Canvas的兼容性问题时常困扰着开发者。本文将详细探讨如何解决在IE环境下,尤其是低版本IE中的Canvas兼容...

    js开发时钟(浏览器兼容)

    在浏览器兼容性方面,开发者需要考虑到IE和其他现代浏览器之间的差异。例如,旧版本的IE可能不支持`Date.now()`,因此可能需要使用`new Date().getTime()`作为替代。此外,CSS选择器和DOM操作也可能存在差异,开发者...

    让IE兼容 HTML5的canvas标签

    3. **检测浏览器兼容性**:在JavaScript代码中,首先检查浏览器是否支持canvas,如果不支持,则使用excanvas创建一个模拟的canvas对象。 ```javascript if (!document.createElement('canvas').getContext) { G_...

    Node.js-从浏览器接收canvas帧并在服务器上生成视频与CCapture.js兼容

    **与CCapture.js的兼容性** `CCapture.js`允许在浏览器端直接捕获和编码Canvas动画,生成多种格式(如WebM、GIF、MP4)的视频文件。然而,由于浏览器的同源策略限制,有时我们需要服务器端的帮助来处理这些数据。这...

    html2canvas(兼容截图svg元素)

    需要注意的是,在实际应用中可能还需要考虑其他因素,比如CSS样式、异步加载的内容以及浏览器的兼容性问题,可能需要对代码进行相应的优化和调整。 总的来说,`html2canvas`和`canvg`的结合使用,为开发者提供了一...

    Canvas globalCompositeOperation

    在默认情况之下,如果在Canvas之中将某个物体(源)绘制在另一个物体(目标)之上,那么浏览器就会简单地把源特体的图像叠放在目标物体图像上面。 简单点讲,在Canvas中,把图像源和目标图像,通过Canvas中的 ...

    Canvas实现文字云效果,多浏览器支持.zip

    虽然现代浏览器广泛支持Canvas,但老版本的IE可能需要`ExplorerCanvas`或`FlashCanvas`这样的 polyfill 来提供兼容性。 10. **交互性**: 添加交互功能,如鼠标悬停显示单词详情,或者提供重绘或调整大小的选项,...

Global site tag (gtag.js) - Google Analytics