无法维护fabricjs组元素的strokeWidth

时间:2015-11-25 09:47:01

标签: javascript html5-canvas fabricjs

您好我正在使用fabricjs库并遇到错误。

我正在绘制一组Text和Rect,然后重新调整它的大小。 但是我看到@borders组的大小随着重新调整大小而增加。 但我希望strokeWidth在整个过程中都是相同的。

这里是Fiddle

代码: `

var gCanvas = new fabric.Canvas('canvDraw');
 gCanvas.setWidth(500);
 gCanvas.setHeight(500);

var myEllipse = new fabric.Ellipse({
top: 250,
left: 100,
rx: 75,
ry: 50,
fill: '#999999',
stroke: '#000000',
strokeWidth: 2
});

var myText = new fabric.Text("Some text", {
top: 250,
left: 250,
});


// set up a listener for the event where the object has been modified
gCanvas.observe('object:modified', function (e) {
var objects = gCanvas.getObjects();
for (i in objects) {
    console.log(objects[i]);
    objects[i].strokeWidth = 2;
}
}); 
var group = new fabric.Group([ myEllipse, myText ], {borderColor: 'black', cornerColor: 'green'});
gCanvas.add(group);`

1 个答案:

答案 0 :(得分:1)

Se更新小提琴 http://jsfiddle.net/6CDFr/264/ 用于动态的笔画宽度变化。

gCanvas.observe('object:modified', function (e) {
var myObject = e.target;

if (!myObject._objects) {
  return;
}
for (i in myObject._objects) {
    objects[i].strokeWidth = 2 / Math.sqrt(myObject.scaleX * myObject.scaleY);
}
});

小心我删除了几个canvas.add();你不应该在画布和组中添加对象。

Mantain还有TEXT尺寸:

gCanvas.observe('object:added', function (e) {
    if (e.target.type === 'text' || e.target.type === 'i-text') {
        e.target.originalFontsize = e.target.fontSize;
    }
});
gCanvas.observe('object:modified', function (e) {
var myObject = e.target;

if (!myObject._objects) {
  return;
}
for (i in myObject._objects) {
    var obj = myObject._objects[i];
    var scaleFactor = Math.sqrt(myObject.scaleX * myObject.scaleY);
    obj.strokeWidth = 2 / scaleFactor;
    if (obj.type === 'text' || obj.type === 'i-text') {
        obj.fontSize = obj.originalFontsize / scaleFactor;
    }
}
});

请参阅更新的小提琴http://jsfiddle.net/6CDFr/269/