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

简介:

首先下载对应资源的包

百度一下:百度地图 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

目录
相关文章
|
7月前
|
前端开发 定位技术 API
怎么用LarkMap完成地图需求
本文属于技术选型的参考性文章,主要以一个一个的案例分析,来带各位快速的了解到LarkMap能帮助我们完成哪些需求。希望阅读完之后您对LarkMap有一个大致的印象,若后续有地图需求的话,可以考虑使用LarkMap。
249 2
|
7月前
|
XML 小程序 JavaScript
微信小程序如何使用地图
微信小程序如何使用地图
245 4
|
8月前
|
存储 JavaScript 小程序
高德地图实现点聚合功能的详细步骤加截取地图图片 (附源码)
高德地图实现点聚合功能的详细步骤加截取地图图片 (附源码)
181 0
|
移动开发 JavaScript 定位技术
百度地图开发:地图调起API(Web端)使用终点经纬度直接调用百度地图导航信息的解决方案
百度地图开发:地图调起API(Web端)使用终点经纬度直接调用百度地图导航信息的解决方案
382 0
|
8月前
|
IDE 定位技术 开发工具
百度地图如何创建一个属于自己的地图,附加到项目中?
百度地图如何创建一个属于自己的地图,附加到项目中?
168 0
|
小程序 JavaScript 定位技术
微信小程序地图步骤
微信小程序地图步骤
|
小程序 定位技术
微信小程序如何实现地图多点标注
微信小程序如何实现地图多点标注
854 0
|
前端开发 小程序 API
微信小程序2.9.0基础库canvas2D新API,生成海报保存到手机功能实现
微信小程序2.9.0基础库canvas2D新API,生成海报保存到手机功能实现
379 0
|
JavaScript 定位技术
百度地图实用案例
百度地图实用案例
|
JavaScript 前端开发 数据可视化
【前端搞地图】如何设计一张让用户过目不忘的地图
【前端搞地图】如何设计一张让用户过目不忘的地图
【前端搞地图】如何设计一张让用户过目不忘的地图