본문 바로가기
안드로이드 자바

[Android][Java] GroupBarchart 만들기

by teamnova 2023. 5. 17.

안녕하세요. 오늘은 MP chart 라이브러리를 사용해서 막대 그래프를 그려보겠스빈다.

 

1. 라이브러리 추가하기

repositories {
        maven {
            url "https://jitpack.io"
        }
    }

dependencies {
    implementation 'com.github.PhilJay:MPAndroidChart:v3.1.0'
}

 

2. main.xml

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <com.github.mikephil.charting.charts.BarChart
        android:id="@+id/group_bar_chart"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

</androidx.constraintlayout.widget.ConstraintLayout>

3.mainActivity

public class MainActivity extends AppCompatActivity {
    private ActivityMainBinding bind;
    BarChart mpBarchart;

    // 앱이 시작될 때 호출되는 메소드
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mpBarchart = findViewById(R.id.group_bar_chart);

        // 각 데이터셋을 생성하고 색상을 설정합니다.
        BarDataSet barDataSet = new BarDataSet(barEntries(), "데이타셋 1");
        barDataSet.setColor(Color.RED);
        BarDataSet barDataSet2 = new BarDataSet(barEntries2(), "데이터셋 2");
        barDataSet2.setColor(Color.BLUE);
        BarDataSet  barDataSet3 = new BarDataSet(barEntries3(), " 데이터셋 3");
        barDataSet3.setColor(Color.MAGENTA);
        BarDataSet barDataSet4 = new BarDataSet(barEntries4(), "데이터셋 4");
        barDataSet4.setColor(Color.GREEN);

        // 데이터셋을 하나의 데이터 객체로 결합합니다.
        BarData data = new BarData(barDataSet,barDataSet2,barDataSet3,barDataSet4);
        mpBarchart.setData(data);

        // x축 레이블을 설정합니다.
        String[] days = new String[]{"일요일","월요일","화요일","수요일","목요일","금요일","토요일"};
        XAxis xAxis = mpBarchart.getXAxis();
        xAxis.setValueFormatter(new IndexAxisValueFormatter(days));
        xAxis.setCenterAxisLabels(true);
        xAxis.setPosition(XAxis.XAxisPosition.BOTTOM);
        xAxis.setGranularity(1);
        xAxis.setGranularityEnabled(true);

        // 차트의 드래그 기능을 활성화하고 최대 가시 범위를 설정합니다.
        mpBarchart.setDragEnabled(true);
        mpBarchart.setVisibleXRangeMaximum(3);

        // 막대 그래프의 간격을 설정합니다.
        float barSpace = 0.08f;
        float groupSpace = 0.44f;
        data.setBarWidth(0.10f);

        // x축의 최소값과 최대값을 설정합니다.
        mpBarchart.getXAxis().setAxisMinimum(0);
        mpBarchart.getXAxis().setAxisMaximum(0+mpBarchart.getBarData().getGroupWidth(groupSpace,barSpace)*7);
        mpBarchart.getAxisLeft().setAxisMinimum(0);

        // 막대 그래프의 그룹을 설정하고 차트를 새로 고칩니다.
        mpBarchart.groupBars(0,groupSpace,barSpace);
        mpBarchart.invalidate();
    }

    // 각 데이터셋에 대한 데이터를 반환하는 메소드들
    private ArrayList<BarEntry> barEntries(){
        ArrayList<BarEntry> barEntries = new ArrayList<>();
        barEntries.add(new BarEntry(1,2000));
        barEntries.add(new BarEntry(2,791));
        barEntries.add(new BarEntry(3,630));
        barEntries.add(new BarEntry(4,540));
        barEntries.add(new BarEntry(5,2821));
        barEntries.add(new BarEntry(6,500));
        barEntries.add(new BarEntry(7,2173));
        return  barEntries;
    }

    private ArrayList<BarEntry> barEntries2(){
        ArrayList<BarEntry> barEntries = new ArrayList<>();
        barEntries.add(new BarEntry(1,1121));
        barEntries.add(new BarEntry(2,391));
        barEntries.add(new BarEntry(3,1630));
        barEntries.add(new BarEntry(4,940));
        barEntries.add(new BarEntry(5,2121));
        barEntries.add(new BarEntry(6,777));
        barEntries.add(new BarEntry(7,1273));
        return  barEntries;
    }

    private ArrayList<BarEntry> barEntries3(){
        ArrayList<BarEntry> barEntries = new ArrayList<>();
        barEntries.add(new BarEntry(1,921));
        barEntries.add(new BarEntry(2,791));
        barEntries.add(new BarEntry(3,1690));
        barEntries.add(new BarEntry(4,1420));
        barEntries.add(new BarEntry(5,2121));
        barEntries.add(new BarEntry(6,977));
        barEntries.add(new BarEntry(7,373));
        return  barEntries;
    }

    private ArrayList<BarEntry> barEntries4(){
        ArrayList<BarEntry> barEntries = new ArrayList<>();
        barEntries.add(new BarEntry(1,1721));
        barEntries.add(new BarEntry(2,1491));
        barEntries.add(new BarEntry(3,1690));
        barEntries.add(new BarEntry(4,826));
        barEntries.add(new BarEntry(5,1221));
        barEntries.add(new BarEntry(6,2277));
        barEntries.add(new BarEntry(7,1373));
        return  barEntries;
    }

다음과 같이 GroupBarchart 그래프를 그릴 수 있습니다.