javascript - 使用 Fabric js 克隆 Canvas 并继续编辑

标签 javascript canvas fabricjs

我想使用 Fabric JS 克隆 Canvas 并继续编辑克隆 Canvas 中现有的 Fabric JS 对象,但它不起作用。表明setBackgroundImage未定义。

$('#btnClick').on('click touchstart', function () {
    var canvas = document.getElementsByTagName("canvas");
    // canvas context
    var context = canvas[0].getContext("2d");
    // get the current ImageData for the canvas
    var data = context.getImageData(0, 0, canvas[0].width, canvas[0].height);
    // store the current globalCompositeOperation
    var compositeOperation = context.globalCompositeOperation;
    // set to draw behind current content
    context.globalCompositeOperation = "destination-over";
    //set background color
    context.fillStyle = "#FFFFFF";
    // draw background/rectangle on entire canvas
    context.fillRect(0,0,canvas[0].width,canvas[0].height);

    var tempCanvas = document.createElement("canvas"),
    tCtx = tempCanvas.getContext("2d");
    
    tempCanvas.width = 640;
    tempCanvas.height = 480;
  
    tempCanvas.setBackgroundImage('');
}
<canvas><canvas>

最佳答案

使用fabric库的想法是使用它的方法来简化你的工作。您不会直接与 Canvas 元素交互。

canvas loadFromJSONtoJSON 方法可用于克隆 Canvas 的副本(包括背景图像)。

var canvas = new fabric.Canvas('canvas');
var canvas2 = new fabric.Canvas('canvas2');
$(document).ready(function() {
    var rect = new fabric.Rect({width: 100, height:200, fill: 'red'});
    canvas.add(rect);
    var circle = new fabric.Circle({radius: 80, fill: 'blue'});
    canvas.add(circle);        
    $('#clone').click(
      function(){canvas2.loadFromJSON(JSON.stringify(canvas), function(){canvas2.renderAll()}); })
});
<script src="http://cdnjs.cloudflare.com/ajax/libs/fabric.js/1.5.0/fabric.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
   
<canvas id='canvas' width="500" height="400" style="border:#000 1px solid;">
</canvas>
 <input id="clone" type="button" value="clone canvas">
<canvas id='canvas2' width="500" height="400" style="border:#000 1px solid;">
</canvas>

关于javascript - 使用 Fabric js 克隆 Canvas 并继续编辑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33716349/

相关文章:

javascript - '^^' 的 Angular 指令中的“要求”

javascript - 如何使用innerHTML在javascript中附加内容

javascript - HTML5 Canvas - 如何从线性化图像数据 Uint8ClampedArray 获取相邻像素位置?

javascript - Html5 Canvas 游戏,创建比查看 Canvas 大得多的 map

javascript - 如何在fabricjs中使用嵌入式图像base64将 Canvas 转换为SVG

javascript - 非常基本的语法荧光笔

javascript - Laravel 和 Dropzonejs,文件上传不正确

javascript - 获取图像 4 个 Angular 的 x、y 坐标

javascript - Fabric.js : How to observe object:scaling event and update properties dynamically?

javascript - Fabric.js 将文本剪切到矩形