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
分享到:
相关推荐
2.40_Canvas与浏览器兼容性|Canvas高级内容2|Canvas图形、动画、游戏开发从入门到精通全系列课程
canvas制图 canvas是浏览器提供的绘图机制,使用canvas 标签和js脚本绘图想要绘制的图形
在IT领域,尤其是在Web开发中,经常会遇到与中文输入法和浏览器兼容性相关的问题。本文主要探讨了在使用Canvas元素实现文本监听输入时所遇到的bug及其解决方案。 首先,Canvas元素本身并不支持直接记录文字内容,...
通过这些知识点,开发者可以在canvas上创造出复杂的动画效果,如渐变透明、层叠图像等,大大增强了网页的交互性和视觉吸引力。在实际应用中,可以根据需要结合`globalAlpha`和`globalCompositeOperation`,以达到...
在开发过程中,利用工具如BrowserStack、Can I Use等进行实时测试和特性查询,能有效预防和解决浏览器兼容性问题。同时,保持代码的模块化和可维护性,以及定期更新和优化,都是确保项目长期稳定的关键。
在IT行业中,浏览器兼容性是前端开发者经常面临的一大挑战。不同的浏览器由于内核实现和标准支持的差异,可能会导致相同代码在不同浏览器上表现出不一致的行为。本篇将深入探讨如何解决浏览器兼容问题,帮助您确保...
本文将深入探讨“IE FIREFOX兼容性测试”这一主题,旨在帮助开发者更好地理解和解决不同浏览器间存在的兼容性问题。 首先,我们来理解标题“IE FIREFOX兼容性测试”的含义。这指的是针对Internet Explorer(IE)和...
用于各个浏览器(IE)html2canvas不工作解决方案 html2canvas在火狐、Chrome等浏览器好用,但是IE浏览器无效,导入这个js后就OK啦
尽管如此,理解Flash对联广告在历史上的应用和它如何实现跨浏览器兼容性仍然有价值。 "多浏览器兼容性比较好的Flash对联广告"是指一种设计用于在多种网络浏览器上正常显示的Flash格式广告,通常出现在网页两侧,...
在IT领域,浏览器兼容性是开发...总的来说,理解和解决浏览器兼容性问题对于任何Web开发者来说都是必备技能,通过合理的代码编写、工具辅助以及持续的测试,可以确保网页或应用在各种浏览器上都能提供一致的用户体验。
同时,定期更新和测试在不同浏览器和设备上的兼容性,以确保应用能在各种环境下正常运行。 总结来说,canvas画布在主流浏览器中的尺寸限制是一个重要的考虑因素,开发者需要根据具体目标平台和性能需求来合理设定...
然而,由于浏览器的差异性,尤其是在IE(Internet Explorer)这种历史悠久且有着复杂版本历史的浏览器上,Canvas的兼容性问题时常困扰着开发者。本文将详细探讨如何解决在IE环境下,尤其是低版本IE中的Canvas兼容...
在浏览器兼容性方面,开发者需要考虑到IE和其他现代浏览器之间的差异。例如,旧版本的IE可能不支持`Date.now()`,因此可能需要使用`new Date().getTime()`作为替代。此外,CSS选择器和DOM操作也可能存在差异,开发者...
3. **检测浏览器兼容性**:在JavaScript代码中,首先检查浏览器是否支持canvas,如果不支持,则使用excanvas创建一个模拟的canvas对象。 ```javascript if (!document.createElement('canvas').getContext) { G_...
**与CCapture.js的兼容性** `CCapture.js`允许在浏览器端直接捕获和编码Canvas动画,生成多种格式(如WebM、GIF、MP4)的视频文件。然而,由于浏览器的同源策略限制,有时我们需要服务器端的帮助来处理这些数据。这...
需要注意的是,在实际应用中可能还需要考虑其他因素,比如CSS样式、异步加载的内容以及浏览器的兼容性问题,可能需要对代码进行相应的优化和调整。 总的来说,`html2canvas`和`canvg`的结合使用,为开发者提供了一...
在默认情况之下,如果在Canvas之中将某个物体(源)绘制在另一个物体(目标)之上,那么浏览器就会简单地把源特体的图像叠放在目标物体图像上面。 简单点讲,在Canvas中,把图像源和目标图像,通过Canvas中的 ...
虽然现代浏览器广泛支持Canvas,但老版本的IE可能需要`ExplorerCanvas`或`FlashCanvas`这样的 polyfill 来提供兼容性。 10. **交互性**: 添加交互功能,如鼠标悬停显示单词详情,或者提供重绘或调整大小的选项,...