Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/design-patterns/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Design patterns fabric JS中对象缩放的模式重复_Design Patterns_Html5 Canvas_Repeat_Fabricjs_Tiling - Fatal编程技术网

Design patterns fabric JS中对象缩放的模式重复

Design patterns fabric JS中对象缩放的模式重复,design-patterns,html5-canvas,repeat,fabricjs,tiling,Design Patterns,Html5 Canvas,Repeat,Fabricjs,Tiling,假设我有一个填充了图案的矩形。我希望在缩放矩形时重复该图案 现在,当我缩放它时,它正在缩放 谢谢@user2571818我也在找这个,终于找到了。我们必须使用object:scaling事件将对象缩放回1x,并更改对象的大小,以使模式重复,而不是缩放。看到这里了吗 Is there any way to repeat the pattern inside an object in fabric JS. jsiddle:目前没有内置的支持,但作为一种解决方法,您应该能够在调整对象大小时更改源图像

假设我有一个填充了图案的矩形。我希望在缩放矩形时重复该图案

现在,当我缩放它时,它正在缩放


谢谢

@user2571818我也在找这个,终于找到了。我们必须使用
object:scaling
事件将对象缩放回1x,并更改对象的大小,以使模式重复,而不是缩放。看到这里了吗

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

jsiddle:

目前没有内置的支持,但作为一种解决方法,您应该能够在调整对象大小时更改源图像尺寸。请看一看,如果在重新调整对象大小时使用对象缩放方法捕获对象的宽度,则无法正确获取宽度值。我点击鼠标并将对象重新调整到某个位置,然后释放鼠标,它在这些动作上显示相同的值。在下一次单击“仅”时,我将获得新值。代码示例代码:canvas.on('object:scaling',function(evt){console.log(evt.target.currentWidth,evt.target.currentHeight);});您应该检查
evt.target.scaleX
&
evt.target.scaleY
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;
  }
});