android 百度地图定位开发2

先下载了示例代码

进行配置(可查看开发 指南 Hello BaiDuMap)

第一步:创建并配置工程(具体方法参见工程配置部分的介绍);

第二步:在AndroidManifest中添加开发密钥、所需权限等信息;

(1)在application中添加开发密钥

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

2)添加所需权限

"android.permission.ACCESS_NETWORK_STATE"/>
"android.permission.INTERNET"/>
"com.android.launcher.permission.READ_SETTINGS" />
"android.permission.WAKE_LOCK"/>
"android.permission.CHANGE_WIFI_STATE" />
"android.permission.ACCESS_WIFI_STATE" />
"android.permission.GET_TASKS" />
"android.permission.WRITE_EXTERNAL_STORAGE"/>
"android.permission.WRITE_SETTINGS" />
 

第三步,在布局xml文件中添加地图控件;

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

第四步,在应用程序创建时初始化 SDK引用的Context 全局变量:

public class MainActivity extends Activity {  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);   
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext  
        //注意该方法要再setContentView方法之前实现  
        SDKInitializer.initialize(getApplicationContext());  
        setContentView(R.layout.activity_main);  
    }  
}

注意:在SDK各功能组件使用之前都需要调用

SDKInitializer.initialize(getApplicationContext());,因此我们建议该方法放在Application的初始化方法中

第五步,创建地图Activity,管理地图生命周期;

public class MainActivity extends Activity {  
    MapView mMapView = null;  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);   
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext  
        //注意该方法要再setContentView方法之前实现  
        SDKInitializer.initialize(getApplicationContext());  
        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();  
        }  
    }

 

第一步,初始化LocationClient类

 

此处需要注意:LocationClient类必须在主线程中声明。需要Context类型的参数。

 

Context需要时全进程有效的context,推荐用getApplicationConext获取全进程有效的context

 

public LocationClient mLocationClient = null;
public BDLocationListener myListener = new MyLocationListener();
 
public void onCreate() {
    mLocationClient = new LocationClient(getApplicationContext());     //声明LocationClient类
    mLocationClient.registerLocationListener( myListener );    //注册监听函数

     initLocation();
     mLocationClient.start();


}
 
     

LocationClient类是定位SDK的核心类,具体方法详见类参考。

 

第二步,配置定位SDK参数

 

设置定位参数包括:定位模式(高精度定位模式,低功耗定位模式和仅用设备定位模式),返回坐标类型,是否打开GPS,是否返回地址信息、位置语义化信息、POI信息等等。

 

LocationClientOption类,该类用来设置定位SDK的定位方式,e.g.:

 

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);
    }

 

高精度定位模式:这种定位模式下,会同时使用网络定位和GPS定位,优先返回最高精度的定位结果;

 

低功耗定位模式:这种定位模式下,不会使用GPS,只会使用网络定位(Wi-Fi和基站定位);

 

仅用设备定位模式:这种定位模式下,不需要连接网络,只使用GPS进行定位,这种模式下不支持室内环境的定位。

 

第三步,实现BDLocationListener接口

BDLocationListener接口有1个方法需要实现: 1.接收异步返回的定位结果,参数是BDLocation类型参数。

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号和大体定位时间到[email protected],会有人追查原因");
            } 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 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());
        }
BDLocation类,封装了定位SDK的定位结果,在BDLocationListener的onReceive方法中获取。通过该类用户可以获取error code,位置的坐标,精度半径等信息。具体方法请参考类参考。

 

 

 

下面是我做的项目:

activity_main.xml

"http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

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

配置权限

AndroidManifest.xml

"1.0" encoding="utf-8"?>
"http://schemas.android.com/apk/res/android"
    package="com.bawei.baidumap"
    android:versionCode="1"
    android:versionName="1.0" >

    sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />
    

    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        
        
        
        <activity
            android:name="com.bawei.baidumap.MainActivity"
            android:label="@string/app_name" >
            
                "android.intent.action.MAIN" />

                "android.intent.category.LAUNCHER" />
            
        
          
        
    

注释:service 为百度定位时用到的

 导包  在示例代码里自己找

android 百度地图定位开发2_第1张图片

MainActivity.java     可参考示例代码BaiduMapsApiDemo\src\baidumapsdk\demo\LocationDemo.java

package com.bawei.baidumap;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.widget.Toast;

import com.baidu.location.BDLocation;
import com.baidu.location.BDLocationListener;
import com.baidu.location.LocationClient;
import com.baidu.location.LocationClientOption;
import com.baidu.mapapi.SDKInitializer;
import com.baidu.mapapi.map.BaiduMap;
import com.baidu.mapapi.map.BitmapDescriptor;
import com.baidu.mapapi.map.BitmapDescriptorFactory;
import com.baidu.mapapi.map.MapStatus;
import com.baidu.mapapi.map.MapStatusUpdateFactory;
import com.baidu.mapapi.map.MapView;
import com.baidu.mapapi.map.MarkerOptions;
import com.baidu.mapapi.map.MyLocationData;
import com.baidu.mapapi.map.OverlayOptions;
import com.baidu.mapapi.model.LatLng;

public class MainActivity extends Activity {

    private MapView mMapView;
    private BaiduMap mBaiduMap;
    private LocationClient mLocClient;
    public MyLocationListenner myListener = new MyLocationListenner();
      boolean isFirstLoc = true; // 是否首次定位
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        
        //在使用SDK各组件之前初始化context信息,传入ApplicationContext  
        //注意该方法要再setContentView方法之前实现  
         SDKInitializer.initialize(getApplicationContext());
         
        setContentView(R.layout.activity_main);
         // 地图初始化
        mMapView = (MapView) findViewById(R.id.bmapView);  
        mBaiduMap = mMapView.getMap(); 
    /*    // 实时交通图
        //开启交通图   
        mBaiduMap.setTrafficEnabled(true);
        
        
        //百度城市热力图
        mMapView = (MapView) findViewById(R.id.bmapView);  
        mBaiduMap = mMapView.getMap();  
        //开启交通图   
        mBaiduMap.setBaiduHeatMapEnabled(true);
        
        
        //地图标注
        //定义Maker坐标点  
        LatLng point = new LatLng(39.963175, 116.400244);  
        //构建Marker图标  
        BitmapDescriptor bitmap = BitmapDescriptorFactory  
            .fromResource(R.drawable.icon_marka);  
        //构建MarkerOption,用于在地图上添加Marker  
        OverlayOptions option1 = new MarkerOptions()  
            .position(point)  
            .icon(bitmap);  
        //在地图上添加Marker,并显示  
        mBaiduMap.addOverlay(option1); */
         
        /*
        *
        *百度定位
        *
        *
        */
        
        
         // 开启定位图层
        mBaiduMap.setMyLocationEnabled(true);
        // 定位初始化
        mLocClient = new LocationClient(this);
        //注册定位的监听
        mLocClient.registerLocationListener(myListener);
        //
        LocationClientOption option = new LocationClientOption();
        option.setOpenGps(true); // 打开gps
        option.setCoorType("bd09ll"); // 设置坐标类型
        option.setPriority(LocationClientOption.NetWorkFirst);//设置定位优先级 网络优先
        //判断是否需要定位当前地址
        option.setIsNeedAddress(true);
        //定位间隔时间
        option.setScanSpan(1000);
        //
        mLocClient.setLocOption(option);
         //开始定位
        mLocClient.start();
        
        
    }
    class  MyLocationListenner implements BDLocationListener{

        public void onReceiveLocation(BDLocation arg0) {
            // TODO Auto-generated method stub
            //吐司
            Toast.makeText(MainActivity.this, "经度"+arg0.getLongitude()+"纬度"+arg0.getLatitude()+"地址"+arg0.getAddrStr()+"街道"+arg0.getStreet()+"时间"+arg0.getTime(), 0).show();
            //定义Maker坐标点  
            LatLng point = new LatLng(arg0.getLatitude(),arg0.getLongitude());  
            //构建Marker图标  
            BitmapDescriptor bitmap = BitmapDescriptorFactory  
                .fromResource(R.drawable.icon_marka);  
            //构建MarkerOption,用于在地图上添加Marker  
            OverlayOptions option2 = new MarkerOptions()  
                .position(point)  
                .icon(bitmap);  
            //在地图上添加Marker,并显示  
            mBaiduMap.addOverlay(option2);
        
            
             // map view 销毁后不在处理新接收的位置
            if (arg0 == null || mMapView == null) {
                return;
            }
            //画出定位的区域
            MyLocationData locData = new MyLocationData.Builder()
                    .accuracy(arg0.getRadius())
                            // 此处设置开发者获取到的方向信息,顺时针0-360
                      //方圆100米
                    .direction(100).latitude(arg0.getLatitude())
                    .longitude(arg0.getLongitude()).build();
            mBaiduMap.setMyLocationData(locData);
            if (isFirstLoc) {
                //判断是否首次定位
                isFirstLoc = false;
                 //定位当前所在位置
                LatLng ll = new LatLng(arg0.getLatitude(),arg0.getLongitude());
                MapStatus.Builder builder = new MapStatus.Builder();
                //放大18倍
                builder.target(ll).zoom(18.0f);
                mBaiduMap.animateMapStatus(MapStatusUpdateFactory.newMapStatus(builder.build()));
            }
        }
        

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

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

        @Override
        protected void onDestroy() {
            // 退出时销毁定位
            mLocClient.stop();
            // 关闭定位图层
            mBaiduMap.setMyLocationEnabled(false);
          //在activity执行onDestroy时执行mMapView.onDestroy(),实现地图生命周期管理  
            mMapView.onDestroy();
            mMapView = null;
            super.onDestroy();
        }
}

 

 

 

你可能感兴趣的:(android 百度地图定位开发2)