麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 擴展 > SVG > 正文

詳解FireFox下Canvas使用圖像合成繪制SVG的Bug

2024-09-06 19:57:12
字體:
來源:轉載
供稿:網友

本文適合適合對canvas繪制、圖形學、前端可視化感興趣的讀者閱讀。

楔子

所有的事情都會有一個起因。

最近產品上需要做一個這樣的功能:給一些圖形進行染色處理。想想這還不是順手拈來的事情,早就研究過圖形染色的技術。于是我把之前寫好的兩種算法發給了小伙伴,讓他參照實現,第一種算法是操縱像素、第二種使用了圖像合成:globalCompositeOperation。

所有的事情都可能會有意外,寫程序更是如此了。

沒多久,小伙伴說,第二種算法在firefox下不起作用。

探索原因

聽說有bug,心中一驚。我測試過了的,FireFox下面也測試過的。于是我打開火狐瀏覽器,啟動示例,發現是好的,沒有問題。

但是小伙伴集成到產品中就有問題。 差別在哪兒呢? 通過一起排查,最終發現我的示例代碼和產品中代碼的一個區別是:示例代碼用的是png圖片,而產品中用的是svg圖片。

難道是svg圖片的問題,拿一個svg圖片放到示例代碼中,果然不對。結論已經明顯:

FireFox瀏覽器下,用Canvas下繪制繪制SVG圖的時候,globalCompositeOperation的設置將不生效。

下面是一段用于測試的代碼,ctx.globalCompositeOperation = 'destination-out' 表示用源圖像的形狀去挖空目標圖像。

在其他瀏覽器中,以下代碼中是生效的,又挖空的效果。但是在

在FireFox 下不生效:

<html><head>    <script>        function init() {            var canvas = document.getElementById('c');            var ctx = canvas.getContext('2d');            var img = new Image();            img.onload = function () {                ctx.drawImage(img, 0, 0, img.width * 2, img.height * 2);                ctx.globalCompositeOperation = 'destination-out';            }            img.src = 'diffuse.png';            var svg = new Image;            svg.src = "./d.svg";                                function drawPoint(pointX, pointY) {                ctx.drawImage(svg, pointX - svg.width / 4, pointY - svg.height / 4, svg.width / 2, svg.height / 2);            }            canvas.addEventListener('click', function (e) {                drawPoint(e.clientX, e.clientY);            }, false);        }    </script></head><body onload="init();" style="background: red">    <div>        <canvas id="c" width="1000" height="1000"></canvas>    </div></body></html>

如何解決

找到問題的原因了,解決方法其實簡單。

事情往往就是這樣,很多時候,找到問題所在往往比解決問題要難。

解決方案其實很簡單

代碼中加入判斷,判斷瀏瀏覽器是否是FireFox。

如果是,則先把svg圖片繪制到臨時的canvas上面。

后續繪制用臨時的canvas替代svg圖片。

比如上面代碼可以改進如下:

function init() {            var canvas = document.getElementById('c');            var ctx = canvas.getContext('2d');            var img = new Image();            img.onload = function () {                ctx.drawImage(img, 0, 0, img.width * 2, img.height * 2);                ctx.globalCompositeOperation = 'destination-out';            }            img.src = 'diffuse.png';            var svg = new Image;            svg.src = "./d.svg";                              var tempCanvas = svg;                           if(isFirefox){                             svg.onload = function(){                                  tempCanvas = document.createElement('canvas');                                tempCanvas.width = svg.width;                                tempCanvas.height = svg.height;                                var tempCtx = tempCanvas.getContext('2d');                                tempCtx.drawImage(svg,0,0,svg.width,svg.height);                             }                                    }                                  function drawPoint(pointX, pointY) {                                            ctx.drawImage(tempCanvas, pointX - svg.width / 4, pointY - svg.height / 4, svg.width / 2, svg.height / 2);            }            canvas.addEventListener('click', function (e) {                drawPoint(e.clientX, e.clientY);            }, false);        }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 国产黄色毛片 | 久久国产精品久久久久 | 国产亚洲精品一区二区三区 | 国产精品久久久乱弄 | 欧美五月婷婷 | 天天夜干 | 欧美日韩大片在线观看 | 欧美国产一区二区三区 | 久久国产一二区 | 久久美女色视频 | 毛片免费视频播放 | 九九热视频在线免费观看 | 日韩黄色av网站 | 极品销魂一区二区三区 | 女人叉开腿让男人桶 | 久久久久久久.comav | 日韩美香港a一级毛片免费 日韩激情 | 国产一区二区免费在线观看视频 | 日韩视频1 | 校花被肉干高h潮不断 | 中文字幕免费一区 | 久久99国产综合精品 | 国产精品18久久久久久久久 | 久久免费视频一区二区三区 | 五月天影院,久久综合, | 日韩毛片毛片久久精品 | 7777在线视频免费播放 | 黄色成人短视频 | 成人在线视频黄色 | 综合日韩av | www亚洲成人 | 欧美一级做一级爱a做片性 久久久资源网 | 久久久久久久久久美女 | 欧美成人小视频 | 高清av在线| 美女黄色毛片免费看 | 国产精品一区二区日韩 | 久久国产不卡 | 黄色免费播放网站 | 一级黄色影片在线观看 | 亚洲网站在线播放 |