繁体   English   中英

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

[英]How to set the background image of FabricJS canvas to image from a web service?

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

  1. 连接到Web服务,
  2. 从中获取图像,
  3. 将其存储在myDataURL变量中,
  4. 将其显示在画布上。

这是代码:

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

这是我按下下载按钮后浏览器窗口的外观:

截图

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

我该怎么做?

官方的FabricJS教程建议这样做:

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

但是然后我得到以下错误:

截图

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

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

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

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

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

要使用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> 

另外,如果由于某种原因不需要img元素,则可以按照前面的说明进行操作:

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

那更短更好。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM