google map,获取触摸点时 getZoomControls 与OnTouchListener冲突问题

本文介绍了解决Google Map中触摸事件与内置缩放控件冲突的问题。通过使用已废弃的API方法而非设置内置缩放控件,可以在保留缩放图标的同时,确保触摸事件正常触发。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

正文转自

http://384444165.javaeye.com/blog/779501

--------------------------------------------------------------------

google map,获取触摸点时 getZoomControls 与OnTouchListener冲突问题

文章分类:移动开发

今天在只有MapView的MapActivity页面使用View.OnTouchListener()遇到个问题,就是在模拟器中点击鼠标没有反应。

经过一段时间的琢磨才发现问题所在,
因为在程序中使用了map.setBuiltInZoomControls(true);
语句添加缩放图标(这里需要说明1.5之前的版本不是这样所的,之前的方法已经过期,但是下面我们要说到)

这里说一下原因
我们先来看一下鼠标按键所引起的时间顺序

当鼠标键按下时(即触摸)

首先触发dispatchTouchEvent
然后触发onUserInteraction
再次onTouchEvent
如果是点击的话,紧跟着下列事件(点击分俩步,ACTION_DOWN,ACTION_up)
触发dispatchTouchEvent
再次onTouchEvent
当ACTION_up事件时不会触发onUserInteraction(可查看源代码)

所以这时候你在页面继承OnDispathTouchEvent输出测试信息,会发现不仅仅OnTouch的事件不被触发,而且缩放的图标也无响 应。再返过头来你会发现不论点击那里都是会引起缩放图标的显示。本来可以不引入缩放标志,但是从界面上来讲google自带的缩放标志比自己做的 button美观也方便,但是这里原因其实很明显了,缩放图标的事件肯定阻止住了OnTouch事件,这里我想到解决办法是利用过期的API中的 map.getZoomControls()方法

Java代码 收藏代码
  1. public class ShowState extends MapActivity{
  2. private static final StringTAG= "ShowTrack" ;
  3. @Override
  4. protected boolean isRouteDisplayed(){
  5. //TODOAuto-generatedmethodstub
  6. return false ;
  7. }
  8. @Override
  9. public void onCreate(BundlesavedInstanceState){
  10. super .onCreate(savedInstanceState);
  11. setContentView(R.layout.showstate);
  12. findViews();
  13. setupMap();
  14. }
  15. private MapViewmap;
  16. private MapControllermc;
  17. private ViewGroupzoom;
  18. /**
  19. *findthemapViewandcontroller
  20. *
  21. *@return
  22. */
  23. private void findViews(){
  24. Log.d(TAG,"findViews" );
  25. map=(MapView)findViewById(R.id.map);
  26. mc=map.getController();
  27. zoom=(ViewGroup)findViewById(R.id.zoom);
  28. zoom.addView(map.getZoomControls());
  29. }
  30. /**
  31. *settheviewofmap
  32. *
  33. *@return
  34. */
  35. private void setupMap(){
  36. GeoPointstationTest=new GeoPoint(( int )( 25.047192 * 1000000 ),( int )( 121.516981 * 1000000 ));
  37. map.setStreetView(true );
  38. //map.setBuiltInZoomControls(true);
  39. mc.setZoom(18 );
  40. mc.animateTo(stationTest);
  41. mc.setCenter(stationTest);
  42. map.setOnTouchListener(new View.OnTouchListener(){
  43. public boolean onTouch(Viewv,MotionEventevent){
  44. //TODOAuto-generatedmethodstub
  45. if (event.getAction()==MotionEvent.ACTION_DOWN){
  46. Log.d(TAG,"getthetouch" +event.getRawX()+ "" +event.getRawY());
  47. }
  48. return false ;
  49. }
  50. });
  51. }
  52. }
public class ShowState extends MapActivity{

	private static final String TAG = "ShowTrack";
	
	@Override
	protected boolean isRouteDisplayed() {
		// TODO Auto-generated method stub
		return false;
	}
	
	@Override
	public void onCreate(Bundle savedInstanceState) {
	    super.onCreate(savedInstanceState);
	    setContentView(R.layout.showstate);
	    findViews();
	    setupMap();
	}
	
	private MapView map;
	private MapController mc;
	private ViewGroup zoom;
	
	/**
	 * find the mapView and controller
	 * 
	 * @return
	 */
	private void findViews(){
		Log.d(TAG, "find Views");
		map=(MapView)findViewById(R.id.map);
		mc=map.getController();
		
		zoom=(ViewGroup)findViewById(R.id.zoom);
		zoom.addView(map.getZoomControls());
	}
	
	/**
	 * set the view of map
	 * 
	 * @return
	 */
	private void setupMap(){
		GeoPoint stationTest=new GeoPoint((int)(25.047192*1000000) ,(int)(121.516981*1000000));
        
		map.setStreetView(true);
        // map.setBuiltInZoomControls(true);
       
        mc.setZoom(18);
        mc.animateTo(stationTest);
        mc.setCenter(stationTest);

        map.setOnTouchListener(new View.OnTouchListener() {
			
			public boolean onTouch(View v, MotionEvent event) {
				// TODO Auto-generated method stub
				if(event.getAction()==MotionEvent.ACTION_DOWN){
					Log.d(TAG, "get the touch "+event.getRawX()+" "+event.getRawY());
				}
				
				return false;
			}
		});        
	}
}


xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">

<view android:id="@+id/map"
class="com.google.android.maps.MapView"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_weight="1"
android:apiKey="*****"
android:clickable="true"
/>

<LinearLayout
android:id="@+id/zoom"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
/>

</RelativeLayout>


这样很好的实现了需要的功能,可以实现在map里获取触摸点并且显示出缩放按钮,而且在点击缩放按钮的时候不会触发捕捉的事件。
我想这是很有用处的,map里面的OnTouch存在的这个问题会影响到我们的使用。还有OnTouchListener必须用map调用,在类里重写方法也会被阻塞。虽然很好的解决了,但是用了过期的API,希望有更好的解决办法!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值