使用Fabric.js以编程方式创建和选择组

eff*_*ffe 4 fabricjs

假设我有一个包含6个对象的画布和一个画布外的按钮.

当我单击此按钮时,其中3个对象将成为一个组并被选中,对象将保持其相对于画布的位置.

那可能吗?

我尝试了很多东西,但可以管理它.我正在寻找的解决方案如下所示.

var objectList=[1,2,3];    
var newgroup = new fabric.Group();

$.each(objectList, function (i) {
    var obj = canvas.item(i);
    newgroup.add(obj.clone());
    canvas.remove(obj);
});

canvas.add(newgroup)
canvas.setActiveGroup(newgroup);
canvas.renderAll();
Run Code Online (Sandbox Code Playgroud)

Kie*_*enz 8

你可以使用这样的东西:

(function() {
  var objectList = [1,2,3],
      group = new fabric.Group();

  canvas.forEachObject(function(o, i) {
    if (objectList.indexOf(i) > -1) {
      group.addWithUpdate(o);
      canvas.remove(o);
    }
  });
  canvas.setActiveObject(group);
  canvas.add(group);
})();
Run Code Online (Sandbox Code Playgroud)

仅将索引1,2或3处的对象添加到组中.