สร้างกราฟ Line Chart บน Android ด้วย AChartEngine
บทความสอนเขียนแอพ Android วันนี้ขอนำเสนอเรื่อง การเขียนกราฟ การ plot กราฟ บนแอพพลิเคชัน Android สำหรับบทความนี้จะใช้ Library ที่ชื่อว่า AChartEngine ตัวอย่าง AChartEngine ทำอะไรได้บ้าง ก็ดูได้จากลิงค์นี้ครับ ตัวอย่าง AChartEngine
มาเข้าเรื่องเลยดีกว่า บทความนี้จะเป็นการแสดง Line Chart (กราฟเส้น) แบบง่ายๆให้ดูนะครับ เริ่มต้น ก็สร้างโปรเจ็คแบบปกติ ไฟล์ที่ต้องใช้มีแค่ 2 ไฟล์ครับ คือ ไฟล์ Activity กับ ไฟล์เลเอาท์ xml
บทความนี้ใช้ Eclipse รันบน Ubuntu 14.04 นะครับ
Add Library
ทำการโหลด Library ของ AChartEngine ที่นี่ เลือกดาวน์โหลด achartengine-1.1.0.jar จากนั้นก็ import ไปที่โปรเจ็คของเรา
สำหรับ Eclipse ก็อปปี้ไฟล์ achartengine-1.1.0.jar ไปไว้ที๋โฟลเดอร์ libs
ของโปรเจ็ค จากนั้นคลิกขวาที่ไฟล์ เลือก Build Path -> Add to Build Path
สำหรับ Android Studio มีสองทางเลือกครับ คือ ก็อปไปไว้ที่โฟลเดอร์ libs
เช่นเดียวกัน จากนั้นแก้ไขไฟล์ build.gradle
โดยเพิ่ม dependencies ดังนี้
หากใครมีแล้ว ก็ไม่ต้องแก้อะไร (คำสั่งด้านบนเป็นการสั่ง compile ไฟล์ .jar ทั้งหมดที่อยู่ในโฟลเดอร์ libs)
อีกวิธีหนึ่ง สำหรับคนใช้ maven ครับ เปิด build.gradle
ที่ root โปรเจ็คนะครับ แล้วเพิ่ม นี้ลงไป
จะได้เป็นแบบนี้
ส่วนไฟล์ build.gradle
ที่อยู่ใน module ก็เพิ่ม dependencies เข้าไปเป็นแบบนี้
Getting Started with AChartEngine
ก่อนที่จะไปสร้าง Line Chart (กราฟเส้น) ด้วย AChartEngine เรามาดูภาพรวม แล้วก็แต่ละคลาสที่ใช้กันก่อนครับ
XYSeries
: ตัวนี้จะเปรียบเสมือนข้อมูลของกราฟเรา เช่น รายได้ จำนวนประชากร เป็นต้นXYSeriesRenderer
: ตัวนี้จะเอาไว้ render กราฟเราครับ เช่น รูปทรงกราฟ สี รูปแบบต่างๆ ปรับแต่งได้XYMultipleSeriesDataset
: ตัวนี้คือ Dataset มันคือข้อมูลทั้งหมดของกราฟ โดยดึงมาจากXYSeries
XYMultipleSeriesRenderer
: ตัวนี้คือตัว render ทั้งกราฟครับGraphicalView
: ตัวนี้คือ View ชนิดหนึ่ง ที่เอาไว้แสดง graph ครับ
รายละเอียดคร่าวๆ ก็เป็นดังนี้ หากใครงง (แน่นอนว่าต้องงง ถ้าเพิ่งเคยทำ ต้องลองดูตัวอย่าง แล้วจะเข้าใจมากขึ้นครับ)
เริ่มสร้างกราฟ
เป้าหมายคือ ต้องการสร้างกราฟข้อมูลยอดขาย ของ 3 บริษัท ในปีๆหนึ่ง ฉะนั้นกราฟก็จะมี 3 เส้น แบบนี้
ให้เปิดคลาส MainActivity.java
ขึ้นมา โค๊ดเริ่มต้นผมเป็นแบบนี้
ใครใช้ fragment ไม่เป็น แนะนำให้อ่าน Android Fragment คือ? จริงๆควรจะใช้ fragment ในทุกๆโปรเจ็คนะครับ
ก่อนสร้างกราฟ เราต้องมีข้อมูลก่อน ฉะนั้น สร้างข้อมูลจำลองขึ้นมา โดยสร้างเมธอดใหม่ ชื่อ initData()
แบบนี้
โค๊ดด้านบน months
หมายถึง ข้อมูลที่่จะแสดงบนแกน x ระบุว่าแต่ละเดือนยอดขายเป็นยังไง ส่วน index
คือตำแหน่งของข้อมูล โดยใช้ข้อมูล 3 บริษัท ได้แก่ incomeA
, incomeB
และ incomeC
เมื่อมีข้อมูลดิบแล้ว ขั้นตอนต่อมาทำอย่างไร?
ใช้ XYSeries
เพื่อเก็บข้อมูลที่ของเราแบบนี้ (ยังอยู่ในเมธอด initData()
นะ)
ต่อมาใช้ XYSeriesRenderer
เพื่อจะกำหนดให้กราฟออกมาลักษณะไหน
ด้านบนเป็นการกำหนด ให้แสดง กราฟเป็นจุดและเป็นสีแดง
ต่อมาสร้าง dataset ขึ้นมาโดยใช้ XYMultipleSeriesDataset
แล้วทำการเพิ่ม XYSeries
ทั้ง 3 ที่สร้างไว้ก่อนหน้านี้ ดังนี้
ต่อมาใช้ XYMultipleSeriesRenderer
เพื่อที่จะแสดงกราฟทั้งหมด ขึ้นตอนนี้คือการปรับแต่ง และตั้งค่ากราฟก่อนครับ
จะเห็นว่าด้านบน เป็นการกำหนด ข้อความที่จะแสดงในแกน x คือแสดงเดือน ที่เก็บไว้ใน months
ส่วนอันอื่นก็ดูตามชื่อเมธอดเลยครับ มัน make sense อยู่แล้ว สุดท้าย ก็ต้องเพิ่ม XYSeriesRenderer
ไปที่ XYMultipleSeriesRenderer
ด้วย
ข้อควรระวัง
dataset
และXYSeriesRenderer
ต้องมีจำนวนเท่ากันนะครับdataset
เราเพิ่ม Series ไปเท่าไหร่XYMultipleSeriesRenderer
ก็ต้องเพิ่มXYSeriesRenderer
จำนวนเดียวกันด้วยครับ
ต่อมาเพิ่มอีกหนึ่งบรรทัด เป็นอันจบเมธอด initData()
ปล่อยให้ error ไว้ก่อนครับ เนื่องจากเรายังไม่ได้ทำการสร้าง เมธอด drawChart()
ให้ไปสร้างเลเอาท์ xml ก่อน
สร้างไฟล์ XML
การสร้างเลเอาท์ xml ไม่มีอะไรมากครับ แค่สร้าง ViewGroup
ให้มันซักตัว จะเป็น RelativeLayout
หรือ LinearLayout
ก็ได้ อย่างในบทความ ใช้ RelativeLayout
โดยใช้ไฟล์ res/layout/fragment_main.xml
จะได้ดังนี้
ต่อมาที่คลาส PlachHolderFragment
ภายในคลาส MainActivity
ก็เพ่ิมนี้ลงไป
เพื่อจะเอา View ที่สร้างจาก onCreateView()
ไปใช้ในการสร้าง graph ครับ เลยต้องประกาศเป็นตัวแปร global ไว้
ต่อมาได้เวลาเพิ่มเมธอด drawChart()
ซักที ภายในเมธอดก็มีโค๊ดแบบนี้
เราใช้ GraphicalView
ซึ่งมันก็คือ View
นั่นแหละ เหมือนๆกับ TextView, EditText, Button ทั่วๆไป จากนั้น ก็ใช้ RelativeLayout
ที่เราได้สร้างไว้ใน fragment_main.xml
ที่ชื่อว่า graph_container
ทำการ addView()
ซะ เป็นอันจบ
เมื่อเปิดโปรแกรมขึ้นมา จะได้ดังภาพ
!!! แต่เดี๋ยวก่อน ในเมื่อมีกราฟ ถึง 3 อัน ซึ่งสีเหมือนกัน มันดุยาก เราอยากจะปรับเปลี่ยนสีทำยังไงละ ? แน่นอนครับ ก็ใช้ XYSeriesRenderer
เข้ามาช่วย ฉะนั้นผมสร้าง XYSeriesRenderer
เพิ่ม 2 ตัว ในเมธอด initData()
ดังนี้
แล้ว XYMultipleSeriesRenderer
ก็เพิ่ม XYSeries
ให้มันซะ จาก
ก็จะได้เป็น
ลองรันโปรแกรมใหม่ ผลลัพธ์เป็นแบบนี้
ยังไม่จบ เรายังสามารถปรับแต่งกราฟได้อีก โดยผมปรับแต่ง XYMultipleSeriesRenderer
อีกเป็นแบบนี้
ข้างบนคือปรับสี background ปรับสี แกน x, y ปรับตัวหนังสือ และที่สำคัญ ปรับค่า x ให้เป็น 0 เนื่องจากมันจะไปทับกับค่า เดือน ที่เรากำหนดไว้นั่นเอง
สุดท้าย ก็ได้กราฟออกมาเป็นแบบลักษณะดังรูป
สรุป
ตัวอย่างนี้ก็เป็นตัวอย่างการใช้ AChartEngine โดยการวาด Line Chart (กราฟแท่ง) แบบง่ายๆนั้นเอง หวังว่าผู้อ่านทุกท่าน สามารถนำไปประยุกต์ ปรับแต่ง ใช้งานให้เข้ากับแอพของท่านได้นะครับ
สุดท้าย โค๊ดตัวอย่าง อัพลง Github เรียบร้อยแล้ว ไปดูได้ที่นี่ครับ
- Authors
-
Chai Phonbopit
เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust