javascript svg轉(zhuǎn)canvas和image

代碼(內(nèi)含注釋)

<!DOCTYPE html>
<html>

<head>
    <title></title>
</head>

<body>
    <div id="svg-wrap">
        <svg width="200" height="200" xmlns='http://www.w3.org/2000/svg'>
            <rect width="200" height="200" style="fill:#ddd"></rect>
        </svg>
    </div>
    <canvas id="canvas"></canvas>
    <script>
    window.onload = function(){
        //獲取svg內(nèi)容
        var svg = document.getElementById('svg-wrap').innerHTML;

        var canvas = document.getElementById('canvas');
        var c = canvas.getContext('2d');

        //新建Image對(duì)象
        var img = new Image();

        //svg內(nèi)容
        img.src = 'data:image/svg+xml,' + unescape(encodeURIComponent(svg));//svg內(nèi)容中可以有中文字符
        img.src = 'data:image/svg+xml,' + svg;//svg內(nèi)容中不能有中文字符

        //svg編碼成base64
        img.src = 'data:image/svg+xml;base64,' + window.btoa(unescape(encodeURIComponent(svg)));//svg內(nèi)容中可以有中文字符
        img.src = 'data:image/svg+xml;base64,' + window.btoa(svg);//svg內(nèi)容中不能有中文字符

        //圖片初始化完成后調(diào)用
        img.onload = function() {
            //將canvas的寬高設(shè)置為圖像的寬高
            canvas.width = img.width;
            canvas.height = img.height;
            
            //canvas畫圖片
            c.drawImage(img, 0, 0);

            //將圖片添加到body中
            document.body.appendChild(img)
        }
    }
    </script>
</body>

</html>

效果圖

svg標(biāo)簽一定要加屬性xmlns='http://www.w3.org/2000/svg'
svg標(biāo)簽一定要加屬性xmlns='http://www.w3.org/2000/svg'
svg標(biāo)簽一定要加屬性xmlns='http://www.w3.org/2000/svg'
不然svg內(nèi)容和base64添加到img.src會(huì)出錯(cuò),canvas和image都不會(huì)在頁(yè)面顯示出來

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,569評(píng)論 19 139
  • 注:本文翻譯自developer.mozilla.org/en/docs/Web/SVG/Namespaces_C...
    wengjq閱讀 12,870評(píng)論 1 14
  • 1. XML簡(jiǎn)介 以下內(nèi)容來自于http://www.w3school.com.cn/xml 基本知識(shí) XML 和...
    WebSSO閱讀 2,092評(píng)論 1 7
  • SVG 有一些預(yù)定義的形狀元素,可被開發(fā)者使用和操作。 SVG 形狀 SVG 有一些預(yù)定義的形狀元素,可被開發(fā)者使...
    何wife閱讀 282評(píng)論 0 0
  • 一:canvas簡(jiǎn)介 1.1什么是canvas? ①:canvas是HTML5提供的一種新標(biāo)簽 ②:HTML5 ...
    GreenHand1閱讀 4,881評(píng)論 2 32

友情鏈接更多精彩內(nèi)容