1

我正在使用 excanvas.js 库来支持 IE(9 以下)浏览器中的画布功能。我目前面临的问题是 excanvas 期望 image 作为 drawImage() 方法的第一个参数。我发现它不支持另一个画布或视频作为第一个参数。实现此功能的解决方法是什么?我的代码是这样的。

    var canvas1 = document.getElementById("canvas1"); // Get the first canvas Element
    var canvas2 = document.getElementById("canvas2"); // Get the second canvas element
    if (typeof G_vmlCanvasManager != 'undefined') {
        canvas1 = G_vmlCanvasManager.initElement(canvas1); // Initialise with excanvas
        canvas2 = G_vmlCanvasManager.initElement(canvas2);
    }    

    if (canvas1.getContext) {
        var ctx1 = canvas1.getContext("2d");
        var ctx2 = canvas2.getContext("2d");
        var img = new Image();
        img.onload = function () {
            ctx1.drawImage(this, 0, 0, 200, 200); // Draw the image on first canvas
            ctx2.drawImage(canvas1, 0, 0, 200, 200); // Draw the image on to the second canvas using the first canvas
        }
        img.src = "image1.jpg";        
    }

它不适用于 Ie8 及以下浏览器。如何解决这个问题?

4

1 回答 1

0

我会尝试这样的事情:

function canvasToImage( canvas ) {
    var img = new Image();
    img.src = canvas.toDataURL();
    return img;
}
于 2012-11-23T11:49:37.383 回答