1

我们最近添加了jointjs 的突出显示功能,以向用户显示当前突出显示和选择了哪些cellView。但是,如果用户在外部单击,我们希望取消突出显示在纸上绘制的所有 cellView(s)。在调查了官方文档之后,我们最终无法找到满足我们要求的解决方案。

突出显示 cellView(s) 的代码是:

this.paper.on('cell:pointerclick', (cellView: any) => {
    cellView.highlight();
});
4

1 回答 1

5

为了解决这个问题,我们遍历当前论文(区域)上显示的所有 cellViews 并调用 unhighlight 函数。此逻辑放置在blank:pointerdown回调中 - 以便我们处理实际单元视图之外的所有点击。

this.paper.on('blank:pointerdown', (evt, x, y) => {
               this.paper.findViewsInArea(this.paper.getArea()).forEach(cell => {
               cell.unhighlight();
             });
        });

希望这可以帮助。

于 2018-07-04T14:02:04.810 回答