728x90
GitHUB 에 공개된 샘플 예제는 Java 버전으로 되어 있다.
코틀린 버전 예제로 변경 연습한 코드를 적어둔다.
앱 build.gradle
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
|
plugins {
id 'com.android.application'
id 'kotlin-android'
id 'kotlin-android-extensions'
id 'kotlin-kapt'
}
android {
compileSdkVersion 30
defaultConfig {
applicationId "com.kt.android.mpchart"
minSdkVersion 26
targetSdkVersion 30
versionCode 1
versionName "1.0"
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
kotlinOptions {
jvmTarget = '1.8'
}
}
dependencies {
implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
implementation 'androidx.core:core-ktx:1.5.0'
implementation 'androidx.appcompat:appcompat:1.3.0'
implementation 'com.google.android.material:material:1.3.0'
implementation 'androidx.constraintlayout:constraintlayout:2.0.4'
implementation 'com.github.PhilJay:MPAndroidChart:v3.1.0'
}
|
activity_mail.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<?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">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="200dp"
tools:ignore="MissingConstraints">
<com.github.mikephil.charting.charts.LineChart
android:id="@+id/linechart"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
</androidx.constraintlayout.widget.ConstraintLayout>
|
코틀린 코드
MainActivity.kt
서버에서 데이터를 가져왔다고 가정하고 직접 입력된 값을 표기했다.
import android.graphics.Color
import android.os.Bundle
import androidx.appcompat.app.AppCompatActivity
import com.github.mikephil.charting.charts.LineChart
import com.github.mikephil.charting.data.Entry
import com.github.mikephil.charting.data.LineData
import com.github.mikephil.charting.data.LineDataSet
import com.github.mikephil.charting.interfaces.datasets.ILineDataSet
import java.util.*
class MainActivity : AppCompatActivity() {
private val TAG = this.javaClass.simpleName
lateinit var lineChart: LineChart
private val chartData = ArrayList<ChartData>()
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
// 서버에서 데이터 가져오기 (서버에서 가져온 데이터로 가정하고 직접 추가)
chartData.clear()
addChartItem("1월", 7.9)
addChartItem("2월", 8.2)
addChartItem("3월", 8.3)
addChartItem("4월", 8.5)
addChartItem("5월", 7.3)
// 그래프 그릴 자료 넘기기
LineChart(chartData)
}
private fun addChartItem(lableitem: String, dataitem: Double) {
val item = ChartData()
item.lableData = lableitem
item.lineData = dataitem
chartData.add(item)
}
private fun LineChart(chartData: ArrayList<ChartData>) {
lineChart = findViewById(R.id.linechart)
val entries = mutableListOf<Entry>() //차트 데이터 셋에 담겨질 데이터
for (item in chartData) {
entries.add(Entry(item.lableData.replace(("[^\\d.]").toRegex(), "").toFloat(), item.lineData.toFloat()))
}
//LineDataSet 선언
val lineDataSet: LineDataSet
lineDataSet = LineDataSet(entries, "라인챠트 예시")
lineDataSet.color = Color.BLUE //LineChart에서 Line Color 설정
lineDataSet.setCircleColor(Color.DKGRAY) // LineChart에서 Line Circle Color 설정
lineDataSet.setCircleHoleColor(Color.DKGRAY) // LineChart에서 Line Hole Circle Color 설정
val dataSets = ArrayList<ILineDataSet>()
dataSets.add(lineDataSet) // add the data sets
// create a data object with the data sets
val data = LineData(dataSets)
// set data
lineChart.setData(data)
lineChart.setDescription(null); //차트에서 Description 설정 삭제
}
}
|
728x90
'안드로이드 > Kotlin 기능' 카테고리의 다른 글
[코틀린] RecyclerView + viewModel + ListAdapter + Retrofit2 (0) | 2021.09.15 |
---|---|
[코틀린] MPChart LineChart 예제 (라이브러리 2.2.5) (0) | 2021.06.14 |
코틀린 View Model 예제 (0) | 2021.06.04 |
코틀린 view binding (0) | 2021.06.03 |
[코틀린] 인터넷 IP 주소 알아내기 (0) | 2021.02.06 |