6

我在地图上有一个要绑定两个事件的标记:

  1. 点击
  2. dblclick

我想做以下事情:

  1. 当用户单击标记时,地图应放大并显示更详细的地图。
  2. 我想将“dblclick”事件绑定到同一个标记,以便它将在相邻的“div”元素中加载一些第三方报告。

换句话说,我希望它在用户单击或 dblclicks 时表现不同。但问题是,当我将这两个事件绑定到标记并且用户“双击”标记时,“单击”处理程序被触发,我不想让它发生。

是否真的,当用户双击时,点击事件也会被触发?如果是这样,当用户实际双击时如何防止它触发“点击”事件?有什么办法可以让我在标记的单击和双击事件上做不同的事情?

4

2 回答 2

4

这是 api 的已知细微差别,您需要安装点击计数器超时,如下所示:

function createMap2() {
  var infoWindow = new google.maps.InfoWindow();
  var map = new google.maps.Map(document.getElementById("map2"), myOptions); 

  var doubleClicked=false;
  var clickEvent;

  google.maps.event.addListener(map, 'dblclick', function(event) { 
    doubleClicked=true;
  }); 

  function handleClick() {
    if (!doubleClicked) {
      infoWindow.setPosition(clickEvent.latLng);
      infoWindow.setContent(createInfo(clickEvent));
      infoWindow.open(map);
    }
  }

  google.maps.event.addListener(map, 'click', function(event) { 
    clickEvent = event;
    doubleClicked = false;
    window.setTimeout(handleClick, 250);
  }); 
}

以上代码摘自http://www.william-map.com/20100506/1/v3click.htm

查看这些链接以获取更多信息:

https://groups.google.com/forum/?fromgroups=#!topic/google-maps-js-api-v3/YRAvYHngeNk https://groups.google.com/forum/?fromgroups=#!topic/google -maps-js-api-v3/2MomDiLMEiw

于 2012-12-13T12:49:27.973 回答
0

您可以使用将单击与双击分开的预处理函数。在这种情况下,第二次点击必须在第一次点击的 500 毫秒内发生:

//Global vars
var G = google.maps;
var clickTimeOut = null;

G.event.addListener(marker,'click',mClick);


function mClick(mev) {
    if (clickTimeOut) {
        window.clearTimeout(clickTimeOut);
        clickTimeOut = null;
        doubleClick(mev);
    }
    else {
        clickTimeOut = window.setTimeout(function(){singleClick(mev)},500);
    }
}

function doubleClick(mev) {
    // handle double click here
}

function singleClick(mev) {
    window.clearTimeout(clckTimeOut);
    clickTimeOut = null;
    // handle single click here
}

mev 是事件处理程序作为参数接收的mouseEvent 对象。

于 2012-12-13T15:15:28.997 回答