4
Is there any way to repeat the pattern inside an object in fabric JS.

Suppose i have a rectangle filled with a pattern. I want the pattern to be repeated when i scale the rectangle.

Right now it is zooming when i scale it.

Thanks

user2571818
  • 273
  • 4
  • 9
  • 2
    There's no built-in support for this at the moment, but as a workaround, you should be able to change source image dimensions when resizing an object. Take a look at http://fabricjs.com/dynamic-patterns/ – kangax Sep 11 '13 at 21:57
  • if i use object scaling method to capture the width of the object while re sizing it, i am unable to get the width values properly. I have clicked on the mouse and re size the object to certain position and i releases the mouse,it is displaying the same value on these actions. On the next click only i am getting new values. Code Sample Code: canvas.on('object:scaling',function(evt){ console.log(evt.target.currentWidth,evt.target.currentHeight); }); – user2571818 Sep 12 '13 at 06:38
  • 1
    You should be checking `evt.target.scaleX` & `evt.target.scaleY` instead – kangax Sep 12 '13 at 08:55

1 Answers1

3

@user2571818 I was also looking for this and finally got it working. We'll have to use object:scaling event to scale the object back to 1x and change size of the object instead to make the pattern repeat instead of scaling it. See it here

var canvas = new fabric.Canvas('c');
fabric.Object.prototype.transparentCorners = false;

  var padding = 0;

  fabric.Image.fromURL('', function(img) {

    img.scaleToWidth(50);
    var patternSourceCanvas = new fabric.StaticCanvas();
    patternSourceCanvas.add(img);
    patternSourceCanvas.renderAll();
    var pattern = new fabric.Pattern({
      source: function() {
        patternSourceCanvas.setDimensions({
          width: img.getScaledWidth() + padding,
          height: img.getScaledHeight() + padding
        });
        patternSourceCanvas.renderAll();
        return patternSourceCanvas.getElement();
      },
      repeat: 'repeat'
    }); 

    var rect = new fabric.Rect({
        width: 250,
        height: 250,
        fill: pattern,
        objectCaching: false
    });

    canvas.add(rect);
    rect.center().setCoords();

 });



canvas.on('object:scaling', function(e) {
  if (e.target != null) {
    console.log(e.target);
    var obj = e.target;
        var height = obj.height * obj.scaleY;
        var width = obj.width * obj.scaleX;
        obj.height = height;
        obj.width = width;
        obj.scaleX = 1;
        obj.scaleY = 1;
  }
});

JSFiddle: https://jsfiddle.net/dotriz/ajsdmg4s/

Riz
  • 6,746
  • 16
  • 67
  • 89