欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識(shí)庫(kù) > 詳解FireFox下Canvas使用圖像合成繪制SVG的Bug

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

熱門標(biāo)簽:會(huì)聲會(huì)影怎樣做地圖標(biāo)注效果 江蘇高頻外呼系統(tǒng)線路 標(biāo)準(zhǔn)智能外呼系統(tǒng) 洛陽市伊川縣地圖標(biāo)注中心官網(wǎng) 搜狗星級(jí)酒店地圖標(biāo)注 電銷機(jī)器人視頻 地圖標(biāo)注自己去過的地方 高德地圖標(biāo)注錯(cuò)誤怎么修改 平頂山電子地圖標(biāo)注怎么修改

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

楔子

所有的事情都會(huì)有一個(gè)起因。

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

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

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

探索原因

聽說有bug,心中一驚。我測(cè)試過了的,F(xiàn)ireFox下面也測(cè)試過的。于是我打開火狐瀏覽器,啟動(dòng)示例,發(fā)現(xiàn)是好的,沒有問題。

但是小伙伴集成到產(chǎn)品中就有問題。 差別在哪兒呢? 通過一起排查,最終發(fā)現(xiàn)我的示例代碼和產(chǎn)品中代碼的一個(gè)區(qū)別是:示例代碼用的是png圖片,而產(chǎn)品中用的是svg圖片。

難道是svg圖片的問題,拿一個(gè)svg圖片放到示例代碼中,果然不對(duì)。結(jié)論已經(jīng)明顯:

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

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

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

在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>

如何解決

找到問題的原因了,解決方法其實(shí)簡(jiǎn)單。

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

解決方案其實(shí)很簡(jiǎn)單

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

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

后續(xù)繪制用臨時(shí)的canvas替代svg圖片。

比如上面代碼可以改進(jìn)如下:

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);
        }

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

標(biāo)簽:果洛 阿克蘇 蚌埠 廣東 鄂爾多斯 廣西 常德 松原

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《詳解FireFox下Canvas使用圖像合成繪制SVG的Bug》,本文關(guān)鍵詞  詳解,FireFox,下,Canvas,使用,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《詳解FireFox下Canvas使用圖像合成繪制SVG的Bug》相關(guān)的同類信息!
  • 本頁收集關(guān)于詳解FireFox下Canvas使用圖像合成繪制SVG的Bug的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    波多野结衣中文字幕一区 | 日本午夜精品一区二区三区电影| 国产精品自在欧美一区| 素人fc2av清纯18岁| 欧美男生操女生| 亚洲精品菠萝久久久久久久| 成人综合日日夜夜| 国产精品99久久久久久成人| 国产午夜精品美女毛片视频| 久久精品国产免费| 无码h肉动漫在线观看| 日韩午夜激情电影| 奇米色一区二区三区四区| 波多野结衣影院| 欧美一级日韩免费不卡| 日韩电影在线免费| 在线免费观看a级片| 欧美一级久久久| 日韩国产欧美视频| aaaaa一级片| 精品国产91乱码一区二区三区| 麻豆成人免费电影| 91视频免费观看网站| 精品国产一区二区三区忘忧草| 美女视频免费一区| 亚洲av熟女国产一区二区性色| 精品国产凹凸成av人导航| 蓝色福利精品导航| 国产jizz18女人高潮| 国产精品美女久久久久久2018| 国产成人日日夜夜| 欧美色图亚洲视频| 一区二区三区在线观看欧美 | 欧美日韩亚洲综合在线| 亚洲一级二级三级| 9.1成人看片| 国产天堂亚洲国产碰碰| 99免费精品在线| 欧美日本乱大交xxxxx| 日韩av电影天堂| 蜜臀久久99精品久久久久久| 久久伊人中文字幕| 成人午夜免费视频| 在线观看av一区二区| 丝袜美腿一区二区三区| 舐め犯し波多野结衣在线观看| 欧美国产一区二区| av在线免费观看不卡| 欧美一区二区不卡视频| 精品一区二区三区日韩| 欧美老熟妇一区二区三区| 一区二区三国产精华液| 久久无码人妻精品一区二区三区 | 麻豆视频在线免费看| 一区二区高清在线| 亚洲精品女人久久久| 国产清纯在线一区二区www| 成人av电影观看| 欧美一区二区观看视频| 国产在线精品一区在线观看麻豆| 老熟妇高潮一区二区三区| 亚洲综合激情网| 神马久久久久久久久久久| 亚洲欧洲制服丝袜| 极品粉嫩小仙女高潮喷水久久| 亚洲国产精品二十页| 中文字幕乱视频| 国产日韩一级二级三级| 女同性αv亚洲女同志| 久久久久久免费| 亚洲欧美日韩中文字幕在线观看| 精品国产精品网麻豆系列| 99精品视频免费在线观看| 欧美电视剧在线看免费| 99这里都是精品| 精品久久久网站| 91免费国产在线| 久久久精品欧美丰满| 91浏览器打开| 国产欧美一二三区| 亚洲av人人澡人人爽人人夜夜| 欧美极品美女视频| 朝桐光av一区二区三区| 中文字幕一区二区三区不卡在线| 99re久久精品国产| 最好看的中文字幕久久| a级片在线观看| 亚洲第一搞黄网站| caoporn91| 精品一区二区三区在线观看 | 国产盗摄一区二区| 337p亚洲精品色噜噜噜| 成人精品gif动图一区| 欧美精品一区二区三区四区| 国产chinesehd精品露脸| 国产精品嫩草影院av蜜臀| 欧美亚一区二区三区| 一区二区三区高清在线| 国产高潮国产高潮久久久91| 精品亚洲成av人在线观看| 欧美精品色综合| 99久久99久久精品免费观看| 国产亚洲自拍一区| 日本一区二区三区网站| 亚洲一区二区三区四区在线| 亚洲欧美小视频| 国产乱国产乱300精品| 日韩精品一区二| 美女搡bbb又爽又猛又黄www| 亚洲色图在线看| 亚洲综合视频网站| 国产精品资源在线观看| 欧美一区日韩一区| 风韵丰满熟妇啪啪区老熟熟女| 国产精品你懂的在线| 精品少妇一区二区三区密爱| 久久精品国产第一区二区三区| 欧美疯狂做受xxxx富婆| 在线播放国产视频| 亚洲女人的天堂| 色综合久久久久久久久久久| 成人精品高清在线| 中文字幕亚洲在| 东方av正在进入| 不卡视频在线观看| 亚洲欧洲国产日本综合| 色偷偷一区二区三区| av激情成人网| 亚洲人成网站在线| 一本久道中文字幕精品亚洲嫩| 国产精品综合一区二区三区| 久久久青草青青国产亚洲免观| 欧美做受xxxxxⅹ性视频| 免费久久精品视频| 欧美tk丨vk视频| 国产三级av在线播放| 日本韩国欧美一区二区三区| av综合在线播放| 亚洲精品成人精品456| 欧美色爱综合网| 午夜性福利视频| 亚洲大型综合色站| 欧美一区二区三区播放老司机| 中文字幕在线播放视频| 日韩综合在线视频| 精品成a人在线观看| 国产午夜精品福利视频| 国产成人av电影在线播放| 中文字幕一区二区在线播放| 91福利视频久久久久| 亚洲 自拍 另类 欧美 丝袜| 亚洲午夜免费视频| 日韩三级中文字幕| 久久婷婷五月综合| 丰满放荡岳乱妇91ww| 亚洲男人的天堂av| 欧美日韩视频第一区| 丰满少妇一区二区三区| 国产一区二区三区在线观看免费 | 久久久久国产精品厨房| 亚洲av无一区二区三区| 成+人+亚洲+综合天堂| 亚洲激情欧美激情| 欧美高清视频在线高清观看mv色露露十八| www.四虎精品| 国产精品第13页| 欧美在线|欧美| 在线天堂www在线国语对白| 久久福利资源站| 欧美韩国日本一区| 中文字幕av免费在线观看| 成人污视频在线观看| 亚洲大片一区二区三区| 日韩精品一区二区三区三区免费| 永久免费av无码网站性色av| 99热精品国产| 婷婷丁香久久五月婷婷| 久久精品人人做人人爽人人| 网站永久看片免费| 人妻av一区二区三区| 欧美aaaaaa午夜精品| 国产偷v国产偷v亚洲高清| 在线免费亚洲电影| 国产精品伦子伦| 国产一区二区三区不卡在线观看| 中文字幕亚洲在| 337p亚洲精品色噜噜狠狠| 成年人在线免费看片| 成人一区二区三区视频在线观看| 午夜精品福利一区二区三区av| 精品国产乱码久久久久久久| 加勒比婷婷色综合久久| 91精品国产高清91久久久久久 | 亚洲一区二区三区四区在线免费观看| 欧美一区二区三区在线视频 | 日韩欧美视频在线| 视频国产一区二区| 性高潮免费视频| 美女精品一区二区| 一区二区三区欧美久久|