Home / Developer  / Android Developer  / การพัฒนาแอพพลิเคชัน Android ร่วมกับ Firebase

การพัฒนาแอพพลิเคชัน Android ร่วมกับ Firebase

บทความนี้จะพาเรามารู้จักกับ Firebase ซึ่งเป็น Project ที่ถูกพัฒนามาโดย Google โดยเน้นการทำ API สำหรับเว็บแอพพลิเคชัน และ แอพพลิเคชันแบบ Realtime

1-ulBRJ40ISR1QRrnZZfjnGQ

การทำงานหลักของ Firebase นั้นทำหน้าที่เหมือนกับการจำลองตัวเองเป็น Cloud Storage เพื่อเหมาะกับการโต้ตอบทั้ง Push, Embedded และ ประมวลผล โดยเฉพาะส่วนที่เน้นหนักจริงๆ คือ Cloud Storage ดังนั้นก็พอจะเดาได้ว่า เทคโนโลยีที่น่าจะแฮปปี้ไปกับมันก็น่าจะเป็น Mobile Platform อย่าง iOS, Android, NodeJS และ AngularJS เป็นต้น

เรามาเริ่มต้นลองศึกษาเจ้า Firebase กันหน่อยดีกว่า

เริ่มต้นเลยให้เราสมัคร Google Account แต่ถ้ามีกันอยู่แล้วก็สามารถไปที่เว็บไซต์ Firebase console ได้ทันทีเพื่อไปตั้งค่าการใช้งาน

Firebase Console

Firebase Console

กดที่ปุ่ม Create new Project ให้ใส่รายละเอียดชื่อแอพของเรา และประเทศของเราลงไปให้เรียบร้อยตามตัวอย่าง

สร้างโปรเจ็คใหม่บน Firebase

สร้างโปรเจ็คใหม่บน Firebase

เมื่อเสร็จแล้วเราจะพบกับหน้าจอ DashBoard การจัดการ Firebase console สำหรับโปรเจ็คใหม่ของเราตามภาพด้านล่าง

Firebase Console

Firebase Console

เลือกที่ไอคอนสีเขียวที่เขียนว่า Add Firebase to your Android app แล้วจะพบหน้าจอนี้

Screen Shot 2016-07-10 at 12.12.29 PM

เราจะต้องใส่ค่าของ Package name ของแอพพลิเคชันของเรา และ Key SHA-1 จากโปรเจ็ค Android Studio ของเรามากรอกลงไปในระบบ ดังนั้นให้เราเปิด Android Studio ขึ้นมาครับ สร้าง Project ใหม่

Android Studio 2.1

Android Studio 2.1

เมื่อใส่รายละเอียดเรจะได้ Package Name ที่ตำแหน่งที่เห็นอยู่ใน Android Studio

Screen Shot 2016-07-10 at 12.15.48 PM

เปิด terminal ขึ้นมาหรือ Command Prompt ก็ได้ครับ แล้วรันคำสั่งต่อไปนี้เพื่อได้ค่า SHA ไปใส่ใน Firebase Console

กด Enter เราจะได้ค่า SHA มาใช้งานแล้ว Copy เก็บไว้ไปกรอกใส่ในระบบ

Screen Shot 2016-08-13 at 8.21.15 AM

เราจะได้ไฟล์ google-services.json มาให้ทำตามขั้นตอนที่แนะนำจาก Firebase นั่นคือการนำไปวางใน Project ของเรา

Screen Shot 2016-08-13 at 8.26.05 AM

ปรับโหมดเป็น Project แล้วนำไปวางใน Path เดียวกับ gradle

Screen Shot 2016-08-13 at 8.28.05 AM

เปิด gradle ขึ้นมาเพื่อตั้งค่าตัว Project ของเราให้รู้จัก Firebase ส่วนแรกคือ gradle ของ Project

Screen Shot 2016-08-13 at 8.30.01 AM

ใส่เพิ่มส่วนของ dependencies ตามนี้

เมื่อเพิ่มแล้วจะเป็นดังนี้

ให้ทำการ Sync now แล้วรอ  จนเสร็จ ต่อจากนั้นให้ไปที่ gradle ส่วนของ App Module

Screen Shot 2016-08-13 at 8.32.54 AM

เพิ่มบรรทัดนี้ในตำแหน่งบรรทัดสุดท้าย

ส่วนของ Module: app จะเป็นดังนี้

ตรวจสอบให้เหมือนตามตัวอย่างแล้วก็ Sync Now ให้เรียบร้อยครับ หากเสร็จขั้นตอนข้างต้น กลับไปที่ console ของ Firebase จะเห็น Project ของเราพร้อมแล้ว

Screen Shot 2016-08-13 at 8.36.16 AM

เราจะเริ่มทดสอบกับ Feature Analytics ของ FireBase ก่อนโดยกลับไปที่ Android Studio ให้ทำการแก้ไข gradle ส่วนของ app โดยการเพิ่ม compile ส่วนนี้เข้าไป

ไฟล์ gradle จะเป็นดังนี้

เพิ่มการติด TrackingEvent เข้าไปใน แอพพลิเคชันของเราครับ รูปแบบก็มีตามนี้

getInstance(Context context)
Returns the singleton FirebaseAnalytics interface.
logEvent(String name, Bundle params)
Logs an app event.
setAnalyticsCollectionEnabled(boolean enabled)
Sets whether analytics collection is enabled for this app on this device.
setMinimumSessionDuration(long milliseconds)
Sets the minimum engagement time required before starting a session. The default value is 10000 (10 seconds).
setSessionTimeoutDuration(long milliseconds)
Sets the duration of inactivity that terminates the current session. The default value is 1800000 (30 minutes).
setUserId(String id)
Sets the user ID property.
setUserProperty(String name, String value)
Sets a user property to a given value.

เปิดไฟล์ MainActivity.java ขึ้นมาประกาศส่วนของ FireBase Analytics ก่อน

อย่าลืม  Import Header ตามนี้

ต่อมาเราะใช้ FloatingButton เป็นตัวจับ EventTracking ส่ง Param ไปเก็บที่ FireBase Console โดยผมจะกำหนดตามนี้

อธิบายตัวอย่างค่าที่ส่ง Param ไปคือ

  • ค่า ITEM_ID จะส่ง DAYDEV01 ไปเป็นรหัส
  • ค่า CHARACTER เป็น String อาจจะจับพวกการเลือก Character ในเกม

เสียบ USB เครื่องของคุณเข้ากับ Android Studio แล้วลอง Run แอพพลิเคชันของเราครั้งแรก

Screen Shot 2016-08-13 at 8.38.36 AM

ทดสอบโดยการกดปุ่ม FloatingActionButton ดูครับ  หลังจากนั้นก็รอ Report จาก FirebaseConsole ก็ได้

FirebaseConsole

ดูรายงานในระบบ

FirebaseConsole2

นี่คือบทเรียนเบื้องต้นการติดตั้ง FireBase บน android ครับ

Comments

daydevthailand@gmail.com

อาจารย์ประจำสาขาวิชาการออกแบบเชิงโต้ตอบ และการพัฒนาเกม วิทยาลัยครีเอทีฟดีไซน์ & เอ็นเตอร์เทนเมนต์เทคโนโลยี มหาวิทยาลัยธุรกิจบัณฑิตย์ ,ผู้ก่อตั้ง บริษัท Daydev Co., Ltd, (เดย์เดฟ จำกัด)

Review overview