第三方---百度地图的使用

1.实现显示(官方的api其实很详细,按照步骤就可以了,看不懂的可以去看官方的介绍)


1.首先把样板包里的,libs粘贴(注意v4包的使用),图片drawable-hdpi的粘贴,assets粘贴


2.在百度地图申请key值,

3.添加密钥

                 

<application>  
    <meta-data  
        android:name="com.baidu.lbsapi.API_KEY"  
        android:value="开发者 key" />  
</application>

4. 添加权限


<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />
<uses-permission android:name="android.permission.WAKE_LOCK"/>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.GET_TASKS" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_SETTINGS" />

5.在其中添加布局

<com.baidu.mapapi.map.MapView  
    android:id="@+id/bmapView"  
    android:layout_width="fill_parent"  
    android:layout_height="fill_parent"  
    android:clickable="true" />

6.最好创建一个application 在oncreat时添加配置, 记得改变mainfest的配置

//在使用SDK各组件之前初始化context信息,传入ApplicationContext  
        //注意该方法要再setContentView方法之前实现  
        SDKInitializer.initialize(getApplicationContext());  

7.主界面需要的东西,注意生命周期要销毁

MapView mMapView = null;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		// 在使用SDK各组件之前初始化context信息,传入ApplicationContext
		setContentView(R.layout.activity_main);
		// 获取地图控件引用
		mMapView = (MapView) findViewById(R.id.bmapView);
	}

	@Override
	protected void onDestroy() {
		super.onDestroy();
		// 在activity执行onDestroy时执行mMapView.onDestroy(),实现地图生命周期管理
		mMapView.onDestroy();
	}

	@Override
	protected void onResume() {
		super.onResume();
		// 在activity执行onResume时执行mMapView. onResume (),实现地图生命周期管理
		mMapView.onResume();
	}

	@Override
	protected void onPause() {
		super.onPause();
		// 在activity执行onPause时执行mMapView. onPause (),实现地图生命周期管理
		mMapView.onPause();
	}

2.在地图上添加标记


确认已经可以显示百度地图

1.添加新的变量, 注意这个变量也要加载在activity销毁是销毁

// 获得图层 mbaidumap
		mBaiduMap = mMapView.getMap();  

2.添加标记的方法

private void addMarker() {

		// 定义Maker坐标点
		LatLng point = new LatLng(39.963175, 116.400244);
		// 构建Marker图标
		BitmapDescriptor bitmap = BitmapDescriptorFactory
				.fromResource(R.drawable.icon_marka);
		// 构建MarkerOption,用于在地图上添加Marker
		OverlayOptions option = new MarkerOptions().position(point)
				.icon(bitmap);
		// 在地图上添加Marker,并显示
		mBaiduMap.addOverlay(option);
	}

3.点击后弹出框的方法

private void addmMapViewListener() {
		mBaiduMap.setOnMarkerClickListener(new OnMarkerClickListener() {

			@Override
			public boolean onMarkerClick(Marker arg0) {
				// 创建InfoWindow展示的view
				Button button = new Button(getApplicationContext());
				button.setBackgroundResource(R.drawable.popup);
				// 定义用于显示该InfoWindow的坐标点
				LatLng pt = new LatLng(arg0.getPosition().latitude, arg0
						.getPosition().longitude);
				// 创建InfoWindow , 传入 view, 地理坐标, y 轴偏移量
				InfoWindow mInfoWindow = new InfoWindow(button, pt, -47);
				// 显示InfoWindow
				mBaiduMap.showInfoWindow(mInfoWindow);
				// mBaiduMap.hideInfoWindow();// 隐藏方法
				return false;
			}
		});
	}

3.定位  Log显示

标题1的配置已完成-----导入定位的包 确认已经显示

添加服务

<service android:name="com.baidu.location.f" android:enabled="true" android:process=":remote">
</service>
添加权限

<!-- 这个权限用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"></uses-permission>
<!-- 这个权限用于访问GPS定位-->
<uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"></uses-permission>
<!-- 用于访问wifi网络信息,wifi信息会用于进行网络定位-->
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"></uses-permission>
<!-- 获取运营商信息,用于支持提供运营商信息相关的接口-->
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"></uses-permission>
<!-- 这个权限用于获取wifi的获取权限,wifi信息会用来进行网络定位-->
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"></uses-permission>
<!-- 用于读取手机当前的状态-->
<uses-permission android:name="android.permission.READ_PHONE_STATE"></uses-permission>
<!-- 写入扩展存储,向扩展卡写入数据,用于写入离线定位数据-->
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
<!-- 访问网络,网络定位需要上网-->
<uses-permission android:name="android.permission.INTERNET" />
<!-- SD卡读取权限,用户写入离线定位数据-->
<uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"></uses-permission>

导入相关的类

import com.baidu.location.BDLocation;
import com.baidu.location.BDLocationListener;
import com.baidu.location.LocationClient;
import com.baidu.location.LocationClientOption;
import com.baidu.location.BDNotifyListener;//假如用到位置提醒功能,需要import该类
import com.baidu.location.Poi;

添加变量

public LocationClient mLocationClient = null;
public BDLocationListener myListener = new MyLocationListener();

在相关的oncreat方法里获得对象

// 定位的使用
		mLocationClient = new LocationClient(getApplicationContext()); // 声明LocationClient类
		mLocationClient.registerLocationListener(myListener); // 注册监听函数
		initLocation();

// 写出相关的方法 这里导包是导入短的那个包

// 定位的使用
	private void initLocation() {
		LocationClientOption option = new LocationClientOption();
		option.setLocationMode(LocationMode.Hight_Accuracy);// 可选,默认高精度,设置定位模式,高精度,低功耗,仅设备
		option.setCoorType("bd09ll");// 可选,默认gcj02,设置返回的定位结果坐标系
		int span = 1000;
		option.setScanSpan(span);// 可选,默认0,即仅定位一次,设置发起定位请求的间隔需要大于等于1000ms才是有效的
		option.setIsNeedAddress(true);// 可选,设置是否需要地址信息,默认不需要
		option.setOpenGps(true);// 可选,默认false,设置是否使用gps
		option.setLocationNotify(true);// 可选,默认false,设置是否当gps有效时按照1S1次频率输出GPS结果
		option.setIsNeedLocationDescribe(true);// 可选,默认false,设置是否需要位置语义化结果,可以在BDLocation.getLocationDescribe里得到,结果类似于“在北京天安门附近”
		option.setIsNeedLocationPoiList(true);// 可选,默认false,设置是否需要POI结果,可以在BDLocation.getPoiList里得到
		option.setIgnoreKillProcess(false);// 可选,默认true,定位SDK内部是一个SERVICE,并放到了独立进程,设置是否在stop的时候杀死这个进程,默认不杀死
		option.SetIgnoreCacheException(false);// 可选,默认false,设置是否收集CRASH信息,默认收集
		option.setEnableSimulateGps(false);// 可选,默认false,设置是否需要过滤gps仿真结果,默认需要
		mLocationClient.setLocOption(option);
		mLocationClient.start();
		//mLocationClient.stop();// 关闭定位
	}

//写一个内部类就是接口

public class MyLocationListener implements BDLocationListener {

		@Override
		public void onReceiveLocation(BDLocation location) {
			// Receive Location
			StringBuffer sb = new StringBuffer(256);
			sb.append("time : ");
			sb.append(location.getTime());
			sb.append("\nerror code : ");
			sb.append(location.getLocType());
			sb.append("\nlatitude : ");
			sb.append(location.getLatitude());
			sb.append("\nlontitude : ");
			sb.append(location.getLongitude());
			sb.append("\nradius : ");
			sb.append(location.getRadius());
			if (location.getLocType() == BDLocation.TypeGpsLocation) {// GPS定位结果
				sb.append("\nspeed : ");
				sb.append(location.getSpeed());// 单位:公里每小时
				sb.append("\nsatellite : ");
				sb.append(location.getSatelliteNumber());
				sb.append("\nheight : ");
				sb.append(location.getAltitude());// 单位:米
				sb.append("\ndirection : ");
				sb.append(location.getDirection());// 单位度
				sb.append("\naddr : ");
				sb.append(location.getAddrStr());
				sb.append("\ndescribe : ");
				sb.append("gps定位成功");

			} else if (location.getLocType() == BDLocation.TypeNetWorkLocation) {// 网络定位结果
				sb.append("\naddr : ");
				sb.append(location.getAddrStr());
				// 运营商信息
				sb.append("\noperationers : ");
				sb.append(location.getOperators());
				sb.append("\ndescribe : ");
				sb.append("网络定位成功");
			} else if (location.getLocType() == BDLocation.TypeOffLineLocation) {// 离线定位结果
				sb.append("\ndescribe : ");
				sb.append("离线定位成功,离线定位结果也是有效的");
			} else if (location.getLocType() == BDLocation.TypeServerError) {
				sb.append("\ndescribe : ");
				sb.append("服务端网络定位失败,可以反馈IMEI号和大体定位时间到loc-bugs@baidu.com,会有人追查原因");
			} else if (location.getLocType() == BDLocation.TypeNetWorkException) {
				sb.append("\ndescribe : ");
				sb.append("网络不同导致定位失败,请检查网络是否通畅");
			} else if (location.getLocType() == BDLocation.TypeCriteriaException) {
				sb.append("\ndescribe : ");
				sb.append("无法获取有效定位依据导致定位失败,一般是由于手机的原因,处于飞行模式下一般会造成这种结果,可以试着重启手机");
			}
			sb.append("\nlocationdescribe : ");
			sb.append(location.getLocationDescribe());// 位置语义化信息
			List<Poi> list = location.getPoiList();// POI数据
			if (list != null) {
				sb.append("\npoilist size = : ");
				sb.append(list.size());
				for (Poi p : list) {
					sb.append("\npoi= : ");
					sb.append(p.getId() + " " + p.getName() + " " + p.getRank());
				}
			}
			Log.i("BaiduLocationApiDem", sb.toString());
		}
	}


4.定位出自己的具体位置   在地图上显示

确保显示地图 ,确保 定位的包已导入mainfest里边的配置已经配之完毕  参见   1.显示 3.定位

找到BaiduMapsApiDemo/src/baidumapsdk/demo/map/LocationDemo.java,在里边查找代码添加

粘贴定位相关的变量
  // 定位相关
    LocationClient mLocClient;
    public MyLocationListenner myListener = new MyLocationListenner();
    private com.baidu.mapapi.map.MyLocationConfiguration.LocationMode mCurrentMode;// 注意这里的导包,是这个包
    BitmapDescriptor mCurrentMarker;
  // ui相关
	boolean isFirstLoc = true; // 是否首次定位

在oncreat方法里

// 这里是从原demo中的图标设置来实现的

	  // 传入null则,恢复默认图标
        mCurrentMarker = null;
        mBaiduMap
                .setMyLocationConfigeration(new MyLocationConfiguration(
                        mCurrentMode, true, null));

	这里其实上边如果操作 就已经显示了
 	// 地图初始化
        mMapView = (MapView) findViewById(R.id.bmapView);
        mBaiduMap = mMapView.getMap();
	

	 // 开启定位图层
        mBaiduMap.setMyLocationEnabled(true);
        // 定位初始化
        mLocClient = new LocationClient(this);
        mLocClient.registerLocationListener(myListener);
        LocationClientOption option = new LocationClientOption();
        option.setOpenGps(true); // 打开gps
        option.setCoorType("bd09ll"); // 设置坐标类型
        option.setScanSpan(1000);
        mLocClient.setLocOption(option);
        mLocClient.start();

粘贴进去一个内部类 注意 原api中少了一个}大括号 切记 切记

	 /**
     * 定位SDK监听函数
     */
    public class MyLocationListenner implements BDLocationListener {

        @Override
        public void onReceiveLocation(BDLocation location) {
            // map view 销毁后不在处理新接收的位置
            if (location == null || mMapView == null) {
                return;
            }
            MyLocationData locData = new MyLocationData.Builder()
                    .accuracy(location.getRadius())
                            // 此处设置开发者获取到的方向信息,顺时针0-360
                    .direction(100).latitude(location.getLatitude())
                    .longitude(location.getLongitude()).build();
            mBaiduMap.setMyLocationData(locData);
            if (isFirstLoc) {
                isFirstLoc = false;
                LatLng ll = new LatLng(location.getLatitude(),
                        location.getLongitude());
                MapStatus.Builder builder = new MapStatus.Builder();
                builder.target(ll).zoom(18.0f);
                mBaiduMap.animateMapStatus(MapStatusUpdateFactory.newMapStatus(builder.build()));
            }
        }

        public void onReceivePoi(BDLocation poiLocation) {
        }
    }

最后注意构造方法中改注意销毁图层

销毁方法中 
	 // 退出时销毁定位
        mLocClient.stop();
        // 关闭定位图层
        mBaiduMap.setMyLocationEnabled(false);
        mMapView.onDestroy();
        mMapView = null;




Poi搜索功能 就是搜索北京地区的  餐厅 (在某个坐标 的半径为500米的范围内)

确认1.导包,权限 通常不需要定位。如果需要定位,那么 3的定位和权限也是需要的

找到类 /BaiduMapsApiDemo/src/baidumapsdk/demo/search/PoiSearchDemo.java    对应的 布局  activity_poisearch.xml    在mainfest里边添加活动权限

 找到类 /BaiduMapsApiDemo/src/com/baidu/mapapi/overlayutil/PoiOverlay.java
             /BaiduMapsApiDemo/src/com/baidu/mapapi/overlayutil/OverlayManager.java


说明

其中activity中 170行左右searchButtonProcess(View v)方法是响应点击搜索的事件里边的

        String citystr = editCity.getText().toString();// 获得城市
        String keystr = keyWorldsView.getText().toString();// 获得关键字

 这两个参数是从 前台的EditText 获得的数值 ,可以自己设置或者 在跳转时传值 ,然后获得传递过来的值 赋值给 这两个变量就可以了


在190行左右 有方法searchNearbyProcess(View v) 没有使用 ,如果调用 是会在某个圆形区域内搜索
    参数 LatLng southwest = new LatLng(39.92235, 116.380338) 是圆心的位置
    参数 int radius = 500;是圆的半径 默认500米
都是可以改变的

210行 左右 searchBoundProcess(View v)是 矩形区域内搜索,searchbound是规定 矩形的 对角线


路径规划功能


/BaiduMapsApiDemo/src/baidumapsdk/demo/search/RoutePlanDemo.java                    对应的layout 对应的activity_routeplan         对应的图片 pre  next               对应的color
    /BaiduMapsApiDemo/src/com/baidu/mapapi/overlayutil/OverlayManager.java
    /BaiduMapsApiDemo/src/com/baidu/mapapi/overlayutil/WalkingRouteOverlay.java
/BaiduMapsApiDemo/src/baidumapsdk/demo/search/RouteLineAdapter.java                   对应的 activity_transit_item .xml  activity_transit_dialog.xml  以及最后的
/BaiduMapsApiDemo/src/com/baidu/mapapi/overlayutil/TransitRouteOverlay.java
/BaiduMapsApiDemo/src/com/baidu/mapapi/overlayutil/DrivingRouteOverlay.java


95行 左右方法 searchButtonProcess();  是一下  ,可以自己改变

// 处理搜索按钮响应
		EditText editSt = (EditText) findViewById(R.id.start);
		EditText editEn = (EditText) findViewById(R.id.end);
然后自动根据id来判断是驾车?步行?自行车?公交?来判断



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值