我正在尝试调整帆布和所有对象的大小。加载JSON并设置画布的主宽度和高度后,我只是尝试调整画布大小。调整画布和对象大小后,某些对象不尊重最高值(或者不是计算正确的我的功能)。
我在Fabricjs 1.7.7
上Runnungvar j = JSON.parse(json);
setTimeout(function(){
canvas.loadFromDatalessJSON(JSON.stringify(j), canvas.renderAll.bind(canvas), function(o, object){
});
setTimeout(function(){
var newWidth = 500;
if (canvas.width != newWidth) {
var scaleMultiplier = newWidth / canvas.width;
var objects = canvas.getObjects();
var factorX = newWidth / canvas.getWidth();
var factorY = newWidth / canvas.getHeight();
for (var i in objects) {
objects[i].scaleX = objects[i].scaleX;
objects[i].scaleY = objects[i].scaleY;
objects[i].left = factorX * objects[i].left;
objects[i].top = factorY * objects[i].top ;
objects[i].setCoords();
};
canvas.setWidth(canvas.getWidth() * factorX);
canvas.setHeight(canvas.getHeight() * factorY);
canvas.renderAll();
canvas.calcOffset();
};
}, 3000);
}, 2000);
这是一个小提琴:http://jsfiddle.net/w3b3r/3stbg75d/
(在此小提琴中,首先有一些超时显示负载JSON的结果,并在调整大小的结果之后)在这种情况下,我得到了调整大小后没有相同位置的元素。
我也只尝试命令centerh()而无需缩放,但结果与我从视图中获得了一些图片。
预先感谢。最好的。
这是一个解决方案:http://jsfiddle.net/6eb2skx7/1/您需要将object.scaleX
和object.scaleY
乘以factorX