ขั้นตอนการอ่านค่า Keystore และ SHA1 (ถ้าอยู่ในเฟสของ Dev ก็ไม่ต้องสนใจ ข้ามไปขั้นตอนการสมัคร API Key ได้เลย)
data:image/s3,"s3://crabby-images/9af4c/9af4cc6e3cb69b08d97b38c999a497aae4f5c2c6" alt="Android Google Map Android Google Map"
ไฟล์ debug.keystore จะมาพร้อมกับ Android SDK ปกติจะอยู่ที่
Windows
C:\Users\<your_user_name>\.android\debug.keystore
Mac OS X
~/.android/debug.keystore
เราสามารถใช้คำสั่ง
Windows
keytool -list -v -keystore "%USERPROFILE%\.android\debug.keystore" -alias androiddebugkey -storepass android -keypass android
Mac OS X
keytool -list -v -keystore ~/.android/debug.keystore -alias androiddebugkey -storepass android -keypass android
เพื่อทำการอ่านรหัสของ SHA1
data:image/s3,"s3://crabby-images/f17d0/f17d08723aa737e1b100e7787ff397cb7fd96d3d" alt="Android Google Map Android Google Map"
ปกติแล้วมันจะได้ แต่ถ้า Error ดังรูปแสดงว่าไม่ได้ Set Path ของ Java JDK ไว้ซึ่งมันไม่รู้จักคำสั่งของ keytool
data:image/s3,"s3://crabby-images/08ca6/08ca68b2ddf6bbd80ff280480cdbac644dc7d60a" alt="Android Google Map Android Google Map"
ให้ Search หาว่ามันอยู่ที่ไหน หรือไม่ก็ไป Set Path ที่ Environment Variables
data:image/s3,"s3://crabby-images/5f7bc/5f7bcda6061dbd9e5fb3822ddf11a39fd3338578" alt="Android Google Map Android Google Map"
ใช้การ CD เข้ามาใน Path ของ JDK
data:image/s3,"s3://crabby-images/61303/61303fc184d8db9eeb78bd5f0a55b35fd0d61ef3" alt="Android Google Map Android Google Map"
ทดสอบรันใหม่เราจะได้รหัสของ SHA1 ซึ่งอันที่จริงแล้วมันมีรหัสหลายประเภท ขึ้นอยู่ว่า API นั้น ๆ ต้องการรหัสชุดไหน
data:image/s3,"s3://crabby-images/c19f5/c19f574b5fae02a5ff4e1884da26a8fad26517df" alt="Android Google Map Android Google Map"
คลิกขวาเพื่อ Select All และ Copy
MD5: 31:39:AC:F1:C5:1E:F0:8C:90:2B:2C:BD:C9:F0:44:76
SHA1: 63:83:0D:91:E5:E0:1A:64:46:56:04:CB:19:5E:2E:78:E7:95:13:40
SHA256: 4C:3D:AD:DE:74:25:FE:6A:A6:53:75:9D:81:65:7C:5E:52:7D:F5:69:75:16:5A:6C:7E:D7:DB:F1:F4:4B:E4:AA
Signature algorithm name: SHA256withRSA
Version: 3
รหัส SHA1 ที่จะใช้ในการสมัคร API Key
การสมัคร Google API Key จำเป็นจะต้องมี ถ้าไม่มีจะไม่สามารถเรียก Map มาแสดงได้
Google Developer Console
https://console.developers.google.com/
URL สำหรับการสมัคร ซึ่งจะต้องใช้ Account ของ Gmail
data:image/s3,"s3://crabby-images/990d9/990d9630fc50f302e4b52cb3e530f8a63b825c71" alt="Android Google Map Android Google Map"
หลังจากที่ Login เข้ามาแล้ว จะเป็นหน้าจอของ Google API
data:image/s3,"s3://crabby-images/f953f/f953f71a641e81a0c2b180f7929f46e8e2c42755" alt="Android Google Map Android Google Map"
ให้คลิกไปที่ขวามือเลือก Create a project...
data:image/s3,"s3://crabby-images/4d182/4d1829aaa7c0b9be178c5b54e2c1d24389e15a7b" alt="Android Google Map Android Google Map"
กรอกชื่อ Project และเลือก Create
data:image/s3,"s3://crabby-images/6ad01/6ad01e593e1c57ca5d86609f40afbf75134320d3" alt="Android Google Map Android Google Map"
หลังจากที่ Create Project เรียบร้อยแล้ว เราจะกลับมายังหน้า Dashboard
data:image/s3,"s3://crabby-images/df73d/df73dbf02615d995d4f7dd6a18413e4c078f326d" alt="Android Google Map Android Google Map"
ให้เลือก Manage all project...
data:image/s3,"s3://crabby-images/d2746/d27465304dfdad3f1cf171d298bff971349145f9" alt="Android Google Map Android Google Map"
แสดงรายชื่อ Project ทั้งหมดที่มีอยู่ปัจจุบัน ให้คลิกเพื่อเข้าไปจัดการกับ API
data:image/s3,"s3://crabby-images/e197f/e197f0d03078618541719527554a6f462a6df9c4" alt="Android Google Map Android Google Map"
เลือก API Enable and manage APIs
data:image/s3,"s3://crabby-images/46433/464334427cf4162354e005b6622e065c0c0b1d21" alt="Android Google Map Android Google Map"
คลิกที่ Overview -> Google Maps Android API
data:image/s3,"s3://crabby-images/4b3d8/4b3d84c4bfe71985058626239a571aec9a729a6e" alt="Android Google Map Android Google Map"
เลือก Enable API
data:image/s3,"s3://crabby-images/a421a/a421aa2ab68a838cdbdb49bcddea1aa7895b510a" alt="Android Google Map Android Google Map"
ในฝั่งของซ้ายมือเลือก Credentials
data:image/s3,"s3://crabby-images/1893d/1893d50944229f81b567f281850847d70c4fff5d" alt="Android Google Map Android Google Map"
เลือก Add credentials -> API Key
data:image/s3,"s3://crabby-images/6b160/6b1602308365748c0f1b18ce70afaf8d7e0e770a" alt="Android Google Map Android Google Map"
เลือก Android key
data:image/s3,"s3://crabby-images/2cee5/2cee555c01a46931d13b367c2750c301afd5a26b" alt="Android Google Map Android Google Map"
ในขั้นตอนนี้สำคัญมาก จะเห็นว่ามีในส่วนที่จะให้เพิ่ม Add package name and fingerprint
data:image/s3,"s3://crabby-images/2b903/2b903106baef7ab00648b872dfd5812e4ff8d710" alt="Android Google Map Android Google Map"
จะเห็นว่ามีให้กรอก Package name และ SHA-1 ซึ่งเป็นรหัสที่เราได้ก่อนหน้านี้ ส่วน Package name มาจากโปรเจคของเรา
(ย้ำว่าในเฟส Dev ไม่จำเป็นต้องกรอกรหัสนี้ก็ได้)
data:image/s3,"s3://crabby-images/3e25a/3e25acf2659ea75d3c7a6bde31dcc10e9bb0f938" alt="Android Google Map Android Google Map"
หลังจากนั้นเราจะได้ API Key ที่จะใช้งาน
data:image/s3,"s3://crabby-images/24242/242423c256b89988534d87ebd040d3afa0ca64ef" alt="Android Google Map Android Google Map"
API Key ที่ได้
data:image/s3,"s3://crabby-images/c2025/c2025dd77b65bbce1f1c853c93eff317397747c3" alt="Android Google Map Android Google Map"
ในไฟล์ AndroidManifest.xml ให้เพิ่ม API Key และชุดคำสั่งนี้ลงไป (ให้ถูกตำแหน่งด้วย ไม่งั้น App ไม่แสดง Map)
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
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>
<uses-library android:name="com.google.android.maps" > </uses-library>
<meta-data
android:name="com.google.android.maps.v2.API_KEY"
android:value="AIzaSyBPlg32Atd1FsDgmn_c5pefEkOotGqs3z8" />
<meta-data
android:name="com.google.android.gms.version"
android:value="@integer/google_play_services_version" />
</application>
data:image/s3,"s3://crabby-images/0beb5/0beb5a324f6643b0df0ae75c292edf0bf9c8b263" alt="Android Google Map Android Google Map"
เป็นโครงสร้างของโปรเจค สามารถใช้ได้ทั้งบน Eclipse และ Android Studio
activity_main.xml
data:image/s3,"s3://crabby-images/1b38d/1b38d105b38752e0481dd743b0b9945823c75cd0" alt="Android Google Map Android Google Map"
<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/googleMap"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:name="com.google.android.gms.maps.SupportMapFragment"/>
ในการใช้งานแนะนำให้ใช้ fragment
MainActivity.java
package com.myapp;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
public class MainActivity extends FragmentActivity {
// Google Map
private GoogleMap googleMap;
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
googleMap = ((SupportMapFragment)getSupportFragmentManager()
.findFragmentById(R.id.googleMap)).getMap();
}
}
ในการเขียน Code ของ Java แนะนำให้ extends ไปยัง FragmentActivity ซึ่งจะสามารถใช้งาน Google Map ได้อย่างไม่มีปัญหา
Screenshot
data:image/s3,"s3://crabby-images/0a245/0a245451b99cdd3e0f45eed99b3e6d8ddffa04a2" alt="Android Google Map Android Google Map"
ผลลัพธ์ที่ได้
สำหรับหัวข้อแรกนี้อาจจะยาวนิดหนึ่ง แต่เนื้อหาใจความแล้วไม่มีอะไรซับซ้อน ถ้าสมาชิกท่านใดยังไม่สามารถทำให้ Map แสดงผลได้ ลองตรวจสอบขั้นตอนว่าได้ขาดขั้นตอนใดขั้นตอนหนึ่งหรือไม่
.