首頁  >  文章  >  web前端  >  HTML5 之6 __Canvas: 插入圖片, 圖片載入完時執行回調

HTML5 之6 __Canvas: 插入圖片, 圖片載入完時執行回調

黄舟
黄舟原創
2017-02-18 14:29:151455瀏覽

使用canvas API 內建的幾個簡單命令可以輕鬆地為canvas 添加圖片內容,

應當注意:  必須等到圖片完全加載後才能對其進行操作, 瀏覽器通常會在頁面腳本執行的同時異步加載圖片。 如果試圖在圖片未完全加載之前就將其呈現到canvas  上,將不會顯示任何圖片.  

以下示例將加載一張樹皮紋理的圖片作為樹幹以供canvas 使用.  為保證在呈現之前圖片憶完全加載, 這裡提供了回調方法, 即僅當圖像加載完時才執行後續代碼


<!DOCTYPE html>
<html>
  <title>Image example</title>
  <canvas id="trails" style="border: 1px solid;"  width="400" height="400"> </canvas>
  <script>
        // 加载纹理图片
        var bark = new Image();
        bark.src = "bark.jpg";

        // 图片加载完后,将其显示在canvas 上
        bark.onload = function () {
            drawTrails();
        }

        function createCanopyPath(context) {
            context.beginPath();
            context.moveTo(-25, -50);
            context.lineTo(-10, -80);
            context.lineTo(-20, -80);
            context.lineTo(-5, -110);
            context.lineTo(-15, -110);

            context.lineTo(0, -140);

            context.lineTo(15, -110);
            context.lineTo(5, -110);
            context.lineTo(20, -80);
            context.lineTo(10, -80);
            context.lineTo(25, -50);
            context.closePath();
        }

        function drawTrails() {
            var canvas = document.getElementById(&#39;trails&#39;);
            var context = canvas.getContext(&#39;2d&#39;);
            context.save();
            context.translate(130, 250);

            createCanopyPath(context);

            context.lineWidth = 4;
            context.lineJoin = &#39;round&#39;;
            context.strokeStyle = &#39;#663300&#39;;
            context.stroke();

            context.fillStyle = &#39;#339900&#39;;
            context.fill();

            // 用背景图案填充 作为树干的矩形
            context.drawImage(bark, -5, -50, 20, 70);
            context.restore();

            context.save();
            context.translate(-10, 350);
            context.beginPath();
            context.moveTo(0, 0);
            context.quadraticCurveTo(170, -50, 260, -190);
            context.quadraticCurveTo(310, -250, 410,-250);
            context.strokeStyle = &#39;#663300&#39;;
            context.lineWidth = 10;
            context.stroke();
            context.restore();
        }
  </script>
</html>

運行效果圖


onload 函數,以確保只有在圖片載入完成時才呼叫drawTrails 函數.


附件, bark.jpg 圖片:

執行回呼的內容,更多相關內容請關注PHP中文網(www.php.cn)!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn