Fabric JS - send Objects to Back

前端 未结 2 2030
忘掉有多难
忘掉有多难 2021-01-04 23:27

When you select an object (in my example a polygon), it gets automatically moved to the Front. I\'m searching for a way to prevent the movement on the z-axis or send it back

2条回答
  •  离开以前
    2021-01-04 23:29

    Ok so this is happening because of the Fabric version you are using. In fiddle as i can see you have use version0.9. So it seems to be the default behaviour that whenever an object is selected its z-index is changed such that its on the top/front. Try using a later version. In other versions this issue is not there if an object is at the back it remains at the back even if you select it. Here is a the demo with a later version(1.4.0). Here whenever you select the object it will be moved backwards. And if you comment out the sending backwards code it will remain in front if in front and at the back if at the back.

    var canvas  = new fabric.Canvas('c');
    
    var pol = new fabric.Polygon([
      {x: 200, y: 0},
      {x: 250, y: 50},
      {x: 250, y: 100},
      {x: 150, y: 100},
      {x: 150, y: 50} ], {
        left: 250,
        top: 150,
        angle: 0,
        fill: 'green'
      }
    );
    
    var pol2 = new fabric.Polygon([
      {x: 200, y: 50},
      {x: 200, y: 100},
      {x: 100, y: 100},
      {x: 100, y: 50} ], {
        left: 300,
        top: 200,
        angle: 0,
        fill: 'blue'
      }
    );
    canvas.add(pol, pol2);
    
    canvas.on('object:selected', function(event) {
            var object = event.target;
            canvas.sendToBack(object);
            //object.sendToBack();
            console.log("Selected");
      });
      
    
    

提交回复
热议问题