防止在 kineticJS 阶段右键单击默认上下文菜单?

Posted

技术标签:

【中文标题】防止在 kineticJS 阶段右键单击默认上下文菜单?【英文标题】:Prevent default context menu in kinetic JS stage rightclick? 【发布时间】:2013-07-21 22:08:04 【问题描述】:

我需要在点击舞台时禁用动力学 js 中的上下文菜单。我已经尝试了event.preventDefault()cancelbubbleevent.stopPropagation() return false 之类的所有方法,但没有任何效果..

这是 jsfiddle 中的一个示例。需要更改 Wat 以防止显示默认上下文菜单

stage.on('click',stageClicked,true);
function stageClicked(event)
   if(event.button==2)
       event.cancelBubble = true;
       event.preventDefault();
           event.stopPropagation();

       return false;
   

http://jsfiddle.net/xPbgf/

【问题讨论】:

【参考方案1】:

以上答案删除了上下文菜单,但不允许@user2045685 在右键单击时选择event.targetNode

@user2045685 在他的 cmets 中指出,他通过使用 getAllIntersection 方法找到了解决方法,但我敦促您不要使用该替代方法,因为这不是它的用途,@987654325 @ 方法的性能非常,使用 event.targetNode 效果很好。

getAllIntersections(pos)

获取与点相交的所有形状。 注意:由于此方法必须清除一个临时画布并重新绘制容器内的每个形状,因此只能在特殊情况下使用它,因为它的性能很差。请尽可能使用 Kinetic.Stage#getIntersection 方法,因为它的性能要好得多

来源:Kinetic.Container#getAllIntersections

相反,您可以将事件侦听器绑定到您的 div#container 并调用 event.preventDefault() 以禁用上下文菜单。

document.getElementById("container").addEventListener('contextmenu', function (event) 
  event.preventDefault();
);

您还需要添加一个具有舞台宽度和高度的“背景矩形”,以便图层能够检测到您的点击。这就是为什么在上面@Brandon Boone 的回答中,他说“on 似乎没有做任何事情”。为舞台。 KineticJS 需要一个节点来监听事件,所以如果你不添加“透明背景”,那么stage.on("click") 只会在你右键单击绿色矩形时触发(而不是舞台的其余部分)。

var bg = new Kinetic.Rect(
  width: stage.getWidth(),
  height: stage.getHeight()
);

// add bg first as your transparent background
layer.add(bg);
// add the shape to the layer
layer.add(rect);

现在您可以毫无问题地使用您的stage.on('click', stgClicked) 函数并在您的stgClicked 函数中调用event.targetNode

function stgClicked(event) 
  if (event.button == 2) 
     alert('rightclick');
     var node = event.targetNode;
     console.log(node);
  

JSfiddle

【讨论】:

【参考方案2】:

看起来您需要在舞台对象中找到画布引用并将contextmenu 事件直接附加到它,因为将其传递给on 似乎没有任何作用。

试试这个:

Live Demo

var canvas = stage.content.childNodes[0]; 
if (canvas.addEventListener) 
    canvas.addEventListener('contextmenu', stgClicked, false); 
 else if (canvas.attachEvent)  
    canvas.attachEvent('oncontextmenu', stgClicked);


如果您想要 targetNode,只需在本机 javascript 事件中检查它。

function stgClicked(event)
    var targetNode;
    if (event.srcElement)  targetNode = event.srcElement;
    else if (event.target) targetNode = event.target;

    alert(targetNode.nodeName);

【讨论】:

但这不会让我将动态 js 事件返回到我的 stgClicked 函数,在该函数中我将使用 event.targetNode 来获取它被右键单击的确切形状... 我的意思是目标节点作为正在点击的动力学形状。在这种情况下,如果我右键单击它上面的矩形。我应该将目标节点作为 Kinetic.Rect 对象及其所有我可以访问的属性..通过将事件传递给动力学js的getAllIntersection方法以获取低于当前鼠标位置的形状,我找到了另一种方法..但这不是那么准确... 请不要使用getAllIntersection方法来选择你的targetNode!请参阅下面的答案。

以上是关于防止在 kineticJS 阶段右键单击默认上下文菜单?的主要内容,如果未能解决你的问题,请参考以下文章

防止圆在 KineticJS 中闪烁

Angular6默认上下文菜单

在 KineticJS 中按类名从阶段获取多个对象

防止在 Safari 浏览器中单击鼠标右键

Kineticjs 停止渲染

JavaScript 防止用户右键单击图像