Devahoy Logo
PublishedAt

Android

Day 25 - Eaze Graph

Day 25 - Eaze Graph

สวัสดีครับ บทความนี้เป็นบทความที่ 25 แล้วนะครับ ที่ผมจะมาเขียน ในซีรีย์ Learn 30 Android Libraries in 30 days

สำหรับบทความทั้งหมด อ่านได้จากด้านล่างครับ

สำหรับวันนี้ขอนำเสนอเรื่อง EazeGraph ตัวนี้เป็น Library ที่เอาไว้แสดง Graph บน Android ะครับ คล้ายๆกับ AChartEngine และ Android GraphView แต่จุดเด่นของ Library นี้คือเน้นความสวยงามครับ สำหรับ Graph แต่ละชนิดที่ใช้ได้ใน Library ก็ได้แก่

  • LineChart
  • BarChart
  • Stacked Bar Chart
  • PieChart

Installation

ขั้นตอนการติดตั้ง เปิดไฟล์ build.gradle ขึ้นมา แล้วเพิ่ม dependencies ลงไปดังนี้

1
dependencies {
2
compile 'com.github.blackfizz:eazegraph:1.1.3-SNAPSHOT@aar'
3
}

กด Sync Gradle เป็นอันเรียบร้อย

Usage

การใช้งาน EazeGraph ในบทความนี้ ผมขอทำตัวอย่าง แค่ 3 ตัวอย่างนะครับ คือ PieChart, BarChart และ LineChart ส่วน Stacked Bar Chart มันก็คล้ายๆกับ BarChart ก็เลยไม่ทำ ไปอ่านเพิ่มเติมใน Docs ของมันเลยครับ

Pie Chart

การสร้าง PieChart จำเป็นต้องมีคลาส ดังนีครับ

  • PieChart : เป็น Container เอาไว้เก็บข้อมูลสำหรับแสดง Chart
  • PieModel : เป็นก้อน Slice ของ Pie 1 PieModel คือ Pie 1 ชิ้น สร้างได้โดย new PieChart("name", value, color)parameter คือชื่อ ค่าที่ต้องการ และสี (เป็น int เช่น 0xffff0000 หรือ `Color.parseColor(“#ff0000”))

ตัวอย่างเลเอาท์ XML ของ Pie Chart

1
<org.eazegraph.lib.charts.PieChart
2
xmlns:app="http://schemas.android.com/apk/res-auto"
3
android:id="@+id/piechart"
4
android:layout_width="match_parent"
5
android:layout_height="300dp"
6
android:padding="8dp"
7
app:egLegendTextSize="18sp"
8
app:egUsePieRotation="true"
9
app:egValueTextSize="36sp"/>

วิธีการเรียกใช้งานจากคลาส Java

1
PieChart pieChart = (PieChart) findViewById(R.id.piechart);
2
pieChart.addPieSlice(new PieModel("Name", 100, Color.parseColor("#ff0000")));

Bar Chart

การสร้าง BarChart จำเป็นต้องมีคลาสดังนี้

  • BarChart : เป็น Container เอาไว้เก็บข้อมูลและแสดงผลแบบ Bar Chart
  • BarModel : เป็นชนิดข้อมูลแบบ Bar 1 BarModel คือข้อมูล 1 แท่ง สร้างได้โดย new BarModel("name", value, color) parameter เหมือนกับการสร้าง PieModel

ตัวอย่างเลเอาท์ XML ของ Bar Chart คือ

1
<org.eazegraph.lib.charts.BarChart
2
xmlns:app="http://schemas.android.com/apk/res-auto"
3
android:id="@+id/barchart"
4
android:layout_width="match_parent"
5
android:layout_height="256dp"
6
android:padding="10dp"
7
app:egFixedBarWidth="true"
8
app:egBarWidth="20dp"
9
app:egLegendHeight="40dp"/>

วิธีการเรียกใช้งานจากคลาส Java คือ

1
BarChart barChart = (BarChart) findViewById(R.id.barchart);
2
barChart.addBar(new BarModel("MyBarChart1", 10.5f, 0xff444444));

Line Chart

การสร้าง LineChart ต้องใช้คลาสดังนี้

  • ValueLineChart : เป็น Container เอาไว้เก็บข้อมูล และแสดง Line Chart
  • ValueLineSeries : เป็นเหมือนกลุ่มข้อมูล คล้ายๆกับ Array ของข้อมูล
  • ValueLinePoint : เป็นข้อมูลแต่ละจุด เช่น แกน x = 1, x = 2, x = 3 มีค่า 2, 3, 4 ตามลำดับ วิธีการสร้างก็คือ new ValueLinePoint(name, value) parameter คือ ชื่อ และ ค่าที่ต้องการ

ตัวอย่างไฟล์เลเอาท์ XML ของ LineChart คือ

1
<org.eazegraph.lib.charts.ValueLineChart
2
xmlns:app="http://schemas.android.com/apk/res-auto"
3
android:id="@+id/cubiclinechart"
4
android:layout_width="match_parent"
5
android:layout_height="200dp"
6
app:egUseCubic="true"
7
app:egUseOverlapFill="true"
8
app:egCurveSmoothness="0.4"
9
app:egIndicatorColor="#FE6DA8"
10
app:egLegendHeight="40dp"
11
app:egShowStandardValue="true"/>

วิธีการเรียกใช้งานจากคลาส Java คือ

1
ValueLineChart lineChart = (ValueLineChart) findViewById(R.id.linechart);
2
ValueLineSeries series = new ValueLineSeries();
3
series.setColor(0xffff0000);
4
5
series.addPoint(new ValueLinePoint("Red", 24.4f));
6
series.addPoint(new ValueLinePoint("Green", 11.3f));
7
series.addPoint(new ValueLinePoint("Blue", 18.6f));
8
9
lineChart.addSeries(series);

เมื่อพอรู้รายละเอียดการใช้งานคร่าวๆแล้ว มาลองสร้างโปรเจ็คกันดูเลยครับ (หากใครต้องการรายละเอียดของ Chart เพิ่มเติม อ่าน Docs ประกอบนะครับ)

Create Project

ตัวโปรเจ็คนี้ ผมจะทำการสร้างโดยใช้ ViewPager จากนั้นก็แสดง Fragment แต่ละอย่าง แบ่งเป็น PieChartFragment, BarChartFragment และ LineChartFragment นะครับ สำหรับใครที่ไม่รู้วิธีการสร้าง ViewPager อ่านได้จากบทความนี้ประกอบครับ สอนการใช้งาน ViewPager

เริ่มแรกผมทำการสร้าง เลเอาท์หลักขึ้นมาก่อน ผมตั้งชื่อว่า activity_eazegraph.xml ภายในมีแค่ ViewPager อันเดียว ดังนี้

1
<?xml version="1.0" encoding="utf-8"?>
2
3
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
4
android:orientation="vertical"
5
android:layout_width="match_parent"
6
android:layout_height="match_parent">
7
8
<android.support.v4.view.ViewPager
9
android:id="@+id/pager"
10
xmlns:android="http://schemas.android.com/apk/res/android"
11
android:layout_width="match_parent"
12
android:layout_height="match_parent"/>
13
14
</LinearLayout>

จากนั้นสร้างคลาส Activity หลักขึ้นมา ชื่อว่า EazeGraphActivity.java ทำการ binding ViewPager จากไฟล์ xml

1
public class EazeGraphActivity extends ActionBarActivity {
2
3
private ViewPager mViewPager;
4
5
@Override
6
protected void onCreate(Bundle savedInstanceState) {
7
super.onCreate(savedInstanceState);
8
setContentView(R.layout.activity_eazegraph);
9
mViewPager = (ViewPager) findViewById(R.id.pager);
10
}
11
}

ต่อมาสร้าง Adapter ขึ้นมาโดย extends FragmentStatePagerAdapter เพื่อใช้เปลี่ยน Fragment เวลาเราเลื่อน ViewPager ตั้งชื่อคลาสว่า MyPagerAdapter อยู่ภายในคลาส EazeGraphActivity ดังนี้

1
package com.devahoy.learn30androidlibraries.day25;
2
3
import android.os.Bundle;
4
import android.support.v4.app.Fragment;
5
import android.support.v4.app.FragmentManager;
6
import android.support.v4.app.FragmentStatePagerAdapter;
7
import android.support.v4.view.PagerAdapter;
8
import android.support.v4.view.ViewPager;
9
import android.support.v7.app.ActionBarActivity;
10
11
import com.devahoy.learn30androidlibraries.R;
12
13
public class EazeGraphActivity extends ActionBarActivity {
14
15
private ViewPager mViewPager;
16
17
@Override
18
protected void onCreate(Bundle savedInstanceState) {
19
super.onCreate(savedInstanceState);
20
setContentView(R.layout.activity_eazegraph);
21
mViewPager = (ViewPager) findViewById(R.id.pager);
22
23
PagerAdapter adapter = new MyPagerAdapter(getSupportFragmentManager());
24
mViewPager.setAdapter(adapter);
25
}
26
27
public class MyPagerAdapter extends FragmentStatePagerAdapter {
28
29
private final int NUM_OF_PAGE = 3;
30
31
public MyPagerAdapter(FragmentManager fm) {
32
super(fm);
33
}
34
35
@Override
36
public Fragment getItem(int i) {
37
Fragment fragment;
38
switch (i) {
39
case 0:
40
fragment = new PieChartFragment();
41
break;
42
case 1:
43
fragment = new BarChartFragment();
44
break;
45
case 2:
46
fragment = new LineChartFragment();
47
break;
48
default:
49
fragment = new PieChartFragment();
50
}
51
return fragment;
52
}
53
54
@Override
55
public int getCount() {
56
return NUM_OF_PAGE;
57
}
58
}
59
}

จากด้านบนผมทำการสร้าง ViewPager ทั้งหมด 3 หน้า เมื่ออยู่ที่หน้าแรก จะทำการโหลด PieChartFragment มาแสดง หากเลื่อนไปหน้าสอง ก็จะโชว์ BarChartFragment และเลื่อนไปหน้าสุดท้าย ก็จะโชว์ LineChartFragment ส่วนในเมธอด onCreate() ก็ทำการสร้างออปเจ็ค MyPagerAdapter ขึ้นมา แล้วให้ ViewPager ทำการ setAdapter() ซะ เมื่อถึงตอนนี้ โค๊ดด้านบน error แน่นอน เพราะว่ายังไม่ได้สร้าง Fragment ซักอัน :D

ต่อมาสร้าง Fragment แต่ละอันเลย เริ่มจาก

PieChartFragment

ไฟล์เลเอาท์ xml

1
<?xml version="1.0" encoding="utf-8"?>
2
3
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
4
android:orientation="vertical"
5
android:gravity="center"
6
android:layout_width="match_parent"
7
android:layout_height="match_parent">
8
9
<org.eazegraph.lib.charts.PieChart
10
xmlns:app="http://schemas.android.com/apk/res-auto"
11
android:id="@+id/piechart"
12
android:layout_width="match_parent"
13
android:layout_height="400dp"
14
android:padding="8dp"
15
app:egLegendTextSize="18sp"
16
app:egUsePieRotation="true"
17
app:egValueTextSize="36sp"/>
18
19
</LinearLayout>

ตัวคลาส Java

1
package com.devahoy.learn30androidlibraries.day25;
2
3
import android.graphics.Color;
4
import android.os.Bundle;
5
import android.support.annotation.Nullable;
6
import android.support.v4.app.Fragment;
7
import android.view.LayoutInflater;
8
import android.view.View;
9
import android.view.ViewGroup;
10
11
import com.devahoy.learn30androidlibraries.R;
12
13
import org.eazegraph.lib.charts.PieChart;
14
import org.eazegraph.lib.communication.IOnItemFocusChangedListener;
15
import org.eazegraph.lib.models.PieModel;
16
17
public class PieChartFragment extends Fragment {
18
19
private PieChart mPieChart;
20
21
@Override
22
public View onCreateView(LayoutInflater inflater,
23
@Nullable ViewGroup container,
24
@Nullable Bundle savedInstanceState) {
25
26
View view = inflater.inflate(R.layout.day25_fragment_pie_chart, container, false);
27
mPieChart = (PieChart) view.findViewById(R.id.piechart);
28
initData();
29
30
return view;
31
}
32
33
@Override
34
public void onResume() {
35
super.onResume();
36
mPieChart.startAnimation();
37
}
38
39
private void initData() {
40
mPieChart.addPieSlice(new PieModel("KitKat", 17.9f,
41
Color.parseColor("#df5346")));
42
mPieChart.addPieSlice(new PieModel("Jelly Bean", 56.5f,
43
Color.parseColor("#6dd621")));
44
mPieChart.addPieSlice(new PieModel("Ice Cream Sandwich", 11.4f,
45
Color.parseColor("#1f3b83")));
46
mPieChart.addPieSlice(new PieModel("Gingerbread", 13.5f,
47
Color.parseColor("#34a394")));
48
mPieChart.addPieSlice(new PieModel("Froyo", 0.7f,
49
Color.parseColor("#22a7d0")));
50
51
mPieChart.setOnItemFocusChangedListener(new IOnItemFocusChangedListener() {
52
@Override
53
public void onItemFocusChanged(int position) {
54
// TODO: To do what you want.
55
}
56
});
57
}
58
}

ด้านบนเป็นการสร้าง Pie Chart โดยใช้ข้อมูล Android Dashboard มาแสดง

BarChart

ไฟล์เลเอาท์ xml

1
<?xml version="1.0" encoding="utf-8"?>
2
3
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
4
android:orientation="vertical"
5
android:gravity="center"
6
android:layout_width="match_parent"
7
android:layout_height="match_parent">
8
9
<org.eazegraph.lib.charts.BarChart
10
xmlns:app="http://schemas.android.com/apk/res-auto"
11
android:id="@+id/barchart"
12
android:layout_width="match_parent"
13
android:layout_height="400dp"
14
android:padding="10dp"
15
app:egFixedBarWidth="true"
16
app:egBarWidth="20dp"
17
app:egLegendHeight="40dp"/>
18
19
</LinearLayout>

ไฟล์ BarChartFragment.java

1
package com.devahoy.learn30androidlibraries.day25;
2
3
4
import android.os.Bundle;
5
import android.support.annotation.Nullable;
6
import android.support.v4.app.Fragment;
7
import android.view.LayoutInflater;
8
import android.view.View;
9
import android.view.ViewGroup;
10
11
import com.devahoy.learn30androidlibraries.R;
12
13
import org.eazegraph.lib.charts.BarChart;
14
import org.eazegraph.lib.models.BarModel;
15
16
public class BarChartFragment extends Fragment {
17
18
private BarChart mBarChart;
19
20
@Override
21
public View onCreateView(LayoutInflater inflater,
22
@Nullable ViewGroup container,
23
@Nullable Bundle savedInstanceState) {
24
25
View view = inflater.inflate(R.layout.day25_fragment_bar_chart, container, false);
26
mBarChart = (BarChart) view.findViewById(R.id.barchart);
27
28
initData();
29
30
return view;
31
}
32
@Override
33
public void onResume() {
34
super.onResume();
35
mBarChart.startAnimation();
36
}
37
38
private void initData() {
39
mBarChart.addBar(new BarModel("2010", 89.4f, 0xff663397));
40
mBarChart.addBar(new BarModel("2011", 53.0f, 0xff4183d7));
41
mBarChart.addBar(new BarModel("2012", 100, 0xff19b5fe));
42
mBarChart.addBar(new BarModel("2013", 42.9f, 0xff1e8bc3));
43
mBarChart.addBar(new BarModel("2014", 113.8f, 0xff36d7b7));
44
}
45
}

LineChart

ไฟล์เลเอาท์ xml

1
<?xml version="1.0" encoding="utf-8"?>
2
3
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
4
android:orientation="vertical"
5
android:gravity="center"
6
android:layout_width="match_parent"
7
android:layout_height="match_parent">
8
9
<org.eazegraph.lib.charts.ValueLineChart
10
xmlns:app="http://schemas.android.com/apk/res-auto"
11
android:id="@+id/linechart"
12
android:layout_width="match_parent"
13
android:layout_height="160dp"
14
app:egUseCubic="true"
15
app:egUseOverlapFill="true"
16
app:egCurveSmoothness="0.4"
17
app:egIndicatorColor="#ff1aa8fe"
18
app:egLegendHeight="40dp"
19
app:egShowStandardValue="true"/>
20
21
</LinearLayout>

ไฟล์ LineChart.java

1
package com.devahoy.learn30androidlibraries.day25;
2
3
import android.graphics.Color;
4
import android.os.Bundle;
5
import android.support.annotation.Nullable;
6
import android.support.v4.app.Fragment;
7
import android.view.LayoutInflater;
8
import android.view.View;
9
import android.view.ViewGroup;
10
11
import com.devahoy.learn30androidlibraries.R;
12
13
import org.eazegraph.lib.charts.ValueLineChart;
14
import org.eazegraph.lib.models.ValueLinePoint;
15
import org.eazegraph.lib.models.ValueLineSeries;
16
17
public class LineChartFragment extends Fragment {
18
19
private ValueLineChart mLineChart;
20
@Override
21
public View onCreateView(LayoutInflater inflater,
22
@Nullable ViewGroup container,
23
@Nullable Bundle savedInstanceState) {
24
View view = inflater.inflate(R.layout.day25_fragment_line_chart, container, false);
25
mLineChart = (ValueLineChart) view.findViewById(R.id.linechart);
26
27
initData();
28
29
return view;
30
}
31
32
@Override
33
public void onResume() {
34
super.onResume();
35
mLineChart.startAnimation();
36
}
37
private void initData() {
38
39
ValueLineSeries series = new ValueLineSeries();
40
series.setColor(Color.parseColor("#f62459"));
41
42
series.addPoint(new ValueLinePoint("Sun", 12.4f));
43
series.addPoint(new ValueLinePoint("Mon", 23.4f));
44
series.addPoint(new ValueLinePoint("Tue", 51.2f));
45
series.addPoint(new ValueLinePoint("Wed", 26.6f));
46
series.addPoint(new ValueLinePoint("Thu", 34.2f));
47
series.addPoint(new ValueLinePoint("Fri", 13.5f));
48
series.addPoint(new ValueLinePoint("Sat", 61.9f));
49
50
mLineChart.addSeries(series);
51
}
52
}

เมื่อลองรันโปรแกรม จะได้หน้าตาแบบนี้

PieChart BarChart LineChart

สรุป

จริงๆ หากใครเคยเขียน Graph/Chart ด้วย Library ตัวอื่น จะรู้สึกว่ามันคล้ายๆกันมาก วิธีการเขียน ชนิดของกราฟ แตกต่างกันบ้างเล็กน้อย หลังจากลองใช้ตัวนี้ก็รู้สึกว่า หน้าตามันสวยดี แถมมี Animation ด้วย จริงๆ AChartEngine ก็ทำได้นะ แต่ต้องปรับแต่งนานสมควร สำหรับใครที่อยากให้กราฟมันหน้าตาสวยงาม ก็ลอง EazeGraph ดูได้ครับ

สุดท้าย Source Code เหมือนเดิม จริงๆ ก็ก็อปมาแปะในบทความเกือบครบละนะ

Happy Coding :D

Authors
avatar

Chai Phonbopit

เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust

Related Posts