google map事件监听
2010-01-13 10:17
375 查看
事件类型
google地图定义了大量的事件来完成复杂的交互功能。每个事件都在指定的环境下发生,并且可以传递标识环境的参数。例如,当用户在地图对象中移动鼠标时,会触发 mousemove 事件,并且该事件会传递鼠标所在地理位置的 GLatLng。
google map常用的事件有
click、dblclick 鼠标点击事件
movestart、move、moveend 地图移动事件
dragstart、drag、dragend 鼠标拖拽地图事件
zoomstart、zoomend 地图缩放事件
maptypechanged 地图类型改变事件
事件监听
请使用静态方法 GEvent.addListener()。该方法有三个参数,一个对象,一个待监听事件以及一个在指定事件发生时调用的函数。
1 var map = new GMap2(document.getElementById("map"));
2 map.setCenter(new GLatLng(37.4419, -122.1419), 13);
3 GEvent.addListener(map, "click", function() { alert("You clicked the map."); });
移除事件监听的方法
在使用addListener添加的自定义事件注册事件处理程序,返回一个可用于最终注销处理程序的句柄。在使用removeListener方法移除此句柄。
1 var clickHandler = google.maps.Event.addListener(map, 'click', function(){
2 alert('click');
3 google.maps.Event.removeListener(clickHandler);
4 });
事件处理函数的参数
google map会未事件绑定函数传递必要的参数。例如,当用户在地图对象中移动鼠标时,会触发
1 GEvent.addListener(map,"click", function(overlay, latlng) {
2 if (latlng) {
3 var myHtml = "GPoint 为: " + map.fromLatLngToDivPixel(latlng) + ",
4 缩放级别:" + map.getZoom();
5 map.openInfoWindow(latlng, myHtml);
6 }
7 });
8
google地图定义了大量的事件来完成复杂的交互功能。每个事件都在指定的环境下发生,并且可以传递标识环境的参数。例如,当用户在地图对象中移动鼠标时,会触发 mousemove 事件,并且该事件会传递鼠标所在地理位置的 GLatLng。
google map常用的事件有
click、dblclick 鼠标点击事件
movestart、move、moveend 地图移动事件
dragstart、drag、dragend 鼠标拖拽地图事件
zoomstart、zoomend 地图缩放事件
maptypechanged 地图类型改变事件
事件监听
请使用静态方法 GEvent.addListener()。该方法有三个参数,一个对象,一个待监听事件以及一个在指定事件发生时调用的函数。
1 var map = new GMap2(document.getElementById("map"));
2 map.setCenter(new GLatLng(37.4419, -122.1419), 13);
3 GEvent.addListener(map, "click", function() { alert("You clicked the map."); });
移除事件监听的方法
在使用addListener添加的自定义事件注册事件处理程序,返回一个可用于最终注销处理程序的句柄。在使用removeListener方法移除此句柄。
1 var clickHandler = google.maps.Event.addListener(map, 'click', function(){
2 alert('click');
3 google.maps.Event.removeListener(clickHandler);
4 });
事件处理函数的参数
google map会未事件绑定函数传递必要的参数。例如,当用户在地图对象中移动鼠标时,会触发
mousemove事件,并且该事件会传递鼠标所在地理位置的
GLatLng。click事件中为事件传递点击的地图上显示自定义的叠加层对象overlay, 和地理位置坐标latlng。
1 GEvent.addListener(map,"click", function(overlay, latlng) {
2 if (latlng) {
3 var myHtml = "GPoint 为: " + map.fromLatLngToDivPixel(latlng) + ",
4 缩放级别:" + map.getZoom();
5 map.openInfoWindow(latlng, myHtml);
6 }
7 });
8
相关文章推荐
- unity3D 在UGUI中动态添加button的监听事件
- Unigine 监听键盘事件和模拟按键
- 在AS中动态监听控件事件
- JAVA之旅(三十一)——JAVA的图形化界面,GUI布局,Frame,GUI事件监听机制,Action事件,鼠标事件
- OnTouchListener事件监听实现方式之GestureDetector
- android EditText控件事件监听
- 关于JAVA中事件分发和监听机制实现的代码实例-绝对原创实用
- java基础 ---事件监听以及eclipse的安装
- Servlet事件监听器、监听servletContext域对象创建和销毁、监听三个域对象属性变化
- HTML5 storage事件监听
- Linux全局事件监听技术
- android事件监听回调机制
- 12-JS特效-事件监听原理
- 监听页面滚动的事件
- UGUI基于EventTrigger的UI交互事件监听系统&动态加载
- android监听文件和目录的创建删除移动等事件
- Activity中对“BACK”后退键后的事件监听处理,重写onKeyDown方法
- 【android基础学习之一】——事件的监听与触发
- 监听键盘的输入事件[转]
- 关于Servlet中的事件监听