在FabricJS中,如何确定在单击鼠标的坐标处重叠的一组对象?

时间:2019-01-07 14:44:45

标签: javascript html5-canvas fabricjs

我需要能够迭代一组对象,这些对象在单击鼠标的坐标处相互重叠。作为后续,我将使用BringToFront,然后基于该对象显示一个漂亮的菜单,但是我不确定如何识别和迭代对象集。

1 个答案:

答案 0 :(得分:0)

我的特定需求是通过按Tab键设置活动对象/组来遍历一组重叠的对象。以下是我的工作:

var stackArray = new Array();

canvas.on('mouse:down', function(e){
    var subobj = canvas.getObjects();
    stackArray = [];
    for (var i=0;i<subobj.length;i++) {
        if (subobj[i].id != '' && typeof(subobj[i].id) != 'undefined' && subobj[i].id != 'navpanel' && subobj[i].id != 'header') {

            if (e.target!=null && typeof(e.target.id) != 'undefined') {
                if (subobj[i].intersectsWithObject(canvas.getActiveObject()) && subobj[i].id != e.target.id) {
                    stackArray.push(subobj[i]);
                } else if (subobj[i].id == e.target.id) {
                    stackArray.push(subobj[i]);
                }
            }
        }
    }
});

...

e.preventDefault();
switch(e.keyCode){
    case 9: // tab
        if (stackArray.length > 1) {
            fillObj(canvas.getActiveObject(),'inactive');
            canvas.getActiveObject().sendToBack();

            canvas.setActiveObject(stackArray[stackArray.length-1]);
            fillObj(canvas.getActiveObject(),'active');

            stackArray.splice(0, 0, stackArray.splice(stackArray.length-1,1)[0]);
        }
        break;
}

function fillObj(obj,mode) {
    if (obj.type == 'group') {
        obj = obj.item(0);
    }

    if (mode == 'active') {
        obj.set('fill', 'red');
        obj.set('strokeWidth', 1);
        obj.set('shadow','rgba(0,0,0,0.5) 5px 5px 15px');
    } else if (mode == 'inactive') {
        obj.set('fill', '#333');
        obj.set('strokeWidth', 0);
        obj.set('shadow','');    
    }
}