0

有人知道如何创建将在 GMap 上右键单击时启动的 primefaces 上下文菜单吗?

通常,代码应如下所示:

<p:gmap id="gmapElement" widgetVar="gmtls" center="41.381542, 2.122893" zoom="15" type="hybrid" styleClass="mapClass"/>
<p:contextMenu for="gmapElement" >  
    <p:menuitem value="Method A" onclick="method1()" />  
    <p:menuitem value="Method B" onclick="method2()" />  
</p:contextMenu>  

但是,google api 会覆盖右键单击事件。我认为处理它的最佳方法是在谷歌地图中添加额外的侦听器。但我找不到任何信息如何以编程方式显示上下文菜单:

var mapComponent = gmtls.getMap();
google.maps.event.addListener(mapComponent, 'rightclick', function(mouseEvent) {
    //show context menu at coordinates: mouseEvent.latLng
});

有人可以告诉我应该在听众体内放什么吗?

4

1 回答 1

0

所以这就是我一直在寻找的答案。在初始化 GMap 组件期间,必须在 google maps API 中注册额外的侦听器:

var mapComponent = gmtls.getMap();
google.maps.event.addListener(mapComponent, 'rightclick', function(mouseEvent) {
    $(PrimeFaces.escapeClientId('mainForm:contextMenu')).css({
        top: yPos+'px',
        left: xPos+'px'                        
    }).show();
});

获取坐标(yPos、xPos)的最简单方法是使用监听 mouseMove 事件的 jQuery:

var xPos = 0;
var yPos = 0;
jQuery(document).ready(function(){
    $(document).mousemove(function(e){
        xPos = e.pageX;
        yPos = e.pageY;
    }); 
})
于 2013-05-27T10:02:42.823 回答