สร้างกราฟ Pie Chart บน Android ด้วย AChartEngine
บทความสอนเขียนแอพ Android วันนี้ขอนำเสนอเรื่อง การเขียนกราฟด้วย AChartEngine สำหรับบทความนี้จะเป็นการแสดง Pie Chart แบบง่ายๆให้ดูนะครับ เริ่มต้น ก็สร้างโปรเจ็คแบบปกติ ไฟล์ที่ต้องใช้มีแค่ 2 ไฟล์ครับ คือ ไฟล์ Activity กับ ไฟล์เลเอาท์ xml (หรือว่าจะใช้คลาสเก่าจากโปรเจ็คที่แล้วก็ได้)
สำหรับใครที่ยังไม่รู้จัก AchartEngine แนะนำให้อ่านบทความแรกที่ผมเขียน ได้ที่นี่ครับ สร้างกราฟ Line Chart บน Android ด้วย AChartEngine
Getting Started with AChartEngine
ก่อนที่จะไปสร้าง Pie Chart ด้วย AChartEngine เรามาดูภาพรวม แล้วก็แต่ละคลาสที่ใช้กันก่อนครับ
CategorySeries
: ตัวนี้คือข้อมูลของกราฟ Pie ของเรา โดยจะแบ่งเป็นแต่ละชิ้นตามจำนวนข้อมูลของเราSimpleSeriesRenderer
: ตัวนี้เอาไว้ render Pie แต่ละชิ้นของเราครับ เช่นพวก ปรับสีต่างๆDefaultRenderer
: ตัวนี้สำหรับ render ทั้งกราฟ (คล้ายๆกับXYMultipleSeriesRenderer
)GraphicalView
: ตัวนี้คือ View ชนิดหนึ่ง ที่เอาไว้แสดง graph ครับ
รายละเอียดคร่าวๆ ก็เป็นดังนี้ หากใครงง (แน่นอนว่าต้องงง ถ้าเพิ่งเคยทำ ต้องลองดูตัวอย่าง แล้วจะเข้าใจมากขึ้นครับ) คิดว่า Pie Chart เขียนง่ายกว่า Line Chart แน่นอนครับ หากเข้าใจ Line Chart จากบทความก่อนหน้า บทความนี้ต้องบอกว่าง่ายมากๆครับ
เริ่มสร้างกราฟ
เป้าหมายคือ ต้องการแสดงกราฟ Pie Chart โดยดึงข้อมูลเวอร์ชันของ Android จากเว็บนี้ Android Dashboard
ทำการสร้างคลาสแอคติวิตี้ขึ้นมาใหม่ ตั้งชื่อว่า PieChartActivity.java
ขึ้นมา โค๊ดเริ่มต้นผมเป็นแบบนี้
fragment_main
จะใช้อันเดียวกันกับโปรเจ็คที่แล้วนะครับ เนื่องจากมันไม่มีอะไรเลย มีแค่ RelativeLayout
อันเดียวเอง
ใครใช้ fragment ไม่เป็น แนะนำให้อ่าน Android Fragment คือ? จริงๆควรจะใช้ fragment ในทุกๆโปรเจ็คนะครับ
ก่อนสร้างกราฟ เราต้องมีข้อมูลก่อน ฉะนั้น สร้างข้อมูลขึ้นมาโดยอ้างอิงข้อมูลจากเว็บ โดยสร้างเมธอดใหม่ ชื่อ initData()
แบบนี้
จากโค๊ดด้านบน codename
คือชื่อเวอร์ชันของแอนดรอยส์ ส่วน values
คือข้อมูลที่เรามี และ colors
หมายถึงสีแต่ละชิ้นของ Pie ว่าจะให้สีอะไรบ้าง ต่อมาเมื่อมีข้อมูลแล้ว ก็เริ่มทำการสร้างกราฟได้เลย
Pie Chart จะใช้ CategorySeries
ในการเก็บข้อมูล ฉะนั้นก็สร้างแบบนี้เลย (ยังอยู่ในเมธอด initData()
นะ)
ต่อมาใช้ DefaultRenderer
และ SimpleSeriesRenderer
เพื่อไว้ render กราฟ โดย SimpleSeriesRenderer
คือการ render Pie แต่ละชิ้น ในขณะที่ DefaultRenderer
ใช้ render Pie ทั้งก้อน
ด้านบนเป็นการกำหนด ให้แสดง Pie แต่ละชิ้น โดยใช้สีที่กำหนดไว้
ปรับแต่งหน้าตา Chart ซักเล็กน้อย เพราะตัวหนังสือเล็กไปหน่อย
สุดท้ายเพิ่มอีกหนึ่งบรรทัด เป็นอันจบเมธอด initData()
ปล่อยให้ error ไว้ก่อนครับ เนื่องจากเรายังไม่ได้ทำการสร้าง เมธอด drawChart()
ให้ไปสร้างเลเอาท์ xml ก่อน
สร้างไฟล์ XML
จริงๆ ใช้ xml จากบทความก่อนก็ได้ครับ แต่ว่ารอบนี้ผมกะให้มันมี padding ด้วยเนื่องจากมันจะดูสวยกว่าครับ จะได้ดังนี้
ต่อมาที่คลาส PlachHolderFragment
ภายในคลาส MainActivity
ก็เพ่ิมนี้ลงไป
เพื่อจะเอา View ที่สร้างจาก onCreateView()
ไปใช้ในการสร้าง graph ครับ เลยต้องประกาศเป็นตัวแปร global ไว้
ต่อมาได้เวลาเพิ่มเมธอด drawChart()
ซักที ภายในเมธอดก็มีโค๊ดแบบนี้
เราใช้ GraphicalView
ซึ่งมันก็คือ View
นั่นแหละ เหมือนๆกับ TextView, EditText, Button ทั่วๆไป จากนั้น ก็ใช้ RelativeLayout
ที่เราได้สร้างไว้ใน fragment_main.xml
ที่ชื่อว่า graph_container
ทำการ addView()
ซะ เป็นอันจบ
เมื่อเปิดโปรแกรมขึ้นมา จะได้ดังภาพ
สรุป
ตัวอย่างนี้ก็เป็นตัวอย่างการใช้ AChartEngine โดยการวาด Pie Chart แบบง่ายๆนั้นเอง หวังว่าผู้อ่านทุกท่าน สามารถนำไปประยุกต์ ปรับแต่ง ใช้งานให้เข้ากับแอพของท่านได้นะครับ
สุดท้าย โค๊ดตัวอย่าง อัพลง gist เรียบร้อยแล้ว ไปดูได้ที่นี่ครับ
- Authors
-
Chai Phonbopit
เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust