如何在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
- 用Echarts請求百度地圖api 小案例Echarts地圖API
- 在 HTTPS 專案中使用百度地圖 APIHTTP地圖API
- 對接百度地圖API地圖API
- Android應用開發中如何使用隱藏的APIAndroidAPI
- 如何在 Android 專案中應用 OpenCV?AndroidOpenCV
- 百度地圖,您所使用的地圖JS API版本過低,解決方法地圖JSAPI
- 百度地圖API功能演示地圖API
- Android Studio 百度地圖導航Android地圖
- 淺談百度地圖API的坑地圖API
- 百度地圖API : 自定義標註圖示地圖API
- 百度地圖API圖示、文字、圖例與連線地圖API
- 前端 – 百度地圖 API 基礎入門前端地圖API
- 在React中使用百度地圖api的一系列demoReact地圖API
- 使用者故事地圖實際應用地圖
- 百度地圖JavaScript API 學習之地址解析地圖JavaScriptAPI
- 呼叫百度地圖api只顯示網格地圖API
- 使用Angular8和百度地圖api開發《旅遊清單》Angular地圖API
- 教你如何在快應用中跳轉到Android的appAndroidAPP
- 百度API實現地圖示點並測距API地圖
- 上手百度地圖--開放平臺必懂API使用場合(PC端)地圖API
- 如何在移動應用中實現AI畫圖?AI
- vue專案中使用百度地圖Vue地圖
- Android開發百度地圖指南針消失問題Android地圖
- 如何在 JavaScript 中更好地使用陣列JavaScript陣列
- vue 專案中引用百度地圖Vue地圖
- 地圖開發筆記(一):百度地圖介紹、使用和Qt內嵌地圖Demo地圖筆記QT
- react中使用高德地圖的原生APIReact地圖API
- 如何在.NET電子表格應用程式中建立流程圖流程圖
- Android 百度地圖InfoWindow 出現重疊的問題Android地圖
- MVC5使用百度地圖API(JavaScript library庫)【檢索資訊視窗類】MVC地圖APIJavaScript
- 如何在 Vue 中優雅地使用 CSS Modules?VueCSS
- 【練習】註冊appid、下拉選單、訪問百度地圖APIAPP地圖API
- [譯文] 如何在 JavaScript 中更好地使用陣列JavaScript陣列
- 如何在Flask中整合Dash應用Flask
- 百度地圖GeoUtils示例地圖
- 百度地圖API開發的快速使用和新增大量座標點的幾種方法地圖API
- scrapy爬蟲框架呼叫百度地圖api資料存入資料庫爬蟲框架地圖API資料庫
- vue專案使用和引用百度地圖的操作Vue地圖