如何将FabricJS画布的背景图像设置为来自Web服务的图像?

时间:2015-12-01 16:16:59

标签: javascript canvas fabricjs

我有以下代码,当用户按下按钮时执行。它

  1. 连接到网络服务
  2. 从中获取图片,
  3. 将其存储在myDataURL变量和
  4. 在画布上显示。
  5. 以下是代码:

    function downloadButtonPressed() {
        var username = $("input#username").val();
        var password = $("input#password").val();
        $.ajax({
            type: "GET",
            url: "http://myserver/myapp/map",
            headers: {
                "Authorization": "Basic " + btoa(username + ":" + password),
              },
            crossDomain: true,
            xhrFields: {
                    withCredentials: true
                },
            success: function (data, status, xhr) {
                alert("success");
            }
        }).fail(function ($xhr) {
            console.log("response: " + $xhr);
            var myDataURL = "data:image/png;base64," + $xhr.responseText;
            var canvas = document.getElementById('canvas');
            var context = canvas.getContext('2d');
            var img = new Image();
            img.onload = function() {
                context.drawImage(this, 0, 0, canvas.width, canvas.height);
            };
            img.src = myDataURL;
        });
    }
    

    按下下载按钮后,浏览器窗口显示的内容如下:

    Screenshot

    现在我想将该图像作为画布的背景图像,以便我可以在其上添加其他对象(例如,直角,其他图像)。

    我该怎么做?

    官方FabricJS tutorial建议:

    var myDataURL = "data:image/png;base64," + $xhr.responseText;
    var canvas = document.getElementById('canvas');
    var context = canvas.getContext('2d');
    var img = new Image();
    img.onload = function() {
        // context.drawImage(this, 0, 0, canvas.width, canvas.height);
    };
    img.src = myDataURL;
    canvas.setBackgroundImage(myDataURL, canvas.renderAll.bind(canvas));
    

    但后来我收到以下错误:

    Screenshot

    更新1(02.12.2015 13:23 MSK):无论我使用哪种方法,下载后点击它都会立即消失背景图像。

    Here是一段视频,显示了我的意思。

    更新2(02.12.2015 13:28 MSK):

    这是当前版本的代码:

    选项1:

    function ($xhr) {
        var myDataURL = "data:image/png;base64," + $xhr;
        var canvas = new fabric.Canvas('canvas');
        var img = new Image();
        img.onload = function() {
            var f_img = new fabric.Image(img);
            canvas.setBackgroundImage(f_img);
            canvas.renderAll();
        };
        img.src = myDataURL;
    }
    

    选项2:

    function ($xhr) {
        var myDataURL = "data:image/png;base64," + $xhr;
        var canvas = new fabric.Canvas('canvas');
        canvas.setBackgroundImage(myDataURL, canvas.renderAll.bind(canvas));
    }
    

    更新3(02.12.2015 14:07 MSK):

    如果我尝试使用以下代码向画布添加矩形,则会出现同样的问题。

    function rectButtonPressed() {
        var canvas = new fabric.Canvas('canvas');
        var rect = new fabric.Rect({
          left: 100,
          top: 100,
          fill: 'red',
          width: 20,
          height: 20
        });
        canvas.add(rect);
    }
    

    首先,它出现了,但是当我点击画布时,它再次变空。

1 个答案:

答案 0 :(得分:6)

您的代码的主要问题是您正在使用canvas元素而不是fabricJS画布。

要使用canvas.renderAll()函数,您必须初始化fabric.Canvas对象。

检查代码段:



var myDataURL = "";

var canvas = new fabric.Canvas('canvas');
var img = new Image();
img.onload = function() {
    // this is syncronous
    var f_img = new fabric.Image(img);
    canvas.setBackgroundImage(f_img);
    canvas.renderAll();
};
img.src = myDataURL;

<script src="http://cdnjs.cloudflare.com/ajax/libs/fabric.js/1.5.0/fabric.min.js"></script>
<canvas id='canvas' width="400" height="400" style="border:#000 1px solid;"></canvas>
&#13;
&#13;
&#13;

此外,如果您出于某种原因不需要img元素,您可以按照之前的说法进行操作:

var canvas = new fabric.Canvas('canvas');
canvas.setBackgroundImage(myDataUrl, canvas.renderAll.bind(canvas));

这更短更好。