이 예제는 Android에서 막대 차트 그래프를 사용하는 방법을 보여줍니다.
1단계 − Android Studio에서 새 프로젝트를 생성하고 파일 ⇒ 새 프로젝트로 이동하여 필요한 모든 세부 정보를 입력하여 새 프로젝트를 생성합니다.
2단계 − build.gradle(모듈 수준)을 열고 라이브러리 종속성을 추가합니다.
apply plugin: 'com.android.application' android { packagingOptions { exclude 'META-INF/proguard/androidx-annotations.pro' } packagingOptions { exclude 'META-INF/DEPENDENCIES' exclude 'META-INF/LICENSE' exclude 'META-INF/LICENSE.txt' exclude 'META-INF/license.txt' exclude 'META-INF/NOTICE' exclude 'META-INF/NOTICE.txt' exclude 'META-INF/notice.txt' exclude 'META-INF/ASL2.0' } compileSdkVersion 28 defaultConfig { applicationId "com.example.andy.myapplication" minSdkVersion 15 targetSdkVersion 28 versionCode 1 versionName "1.0" testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner" } buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } } } dependencies { implementation fileTree(dir: 'libs', include: ['*.jar']) implementation 'com.android.support:appcompat-v7:28.0.0' implementation 'com.android.support.constraint:constraint-layout:1.1.3' implementation 'com.github.PhilJay:MPAndroidChart:v3.1.0-alpha' testImplementation 'junit:junit:4.12' androidTestImplementation 'com.android.support.test:runner:1.0.2' androidTestImplementation 'com.android.support.test.espresso:espresso-core:3.0.2' }
3단계 − build.gradle(어플리케이션 레벨)을 열고 라이브러리 종속성을 추가합니다.
// Top-level build file where you can add configuration options common to all sub-projects/modules. buildscript { repositories { google() jcenter() } dependencies { classpath 'com.android.tools.build:gradle:3.2.1' // NOTE: Do not place your application dependencies here; they belong // in the individual module build.gradle files } } allprojects { repositories { google() jcenter() maven { url 'https://jitpack.io' } } } task clean(type: Delete) { delete rootProject.buildDir }
4단계 − res/layout/activity_main.xml에 다음 코드를 추가합니다.
<?xml version = "1.0" encoding = "utf-8"?> <android.support.constraint.ConstraintLayout xmlns:android = "https://schemas.android.com/apk/res/android" xmlns:app = "https://schemas.android.com/apk/res-auto" xmlns:tools = "https://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/BarChart" android:layout_width = "fill_parent" android:layout_height = "fill_parent" /> </android.support.constraint.ConstraintLayout>
위의 코드에서는 막대 차트 보기를 사용하여 막대 차트를 표시했습니다.
4단계 − src/MainActivity.java
에 다음 코드 추가package com.example.andy.myapplication; import android.graphics.Color; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import com.github.mikephil.charting.charts.BarChart; import com.github.mikephil.charting.data.BarData; import com.github.mikephil.charting.data.BarDataSet; import com.github.mikephil.charting.data.BarEntry; import com.github.mikephil.charting.utils.ColorTemplate; import java.util.ArrayList; public class MainActivity extends AppCompatActivity { BarChart barChart; BarData barData; BarDataSet barDataSet; ArrayList barEntries; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); barChart = findViewById(R.id.BarChart); getEntries(); barDataSet = new BarDataSet(barEntries, ""); barData = new BarData(barDataSet); barChart.setData(barData); barDataSet.setColors(ColorTemplate.JOYFUL_COLORS); barDataSet.setValueTextColor(Color.BLACK); barDataSet.setValueTextSize(18f); } private void getEntries() { barEntries = new ArrayList<>(); barEntries.add(new BarEntry(2f, 0)); barEntries.add(new BarEntry(4f, 1)); barEntries.add(new BarEntry(6f, 1)); barEntries.add(new BarEntry(8f, 3)); barEntries.add(new BarEntry(7f, 4)); barEntries.add(new BarEntry(3f, 3)); } }
응용 프로그램을 실행해 보겠습니다. 실제 Android 모바일 장치를 컴퓨터에 연결했다고 가정합니다. Android 스튜디오에서 앱을 실행하려면 프로젝트의 활동 파일 중 하나를 열고 도구 모음에서 Run play.jpg 아이콘을 클릭합니다. 모바일 장치를 옵션으로 선택한 다음 기본 화면을 표시할 모바일 장치를 확인하십시오 –
위의 결과에서는 우리의 데이터 세트 값에 따라 막대 차트를 보여주고 있습니다.