如何在FabricJS中优化显示和交互式大svg图像而无滞后

时间:2019-01-02 12:48:18

标签: html5-canvas fabricjs fabricjs2

我有一个fabricJS编辑器,其中包含一些大的svg文件,因此,当我在编辑器上与(移动/拖动)项目进行交互时,它会非常滞后且很沉重。 如何通过fabricJS优化使用大型svg文件?

  • big_image_1.svg: 4.4MB
  • big_image_2.svg: 6.1MB
  • big_image_3.svg: 4.1MB
  • big_image_4.svg: 13.6MB

这是我的代码:

var canvas;

var canvasObject = document.getElementById("editorCanvas");

// set canvas equal size with div
$(canvasObject).width($("#canvasContainer").width());
$(canvasObject).height($("#canvasContainer").height());

canvas = new fabric.Canvas('editorCanvas', {
  backgroundColor: 'white',
  selectionLineWidth: 2,
  width: $("#canvasContainer").width(),
  height: $("#canvasContainer").height()
});

for (var i = 0; i < 4; i++) {

  var bigImage = new fabric.Image();
  bigImage.left = 10 * (i + 1);
  bigImage.top = 10 * (i + 1);
  bigImage["objectCaching"] = true;
  canvas.add(bigImage);
  bigImage.setSrc('https://futushigame.firebaseapp.com/big_image/big_image_' + (i + 1) + '.svg', function(imageObject) {
    imageObject.set('dirty', true);
    canvas.renderAll();
    setObjectCoords();
  });

}

function setObjectCoords() {
  canvas.forEachObject(function(object) {
    object.setCoords();
  });
}
#canvasContainer {
  width: 100%;
  height: 100vh;
  background-color: gray;
}
<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/2.4.3/fabric.js"></script>

<div id="canvasContainer">
  <canvas id="editorCanvas"></canvas>
</div>


拖动项充满繁重和滞后

1 个答案:

答案 0 :(得分:1)

您可以从needsItsOwnCache类重写fabric.Image

var canvasObject = document.getElementById("editorCanvas");

// set canvas equal size with div
$(canvasObject).width($("#canvasContainer").width());
$(canvasObject).height($("#canvasContainer").height());

canvas = new fabric.Canvas('editorCanvas', {
  backgroundColor: 'white',
  selectionLineWidth: 2,
  width: $("#canvasContainer").width(),
  height: $("#canvasContainer").height()
});

for (var i = 0; i < 4; i++) {

  var bigImage = new fabric.Image();
  bigImage.left = 10 * (i + 1);
  bigImage.top = 10 * (i + 1);
  //	bigImage["objectCaching"] = true;
  bigImage["ownCaching"] = true;
  //  bigImage["clipPath"] = [];
  canvas.add(bigImage);
  bigImage.setSrc('https://futushigame.firebaseapp.com/big_image/big_image_' + (i + 1) + '.svg', function(imageObject) {
    //imageObject.set('dirty', true);
    canvas.renderAll();
    setObjectCoords();
  });

}

function setObjectCoords() {
  canvas.forEachObject(function(object) {
    object.setCoords();
  });
}

fabric.Image.prototype.needsItsOwnCache = function() {
  return true
}
#canvasContainer {
  width: 100%;
  height: 100vh;
  background-color: gray;
}
<script src="https://code.jquery.com/jquery-3.3.1.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/2.4.3/fabric.js"></script>

<div id="canvasContainer">
  <canvas id="editorCanvas"></canvas>
</div>