百度地图入门一:获取秘钥和基本地图功能实现

首先下载对应资源的包

百度一下:百度地图 sdk->百度地图api->Android 开发->SDK下载,然后选择我们需要的开发资源,这里我选择了

定位,基础地图,检索功能,Lbs云检索,计算功能,选择这5个之后点击开发包下载,这样你就会获得一个压缩文件,里面有个libs文件夹,将其中的内容全部复制的你的libs里面去即可。

然后就要申请秘钥:sha1+你的包名(这里容易弄错),包名是你清单文件中package名称

点击首页->申请秘钥:

sha1获得:eclipse->preference->bulid

包名:这个看你自己的包了比如我的

然后就可以申请到了争取的key了。下面可以进行简单的地图应用了

首先是在AndroidManifest中添加开发密钥、所需权限等信息

[html] view plain copy

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     package="com.xsf.baidumaptest"  
  4.     android:versionCode="1"  
  5.     android:versionName="1.0" >  
  6.   
  7.     <uses-sdk  
  8.         android:minSdkVersion="11"  
  9.         android:targetSdkVersion="19" />  
  10.     <!-- 百度地图所需的权限 -->  
  11.     <uses-permission android:name="android.permission.GET_ACCOUNTS" />  
  12.     <uses-permission android:name="android.permission.USE_CREDENTIALS" />  
  13.     <uses-permission android:name="android.permission.MANAGE_ACCOUNTS" />  
  14.     <uses-permission android:name="android.permission.AUTHENTICATE_ACCOUNTS" />  
  15.     <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />  
  16.     <uses-permission android:name="android.permission.INTERNET" />  
  17.     <uses-permission android:name="com.android.launcher.permission.READ_SETTINGS" />  
  18.     <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />  
  19.     <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />  
  20.     <uses-permission android:name="android.permission.READ_PHONE_STATE" />  
  21.     <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />  
  22.     <uses-permission android:name="android.permission.BROADCAST_STICKY" />  
  23.     <uses-permission android:name="android.permission.WRITE_SETTINGS" />  
  24.   
  25.     <application  
  26.         android:allowBackup="true"  
  27.         android:icon="@drawable/ic_launcher"  
  28.         android:label="@string/app_name"  
  29.         android:theme="@style/AppTheme" >  
  30.         <activity  
  31.             android:name="com.xsf.baidumaptest.MainActivity"  
  32.             android:label="@string/app_name" >  
  33.             <intent-filter>  
  34.                 <action android:name="android.intent.action.MAIN" />  
  35.   
  36.                 <category android:name="android.intent.category.LAUNCHER" />  
  37.             </intent-filter>  
  38.         </activity>  
  39.         <!-- 百度地图 -->  
  40.         <meta-data  
  41.             android:name="com.baidu.lbsapi.API_KEY"  
  42.             android:value="uvF00wUCZP3MUQLYVmzxI5k4" />  
  43.           
  44.     </application>  
  45.   
  46. </manifest>  

然后在布局xml文件中添加地图控件

[html] view plain copy

  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.     <!-- 添加百度地图的控件标签 -->  
  6.     <com.baidu.mapapi.map.MapView  
  7.         android:id="@+id/id_bmapView"  
  8.         android:layout_width="fill_parent"  
  9.         android:layout_height="fill_parent"  
  10.         android:clickable="true" />  
  11.   
  12. </RelativeLayout>  

最后是mainactivity的书写,要添加初始化地图,覆写onResume() ,onPause(),onDestroy(),这里做了地图缩放级别的更改,普通视图,卫星视图,实时交通三种基本视图,并且将其切换放在了menu按钮中,因此覆写了onCreateOptionsMenu,onOptionsItemSelected,在meun文件夹main.xml文件操作后面会给出

[java] view plain copy

  1. package com.xsf.baidumaptest;  
  2.   
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.view.Menu;  
  6. import android.view.MenuItem;  
  7. import android.view.Window;  
  8.   
  9. import com.baidu.mapapi.SDKInitializer;  
  10. import com.baidu.mapapi.map.BaiduMap;  
  11. import com.baidu.mapapi.map.MapStatusUpdate;  
  12. import com.baidu.mapapi.map.MapStatusUpdateFactory;  
  13. import com.baidu.mapapi.map.MapView;  
  14.   
  15. public class MainActivity extends Activity {  
  16.     private MapView mMapView = null;  
  17.     private BaiduMap mBaiduMap = null;  
  18.   
  19.     @Override  
  20.     protected void onCreate(Bundle savedInstanceState) {  
  21.         super.onCreate(savedInstanceState);  
  22.         // 去除titlebar  
  23.         requestWindowFeature(Window.FEATURE_NO_TITLE);  
  24.         // 在使用SDK各组件之前初始化context信息,传入ApplicationContext  
  25.         // 注意该方法要再setContentView方法之前实现  
  26.         SDKInitializer.initialize(getApplicationContext());  
  27.   
  28.         setContentView(R.layout.activity_main);  
  29.         // 获取地图控件引用  
  30.         initView();  
  31.   
  32.     }  
  33.   
  34.     private void initView() {  
  35.         mMapView = (MapView) findViewById(R.id.id_bmapView);  
  36.         // 获得到地图  
  37.         mBaiduMap = mMapView.getMap();  
  38.         // 设置地图显示比例  
  39.         MapStatusUpdate msu = MapStatusUpdateFactory.zoomTo(10.0f);  
  40.         mBaiduMap.setMapStatus(msu);  
  41.   
  42.     }  
  43.   
  44.     @Override  
  45.     protected void onResume() {  
  46.   
  47.         super.onResume();  
  48.         // 在activity执行onResume时执行mMapView. onResume (),实现地图生命周期管理  
  49.         mMapView.onResume();  
  50.     }  
  51.   
  52.     @Override  
  53.     protected void onPause() {  
  54.   
  55.         super.onPause();  
  56.         // 在activity执行onPause时执行mMapView. onPause (),实现地图生命周期管理  
  57.         mMapView.onPause();  
  58.     }  
  59.   
  60.     @Override  
  61.     protected void onDestroy() {  
  62.   
  63.         super.onDestroy();  
  64.         // 在activity执行onDestroy时执行mMapView.onDestroy(),实现地图生命周期管理  
  65.         mMapView.onDestroy();  
  66.     }  
  67.   
  68.     // 按钮菜单  
  69.     @Override  
  70.     public boolean onCreateOptionsMenu(Menu menu) {  
  71.   
  72.         getMenuInflater().inflate(R.menu.main, menu);  
  73.         return true;  
  74.     }  
  75.   
  76.     // 菜单按钮选择  
  77.     @Override  
  78.     public boolean onOptionsItemSelected(MenuItem item) {  
  79.         // 通过item的ID选择用户选择的按钮  
  80.         switch (item.getItemId()) {  
  81.         case R.id.id_map_commom:  
  82.             // 加载地图类型为普通模式  
  83.             mBaiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL);  
  84.             break;  
  85.         case R.id.id_map_site:  
  86.             // 加载百度地图为卫星视图  
  87.             mBaiduMap.setMapType(BaiduMap.MAP_TYPE_SATELLITE);  
  88.             break;  
  89.         case R.id.id_map_tracffic:  
  90.             // 先判断当前traffic是否打开,若打开则关闭,否则开启  
  91.             if (mBaiduMap.isTrafficEnabled()) {  
  92.                 mBaiduMap.setTrafficEnabled(false);  
  93.                 item.setTitle("实时交通已经关闭");  
  94.             } else {  
  95.                 mBaiduMap.setTrafficEnabled(true);  
  96.                 item.setTitle("实时交通已经开启");  
  97.             }  
  98.             break;  
  99.         default:  
  100.             break;  
  101.         }  
  102.         return super.onOptionsItemSelected(item);  
  103.     }  
  104.   
  105. }  

main.xml文件,增加了三个item

[html] view plain copy

  1. <menu xmlns:android="http://schemas.android.com/apk/res/android"  
  2.     xmlns:app="http://schemas.android.com/apk/res-auto"  
  3.     xmlns:tools="http://schemas.android.com/tools"  
  4.     tools:context="com.xsf.baidumaptest.MainActivity" >  
  5.   
  6.     <item  
  7.         android:id="@+id/id_map_commom"  
  8.         android:showAsAction="never"  
  9.         android:title="普通地图"/>  
  10.     <item  
  11.         android:id="@+id/id_map_site"  
  12.          android:showAsAction="never"  
  13.         android:title="卫星地图"/>  
  14.     <item  
  15.         android:id="@+id/id_map_tracffic"  
  16.          android:showAsAction="never"  
  17.         android:title="实时交通(close)"/>  
  18.   
  19. </menu>  

结果示意图

转载:http://blog.csdn.net/xsf50717/article/details/44948763

时间: 2025-01-01 15:25:10

百度地图入门一:获取秘钥和基本地图功能实现的相关文章

android-Android百度地图API怎么获取邮编?

问题描述 Android百度地图API怎么获取邮编? 我用OnMapOnclickListener里面只有MapPoi,只有地点名称坐标,其他监听点击地图怎么获取点击地点的邮编? 解决方案 android 基于百度地图api获取经纬度android 百度地图apiandroid 用百度地图API获取经纬度和地理位置 解决方案二: 有专门的邮编数据库,查询了地址再查询邮编 解决方案三: 你可以查查百度地图API 解决方案四: http://blog.csdn.net/column/details/

Android百度地图定位后获取周边位置的实现代码

本文实例讲解Android百度地图定位后获取周边位置的实现代码,分享给大家供大家参考,具体内容如下 效果图: 具体代码: 1.布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical&q

C# 如何通过百度地图的API获取经纬度

问题描述 初次涉及百度地图,C#的Client端,如何调用API,通过百度地图获取到当前的经纬度.恳请指教 解决方案 解决方案二:需要你自己申请开发者帐号的.然后自己看百度的api函数,简单的.解决方案三: 解决方案四:注册一个账号,申请服务.解决方案五:百度javascriptapi里面都有的解决方案六:学习了谢谢不错的回答

百度地图 mousemove实时获取鼠标所在的经纬度坐标

问题描述 我想通过polyline中的setPositionAt函数绘制以一个点为定点,末端随鼠标移动的线,通过添加鼠标的mousemove事件就可以获取e.point,即为鼠标实时坐标所在点,可是为啥获取的点并不在鼠标所处的真实位置,而是偏向另一个地方???如图所示,像素不高,以那个圆形marker为定点,手型就是鼠标所在的位置,而画出的线确实偏向另一个地方??即此时通过监听时间得到的坐标并不是鼠标现在所在的位置.代码如下:(path即为polyline)map.addEventListene

android百度地图获取附近地址

问题描述 android百度地图获取附近地址 定位之后,出了当前地址还需要获取附近范围的地址信息,该怎么做?求大神解答 解决方案 百度地图 根据地址获取经纬度android 百度地图v3.2.0获取实际地址 解决方案二: 附近范围的地址信息是什么意思?文一西路1号的隔壁是文一西路2号? 解决方案三: 获取范围的地址,想PIO什么都可以把

百度地图 js使用

在网页中展现地图及位置信息,可使用百度地图.参阅 http://developer.baidu.com/map/index.php?title=jspopular/guide/introduction 1.获取秘钥 秘钥是为了用在百度地图api的js引用中.我的秘钥是3GFi2F04wXaVuwmGu8fN49kL1234567890 <script src="http://api.map.baidu.com/api?v=1.5&ak=您的密钥" type="t

安卓开发-关于百度地图的开发 如何把其他人的地址标记在地图上

问题描述 关于百度地图的开发 如何把其他人的地址标记在地图上 我想把做一种app两个使用者 得到对方的地址信息标记在自己的地图上的 基于百度地图 想请教一下大神 应该怎么做 解决方案 查一下百度的地图提供的接口吧,有很详细的说明. 是不是需要这个功能: 反地理编码+位置语义 按需返回经纬度坐标.详细地址和所在POI描述,支持省市区县结构化地址,独家支持POI语义名称.Android定位SDK 解决方案二: 百度地图通过经纬度获取地址信息百度地图地址转换百度地图 根据地址获取经纬度

百度地图PC端判断用户是否在配送范围内_IOS

最近接了个项目,其中有项目需求是这样的: 在pc端设置商家的配送范围,用户在下单时,根据用户设置的配送地点判断是否在可配送范围内,并给用户相应的提示. 下面说下我的实现思路: 1.用百度地图在PC端设置配送范围,可拖拽选择 2.根据用户设置的配送地址判断是否在配送范围内 一.百度地图PC端获取范围  改动百度地图官网的demo,设置配送范围.  思路:获取多边形的顶点,以json的形式保存到数据库.  百度API关于多边形覆盖物:  构造函数: Polygon(points:Array<Poin

cryptojs aes-在客户端(html js)用CryptoJS AES加密,秘钥暴露在js中,这种安全怎么保障

问题描述 在客户端(html js)用CryptoJS AES加密,秘钥暴露在js中,这种安全怎么保障 秘钥暴露在html代码中 ,右键审查元素就可以看到很不安全 怎么办 解决方案 解决方案二: 客户端加密没有什么意义,有耐心都会研究出来的.你不想放到页面中,可以用ajax动态加载然后更新,不过也会被浏览器开发工具捕捉到. 解决方案三: 用js加密 把客户端的js可读性去掉? 解决方案四: 如果是动态获取的秘钥,就不能直接看到秘钥.要增加他获取秘钥的难度,可以考虑将获取秘钥的操作分散到各种无关的