如何在Android應用中使用百度地圖api
本篇通過一個簡單的示例一步步介紹如何在Android應用中使用百度地圖api。
1)下載百度地圖移動版API(Android)開發包
要在Android應用中使用百度地圖API,就需要在工程中引用百度地圖API開發包,這個開發包包含兩個檔案:baidumapapi.jar和libBMapApiEngine.so。下載地址:http://dev.baidu.com/wiki/static/imap/files/BaiduMapApi_Lib_Android_1.0.zip
2)申請API Key
和使用Google map api一樣,在使用百度地圖API之前也需要獲取相應的API Key。百度地圖API Key與你的百度賬戶相關聯,因此您必須先有百度帳戶,才能獲得API Key;並且,該Key與您引用API的程式名稱有關。
百度API Key的申請要比Google的簡單多了,其實只要你有百度帳號,應該不超過30秒就能完成API Key的申請。申請地址:http://dev.baidu.com/wiki/static/imap/key/
3)建立一個Android工程
這裡需要強調一點:百度地圖移動版api支援Android 1.5及以上系統,因此我們建立的工程應基於Android SDK 1.5及以上。
工程建立完成後,將baidumapapi.jar和libBMapApiEngine.so分別拷貝到工程的根目錄及libs/armeabi目錄下,並在工程屬性->Java Build Path->Libraries中選擇“Add JARs”,選定baidumapapi.jar,這樣就可以在應用中使用百度地圖API了。工程完整的目錄結構如下圖所示:
4)在佈局檔案中新增地圖控制元件(res/layout/main.xml)
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- >
- <com.baidu.mapapi.MapView android:id="@+id/map_View"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:clickable="true"
- />
- </LinearLayout>
5)建立Activity繼承com.baidu.mapapi.MapActivity
- package com.liufeng.baidumap;
- import android.graphics.drawable.Drawable;
- import android.os.Bundle;
- import com.baidu.mapapi.BMapManager;
- import com.baidu.mapapi.GeoPoint;
- import com.baidu.mapapi.MapActivity;
- import com.baidu.mapapi.MapController;
- import com.baidu.mapapi.MapView;
- public class MainActivity extends MapActivity {
- private BMapManager mapManager;
- private MapView mapView;
- private MapController mapController;
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- // 初始化MapActivity
- mapManager = new BMapManager(getApplication());
- // init方法的第一個引數需填入申請的API Key
- mapManager.init("285B415EBAB2A92293E85502150ADA7F03C777C4", null);
- super.initMapActivity(mapManager);
- mapView = (MapView) findViewById(R.id.map_View);
- // 設定地圖模式為交通地圖
- mapView.setTraffic(true);
- // 設定啟用內建的縮放控制元件
- mapView.setBuiltInZoomControls(true);
- // 用給定的經緯度構造一個GeoPoint(緯度,經度)
- GeoPoint point = new GeoPoint((int) (47.118440 * 1E6), (int) (87.493147 * 1E6));
- // 建立標記maker
- Drawable marker = this.getResources().getDrawable(R.drawable.iconmarka);
- // 為maker定義位置和邊界
- marker.setBounds(0, 0, marker.getIntrinsicWidth(), marker.getIntrinsicHeight());
- // 取得地圖控制器物件,用於控制MapView
- mapController = mapView.getController();
- // 設定地圖的中心
- mapController.setCenter(point);
- // 設定地圖預設的縮放級別
- mapController.setZoom(12);
- }
- @Override
- protected boolean isRouteDisplayed() {
- return false;
- }
- @Override
- protected void onDestroy() {
- if (mapManager != null) {
- mapManager.destroy();
- mapManager = null;
- }
- super.onDestroy();
- }
- @Override
- protected void onPause() {
- if (mapManager != null) {
- mapManager.stop();
- }
- super.onPause();
- }
- @Override
- protected void onResume() {
- if (mapManager != null) {
- mapManager.start();
- }
- super.onResume();
- }
- }
6)在AndroidManifest.xml中配置
- <?xml version="1.0" encoding="utf-8"?>
- <manifest xmlns:android="http://schemas.android.com/apk/res/android"
- package="com.liufeng.baidumap"
- android:versionCode="1"
- android:versionName="1.0">
- <application android:icon="@drawable/icon" android:label="@string/app_name">
- <activity android:name=".MainActivity" android:label="@string/app_name">
- <intent-filter>
- <action android:name="android.intent.action.MAIN" />
- <category android:name="android.intent.category.LAUNCHER" />
- </intent-filter>
- </activity>
- </application>
- <uses-sdk android:minSdkVersion="4" />
- <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
- <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
- <uses-permission android:name="android.permission.INTERNET" />
- <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
- <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
- <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
- <uses-permission android:name="android.permission.READ_PHONE_STATE" />
- </manifest>
7)執行結果
說明:上面的應用只是簡單的展示了百度地圖(交通地圖),並將一個指定的點(根據經緯度確定)展示在手機螢幕的中心。當然,實際專案中涉及的map應用不會這麼簡單,百度地圖API為我們提供了豐富的功能介面,有待我們一起去研究學習。
相關文章
- 百度地圖API基本使用(一)地圖API
- 百度地圖API入門——(5)百度地圖API的簡介地圖API
- 如何在 Android 應用中使用 FontAwesome 圖示Android
- 用Echarts請求百度地圖api 小案例Echarts地圖API
- 對接百度地圖API地圖API
- HTML呼叫百度地圖APIHTML地圖API
- 百度地圖API功能演示地圖API
- 在 HTTPS 專案中使用百度地圖 APIHTTP地圖API
- 百度地圖,您所使用的地圖JS API版本過低,解決方法地圖JSAPI
- 關於百度地圖api的實用方法記錄地圖API
- 百度地圖API入門——(2)第二個超簡單應用:Hello, World!地圖API
- ECharts+百度地圖網路拓撲圖應用Echarts地圖
- 淺談百度地圖API的坑地圖API
- 讓百度地圖API支援HTTPS地圖APIHTTP
- 百度地圖API開發demo地址地圖API
- 百度地圖API : 自定義標註圖示地圖API
- Android載入百度地圖Android地圖
- 百度地圖API入門——(4)用Jetty搭建一個簡單的多終端可訪問的地圖應用站點...地圖APIJetty
- 百度地圖API圖示、文字、圖例與連線地圖API
- 百度地圖/社交分享/應用間的跳轉地圖
- 前端 – 百度地圖 API 基礎入門前端地圖API
- 前端 - 百度地圖 API 基礎入門前端地圖API
- nginx正向代理訪問百度地圖APINginx地圖API
- Android應用開發中如何使用隱藏的APIAndroidAPI
- 【月入41萬】Mono For Android中使用百度地圖SDKMonoAndroid地圖
- android使用百度地圖SDK 去掉百度Logo的小技巧Android地圖Go
- 如何在 Android 專案中應用 OpenCV?AndroidOpenCV
- 使用百度地圖問題地圖
- Android中如何在應用A中啟動或安裝應用BAndroid
- 百度地圖、ECharts整合HT for Web網路拓撲圖應用地圖EchartsWeb
- 在React中使用百度地圖api的一系列demoReact地圖API
- 百度地圖API入門——(6)地圖容器及BMap名稱空間地圖API
- 百度地圖JavaScript API 學習之地址解析地圖JavaScriptAPI
- 呼叫百度地圖api只顯示網格地圖API
- 百度地圖API入門——(3)控制元件地圖API控制元件
- 使用Angular8和百度地圖api開發《旅遊清單》Angular地圖API
- Android Studio 百度地圖導航Android地圖
- 百度地圖API入門——(7)新增或刪除圖層地圖API