通过百度地图API显示当前位置在地图上(图标显示)--第三方开源--百度地图(二)

1.下载百度地图的demo,下载地址:http://lbsyun.baidu.com/sdk/download?selected=mapsdk_basicmap,mapsdk_searchfunction,mapsdk_lbscloudsearch,mapsdk_calculationtool,mapsdk_radar

2.把demo里面的BaiduMapsApiDemo解压,把BaiduMapsApiDemo文件夹里面的libs里面的所有文件都复制到自己的项目的libs里面

3.配置AndroidManifest.xml,把BaiduMapsApiDemo文件夹里面的AndroidManifest.xml有关百度地图要使用的配置信息复制到自己的AndroidManifest.xml里面

这是我配置好的例子的AndroidManifest.xml:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <manifest xmlns:android="http://schemas.android.com/apk/res/android"
 3     package="com.zzw.baidumappoint"
 4     android:versionCode="1"
 5     android:versionName="1.0" >
 6
 7     <uses-sdk
 8         android:minSdkVersion="14"
 9         android:targetSdkVersion="21" />
10
11     <application
12         android:allowBackup="true"
13         android:icon="@drawable/ic_launcher"
14         android:label="@string/app_name"
15         android:theme="@style/AppTheme" >
16         <activity
17             android:name=".MainActivity"
18             android:label="@string/app_name" >
19             <intent-filter>
20                 <action android:name="android.intent.action.MAIN" />
21
22                 <category android:name="android.intent.category.LAUNCHER" />
23             </intent-filter>
24         </activity>
25
26         <meta-data
27             android:name="com.baidu.lbsapi.API_KEY"
28             android:value="tpBieaHroLK1LeSkOQWLzq6A" />
29
30         <service
31             android:name="com.baidu.location.f"
32             android:enabled="true"
33             android:process=":remote" >
34         </service>
35     </application>
36
37     <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" >
38     </uses-permission>
39     <uses-permission android:name="android.permission.INTERNET" >
40     </uses-permission>
41     <uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />
42     <uses-permission android:name="android.permission.WAKE_LOCK" >
43     </uses-permission>
44     <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
45     <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
46     <!-- SDK1.5需要android.permission.GET_TASKS权限判断本程序是否为当前运行的应用? -->
47     <uses-permission android:name="android.permission.GET_TASKS" />
48     <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" >
49     </uses-permission>
50     <uses-permission android:name="android.permission.WRITE_SETTINGS" />
51     <!-- 这个权限用于进行网络定位 -->
52     <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" >
53     </uses-permission>
54     <!-- 这个权限用于访问GPS定位 -->
55     <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" >
56     </uses-permission>
57     <!-- 用于访问wifi网络信息,wifi信息会用于进行网络定位 -->
58     <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" >
59     </uses-permission>
60     <!-- 获取运营商信息,用于支持提供运营商信息相关的接口 -->
61     <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" >
62     </uses-permission>
63     <!-- 这个权限用于获取wifi的获取权限,wifi信息会用来进行网络定位 -->
64     <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" >
65     </uses-permission>
66     <!-- 用于读取手机当前的状态 -->
67     <uses-permission android:name="android.permission.READ_PHONE_STATE" >
68     </uses-permission>
69     <!-- 写入扩展存储,向扩展卡写入数据,用于写入离线定位数据 -->
70     <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" >
71     </uses-permission>
72     <!-- 访问网络,网络定位需要上网 -->
73     <uses-permission android:name="android.permission.INTERNET" />
74     <!-- SD卡读取权限,用户写入离线定位数据 -->
75     <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" >
76     </uses-permission>
77     <!-- 允许应用读取低级别的系统日志文件 -->
78     <uses-permission android:name="android.permission.READ_LOGS" >
79     </uses-permission>
80
81 </manifest>

AndroidManifest.xml

4.代码:

activity_main.xml:

 1 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:layout_width="match_parent"
 4     android:layout_height="match_parent"
 5     tools:context="com.zzw.baidumappoint.MainActivity" >
 6
 7     <com.baidu.mapapi.map.MapView
 8         android:id="@+id/mapView"
 9         android:layout_width="match_parent"
10         android:layout_height="match_parent" />
11
12 </RelativeLayout>

MainActivity.java:

 1 package com.zzw.baidumappoint;
 2
 3 import com.baidu.location.BDLocation;
 4 import com.baidu.location.BDLocationListener;
 5 import com.baidu.location.LocationClient;
 6 import com.baidu.location.LocationClientOption;
 7 import com.baidu.mapapi.SDKInitializer;
 8 import com.baidu.mapapi.map.BaiduMap;
 9 import com.baidu.mapapi.map.MapStatusUpdate;
10 import com.baidu.mapapi.map.MapStatusUpdateFactory;
11 import com.baidu.mapapi.map.MapView;
12 import com.baidu.mapapi.map.MyLocationData;
13 import com.baidu.mapapi.model.LatLng;
14
15 import android.app.Activity;
16 import android.os.Bundle;
17
18 public class MainActivity extends Activity {
19
20     private LocationClient mLocationClient;
21     private BaiduMap mBaiduMap;
22
23     @Override
24     protected void onCreate(Bundle savedInstanceState) {
25         super.onCreate(savedInstanceState);
26         SDKInitializer.initialize(getApplicationContext());//是程序不崩溃的作用
27         setContentView(R.layout.activity_main);
28
29         // 获取LocationClient
30         mLocationClient = new LocationClient(this);
31
32         LocationClientOption option = new LocationClientOption();
33         option.setCoorType("bd09ll");
34         mLocationClient.setLocOption(option);
35
36         // 获取BaiduMap
37         MapView mapView = (MapView) findViewById(R.id.mapView);
38         mBaiduMap = mapView.getMap();
39
40         // 显示出当前位置的小图标
41         mBaiduMap.setMyLocationEnabled(true);
42
43         MyLocationListener mListener = new MyLocationListener();
44         mLocationClient.registerLocationListener(mListener);
45         mLocationClient.start();
46     }
47
48     @Override
49     protected void onDestroy() {
50         mLocationClient.stop();
51         super.onDestroy();
52     }
53
54     private class MyLocationListener implements BDLocationListener {
55
56         @Override
57         public void onReceiveLocation(BDLocation location) {
58
59             // 只是完成了定位
60             MyLocationData locData = new MyLocationData.Builder().latitude(location.getLatitude())
61                     .longitude(location.getLongitude()).build();
62
63             //设置图标在地图上的位置
64             mBaiduMap.setMyLocationData(locData);
65
66             // 开始移动百度地图的定位地点到中心位置
67             LatLng ll = new LatLng(location.getLatitude(), location.getLongitude());
68             MapStatusUpdate u = MapStatusUpdateFactory.newLatLngZoom(ll, 16.0f);
69             mBaiduMap.animateMapStatus(u);
70         }
71
72     }
73
74 }
时间: 2024-10-09 20:52:38

通过百度地图API显示当前位置在地图上(图标显示)--第三方开源--百度地图(二)的相关文章

HTML5页面直接调用百度地图API,获取当前位置,直接导航目的地(转)

HTML5页面直接调用百度地图API,获取当前位置,直接导航目的地 我是应用在微信中,自定义菜单,菜单直接链接到这个HTML5页面,获取当前位置后,页面中定好目的地,这样打开页面后直接进入导航页面 可以省下先发送位置信息后,点确定再出导航,省一步, <!DOCTYPE html> <html lang="zh-cmn-Hans"> <meta charset="UTF-8"> <meta name="viewpor

百度地图API多个点聚合时,标注添加的标签label地图刷新就丢失的问题解决

当将自定义的Marker(含有Label)通过MarkerClusterer 管理的时候,当地图发生任何移动.缩放 的时候,Marker 的Label 就会自动消失. 这个问题主要是由于百度的点聚合API<script type="text/javascript" src="http://api.map.baidu.com/library/MarkerClusterer/1.2/src/MarkerClusterer_min.js"></scrip

【百度地图API】北京周边7日游——图标按路线轨迹行动

原文:[百度地图API]北京周边7日游--图标按路线轨迹行动 任务描述: 春节就要来啦~酸奶小妹的妈妈要从遥远的重庆,来到北京过春节呢!酸奶小妹忙着给妈妈计划,北京周边的旅游线路.计划好路线后,就开始驾车旅游啦~~ 如何实现: 利用百度地图API先确定几个坐标点points,把他们连成一条折线BMap.Polyline(points). 然后,更改标注图片为一辆小车,var myIcon = new BMap.Icon("car.png",...). 最后利用二次开发的类K_point

HTML5 利用百度地图API获取当前位置

由于项目需要定位到城市,研究了地理定位,做了一些手记,和大家分享一下~ 项目的开发需求是获取到当前用户的位置,然后为用户提供一些服务. 此时可以采用两种定位方式,一种是用GPS的定位,然后将定位到的经纬度传递到百度地图的API接口当中.另一种方法是利用百度API接口,使用IP地址定位,然后使用IP地址获取到的经纬度,传递到百度地图API接口中. 自己尝试使用了这两种方式进行定位.相对来说,IP地址定位,偏差比较大.GPS定位虽然还可以,但是也不足够精确.产生比较大偏差的原因有可能是以下几点造成的

利用百度地图API获取当前位置信息

利用百度地图API可以做很多事情,个人感觉最核心也是最基础的就是定位功能了.这里分享一个制作的JS可以实现登录网页后定位: 1 <script type="text/javascript"> 2 var map; 3 var gpsPoint; 4 var baiduPoint; 5 var gpsAddress; 6 var baiduAddress; 7 var x; 8 var y; 9 function getLocation() { 10 //根据IP获取城市 1

winodw.navigater 使用地图 api展示当前位置

[课程]web2.0程序设计[作业要求]研究 winodw.navigater 对象,写一段 javascript 程序,收集地理位置信息,并使用百度或高德等地图 api,在地图上展示用户当前位置.[参考文档]HTML5 地理定位 W3School 参考手册 [实验环境] Ubantu firefox 我这里用的是谷歌的API 1.首先我们先放置一个简单的界面: <!DOCTYPE html> <html> <head> <script src="htt

通过百度地图API实现搜索地址--第三方开源--百度地图(三)

搜索地址功能是建立在能够通过百度地图API获取位置的基础上 通过百度地图定位获取位置详情:http://www.cnblogs.com/zzw1994/p/5008134.html 1 package com.zzw.baidumappoint; 2 3 import com.baidu.location.BDLocation; 4 import com.baidu.location.BDLocationListener; 5 import com.baidu.location.Location

转:zTree树控件key配置之title:zTree树节点名称过长如何省略显示且鼠标移入节点上能够显示全称

当树节点的名称有些很长时,全部显示出来显得很拥挤的情况下,我们会想到用省略节点名称来代替,当鼠标移入节点时能够显示该节点的全称.这样我们应该如何做呢? 首先,我们要在树的节点内多增加一个属性用于设置该节点的全称,这里我们以title名称为例吧,示例代码如下所示: view sourceprint? 1.{ id:233, pId:23, name:"叶子节点233...",title:"叶子节点23333434343434"}, 2.{ id:234, pId:23

PC上图标显示异常 白色框框处理方案

步骤如下: 1.打开360安全卫士,点击图标显示异常的立即修复 2.修复完,图标就正常了 3.分析原因: 可能是我用了魔方优化大师(TweakerCube)优化了桌面快捷方式(去掉箭头)引起的,而且是偶然性才会发生,目前就碰到第二次.