使用百度地图,定位你当前位置并显示

使用百度地图,定位你当前位置并显示

1、准备

  • 注册百度开发者账号
  • 到百度地图开放平台创建应用(as获取SHA1值

2、将sdk整到你的项目中去

- 在你app的gradle.build中添加

 dependencies {
            ......
compile files('libs/baidumapapi_base_v4_0_0.jar')
compile files('libs/baidumapapi_cloud_v4_0_0.jar')
compile files('libs/baidumapapi_map_v4_0_0.jar')
compile files('libs/baidumapapi_radar_v4_0_0.jar')
compile files('libs/baidumapapi_search_v4_0_0.jar')
compile files('libs/baidumapapi_util_v4_0_0.jar')
compile files('libs/locSDK_6.13.jar')
}

android {
    ......
    sourceSets {
        main {
            jniLibs.srcDir 'libs'
        }
    }

}

3、在AndroidManifest.xml中配置

<!--baiduMap-->
<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" />

 <meta-data
      android:name="com.baidu.lbsapi.API_KEY"
      android:value="百度key" />

<!--百度地图定位监听服务-->
    <service
        android:name="com.baidu.location.f"
        android:enabled="true"
        android:process=":remote" >
    </service>

4、在activity中

  1. oncreate中

    地图初始化

    mBaiduMap = mMapView.getMap();
    // 开启定位图层
    mBaiduMap.setMyLocationEnabled(true);
    // 定位初始化
    mLocClient = new LocationClient(getActivity());
    mLocClient.registerLocationListener(myListener);
    LocationClientOption option = new LocationClientOption();
    option.setOpenGps(true); // 打开gps
    option.setCoorType("bd09ll"); // 设置坐标类型
    option.setScanSpan(1000);
    mLocClient.setLocOption(option);
    mLocClient.start();
    LatLng ll = new LatLng(100,
            100);
    MapStatus.Builder builder = new MapStatus.Builder();
    builder.target(ll).zoom(18.0f);
    mBaiduMap.animateMapStatus(MapStatusUpdateFactory.newMapStatus(builder.build()));
    
  2. 内部类监听
    public class MyLocationListenner implements BDLocationListener {

    @Override
    public void onReceiveLocation(BDLocation location) {
        // map view 销毁后不在处理新接收的位置
        if (location == null || mMapView == null) {
            return;
        }
        mBaiduMap.clear();
        MyLocationData locData = new MyLocationData.Builder()
                .accuracy(location.getRadius())
                // 此处设置开发者获取到的方向信息,顺时针0-360
                .direction(100).latitude(location.getLatitude())
                .longitude(location.getLongitude()).build();
        mBaiduMap.setMyLocationData(locData);
        LatLng llA=new LatLng(location.getLatitude(),location.getLongitude());
        MarkerOptions ooA = new MarkerOptions().position(llA).icon(bdA)
                .zIndex(9).draggable(true);
        mBaiduMap.addOverlay(ooA);
    
        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) {
    }
    

    }

5、在布局文件中

 <com.baidu.mapapi.map.MapView
            android:id="@+id/map_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            />

6、到此应该可以显示地图了,手机开wifi,开gsp试一试吧!

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要实现获取当前定位并在百度地图显示出来,可以按照以下步骤进行操作: 1. 首先,在HTML文件中引入百度地图API和相关的JavaScript文件。可以使用如下代码: ```html <script src="http://api.map.baidu.com/api?v=2.0&ak=你的百度地图API密钥"></script> ``` 其中,需要将"你的百度地图API密钥"替换为自己申请的百度地图API密钥。 2. 创建地图容器。在HTML文件中添加一个具有唯一ID的元素作为地图容器,例如: ```html <div id="map"></div> ``` 3. 使用JavaScript编写获取当前位置的代码,并在地图上显示出来。可以使用Geolocation API来获取当前位置,然后将经纬度传给百度地图API进行标注。以下是示例代码: ```javascript // 获取当前位置 navigator.geolocation.getCurrentPosition(function(position) { var latitude = position.coords.latitude; // 纬度 var longitude = position.coords.longitude; // 经度 // 创建地图实例 var map = new BMap.Map("map"); // 创建点坐标 var point = new BMap.Point(longitude, latitude); // 在地图上标注当前位置 var marker = new BMap.Marker(point); map.addOverlay(marker); // 设置地图中心点和缩放级别 map.centerAndZoom(point, 15); }); ``` 4. 最后,在CSS文件中设置地图容器的宽度和高度,例如: ```css #map { width: 600px; height: 400px; } ``` 通过以上步骤,就能够获取当前定位并在百度地图显示出来。可以在网页中测试该代码,看到地图会自动显示当前位置的标注。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值