上面的答案删除了上下文菜单,但不允许@user2045685 选择event.targetNode
右键单击。
@user2045685 在他的评论中指出,他通过使用该方法找到了解决getAllIntersection
方法,但我敦促您不要使用该替代方法,因为这不是它的目的,该getAllIntersection
方法性能非常差,并且使用event.targetNode
效果很好。
getAllIntersections(位置)
获取与点相交的所有形状。注意:因为这种方法必须清除一个临时画布并重新绘制容器内的每个形状,所以它应该只用于特殊情况,因为它的性能很差。请尽可能使用 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)
函数并在函数event.targetNode
内部stgClicked
调用。
function stgClicked(event) {
if (event.button == 2) {
alert('rightclick');
var node = event.targetNode;
console.log(node);
}
}
JSfiddle