-
-
Notifications
You must be signed in to change notification settings - Fork 3.5k
FAQ
canvas.getObjects()
returns an array of all objects on canvas.
canvas.item(n)
returns n-th object on canvas (where indexing is associated with z-order)
canvas.getObjects(); // [...]
canvas.item(0); // first item
canvas.item(1); // second item
Using fabric.Object#set
method or one of the set* methods — setFill
, setWidth
, setHeight
, setOpacity
, etc.
// changing dimension
rect.set('width', 100).set('height', 50);
// or
rect.set({ width: 100, height: 50 });
// update the bounding rect after changing dimension
rect.setCoords();
// other properties
rect.setFill('red');
rect.setOpacity(0.5);
Using "backgroundColor" property of fabric.Element
instance.
canvas.backgroundColor = 'red';
// or
canvas.backgroundColor = rgba(0, 255, 0, 0.5);
Using "clipTo" property of fabric.Element
instance:
canvas.clipTo = function(ctx) {
ctx.arc(0, 0, 60, 0, Math.PI*2, true);
};
// or passing to fabric.Element options
new fabric.Element('myCanvas', {
clipTo: function(ctx) {
ctx.arc(0, 0, 60, 0, Math.PI*2, true);
}
});
You can remove all objects on canvas using "shortcut" method clear()
of fabric.Element
instance:
canvas.clear(); // removes all objects and redraws a canvas area
You can remove individual objects using remove()
method of fabric.Element
instance. Note that remove
accepts a reference to an object in question.
canvas.remove(myRect);
To remove a group, walk through each object in a group and manually remove it from canvas.
if (canvas.getActiveGroup()) {
canvas.getActiveGroup().forEachObject(function(a) {
canvas.remove(a);
});
canvas.discardActiveGroup();
}
It's likely that font file was not included. See wiki article on how to render text.
By changing canvas selection
property:
canvas.selection = false;
Increase the padding
property, which in turn enlarges the bounding box:
circle.set('padding', 10);