This is a simple chart library built with Jetpack Compose.
Inspired by: https://github.com/AppPear/ChartView
Public API: https://dautovicharis.github.io/Charts/2.0.0-SNAPSHOT/
- Animations
- M3 theme support
- Customizable chart styles
- Various data set support
- Multiplatform: Android, iOS, Desktop, Web.
commonMain.dependencies {
implementation("io.github.dautovicharis:charts:<version>")
}
dependencyResolutionManagement {
repositories {
mavenCentral()
}
}
https://central.sonatype.com/search?q=io.github.dautovicharis.charts
implementation("io.github.dautovicharis:charts-iosx64:<version>")
implementation("io.github.dautovicharis:charts-iosarm64:<version>")
implementation("io.github.dautovicharis:charts-jvm:<version>")
implementation("io.github.dautovicharis:charts-js:<version>")
implementation("io.github.dautovicharis:charts-android:<version>")
commonMain.dependencies {
implementation("io.github.dautovicharis:charts:<snapshot-version>")
}
dependencyResolutionManagement {
repositories {
maven("https://s01.oss.sonatype.org/content/repositories/snapshots")
}
}
![](https://private-user-images.githubusercontent.com/7049715/306667285-96667aad-abbc-4dd2-b623-e5edc817e897.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2NzI4NS05NjY2N2FhZC1hYmJjLTRkZDItYjYyMy1lNWVkYzgxN2U4OTcuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9MjQyMDdjYWMxZjM5NDRjYzFjOTdhZTkzYTg2YmJiN2Q2OWI3OGJmMWMxNDc3ODM1YWU4MGQzMWJjY2E5YjI3ZCZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.jvklT3Od3nkqcxCph_LPQX27trZ8WRGIZMuvc8D4UMA)
@Composable
private fun AddDefaultPieChart() {
val dataSet = ChartDataSet(
items = listOf(8.0f, 23.0f, 54.0f, 32.0f, 12.0f, 37.0f, 7.0f, 23.0f, 43.0f),
title = stringResource(id = R.string.pie_chart),
postfix = " °C"
)
PieChartView(dataSet = dataSet)
}
![](https://private-user-images.githubusercontent.com/7049715/306667519-d5c3c054-04b5-4d17-a29c-effafbb7b083.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2NzUxOS1kNWMzYzA1NC0wNGI1LTRkMTctYTI5Yy1lZmZhZmJiN2IwODMuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9ZmU2NDM5MWM4Mjg1Nzc1NmRhOGU4NDVkYzE4MzMwMWRmNjc2NmE2NDEwNDIwZTgxMTcxZmVhNTUwM2YxMjBjZCZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.V6fcydpRaVNC7VKcc2lWhuL55MLWlGb_uExKm4erCwA)
@Composable
private fun AddCustomPieChart() {
val pieColors = listOf(
ColorPalette.DataColor.navyBlue,
ColorPalette.DataColor.darkBlue,
ColorPalette.DataColor.deepPurple,
ColorPalette.DataColor.magenta,
ColorPalette.DataColor.darkPink,
ColorPalette.DataColor.coral,
ColorPalette.DataColor.orange,
ColorPalette.DataColor.yellow
)
val style = PieChartDefaults.style(
borderColor = Color.White,
donutPercentage = 40f,
borderWidth = 6f,
pieColors = pieColors,
chartViewStyle = ChartViewDemoStyle.custom(width = 200.dp)
)
val dataSet = ChartDataSet(
items = listOf(60.0f, 25f, 15f, 14f, 30f, 30f, 20f, 30f),
title = stringResource(id = R.string.pie_chart),
postfix = " °C"
)
PieChartView(dataSet = dataSet, style = style)
}
![](https://private-user-images.githubusercontent.com/7049715/306668120-6fed622d-44f1-4fac-98bc-6637e91e04b6.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2ODEyMC02ZmVkNjIyZC00NGYxLTRmYWMtOThiYy02NjM3ZTkxZTA0YjYuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9ODUwNWE1NzA1MTExNWZmZmEyYWVmODBiYjk1Zjg4NzBlOGY3NTU1ZGJiMzU0MTBlOWY3MDcyOTRhYTAzNWFjMiZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.0LZyn3lgER0VTRIS2jJItisEXlT2jVu6N3VFkssCIL8)
@Composable
private fun AddDefaultLineChart() {
val dataSet = ChartDataSet(
items = listOf(
8f, 23f, 54f, 32f, 12f, 37f, 7f, 23f, 43f
),
title = stringResource(id = R.string.line_chart)
)
LineChartView(dataSet = dataSet)
}
![](https://private-user-images.githubusercontent.com/7049715/306668162-a2d76189-1b62-4740-8ef0-d241af5770ae.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2ODE2Mi1hMmQ3NjE4OS0xYjYyLTQ3NDAtOGVmMC1kMjQxYWY1NzcwYWUuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9NmQ4MzE5ZDYwMGE4ZDcwZjA4ZGNiNzE4YzRlZDhkNzZjZWQyMWQzMGJkMjRjN2NjM2VkNzYwMTBlNWNjMjdmZiZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.lMMAImbRmpCvqFN3MjRHecENZWh0-VhEZEm7R6N4g4k)
@Composable
private fun AddCustomLineChart() {
val style = LineChartDefaults.style(
lineColor = ColorPalette.DataColor.deepPurple,
pointColor = ColorPalette.DataColor.magenta,
pointSize = 9f,
bezier = false,
dragPointColor = ColorPalette.DataColor.deepPurple,
dragPointVisible = false,
dragPointSize = 8f,
dragActivePointSize = 15f,
chartViewStyle = ChartViewDemoStyle.custom(width = 200.dp)
)
val dataSet = ChartDataSet(
items = listOf(10f, 100f, 20f, 50f, 150f, 70f, 10f, 20f, 40f),
title = stringResource(id = R.string.line_chart)
)
LineChartView(dataSet = dataSet, style = style)
}
![](https://private-user-images.githubusercontent.com/7049715/306668925-3d84d832-c3f4-4af4-9c57-b2006b38147d.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2ODkyNS0zZDg0ZDgzMi1jM2Y0LTRhZjQtOWM1Ny1iMjAwNmIzODE0N2QuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9NmU3NjRjNWY1NzQzZmM1NTI1YWQ3ZWFmNDE0NDVmMmZjNDEzM2IyZTIzODVkOGY3MjJkYzZiOTc5NWJlMDI0NSZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.zjaH5un5F97aUn6_LH5kQoH7LfIlCnW21tqS-L7BODE)
@Composable
private fun AddDefaultMultiLineChart() {
val items = listOf(
"Cherry St." to listOf(26000.68f, 28000.34f, 32000.57f, 45000.57f),
"Strawberry Mall" to listOf(15261.68f, 17810.34f, 40000.57f, 85000f),
"Lime Av." to listOf(4000.87f, 5000.58f, 30245.81f, 135000.58f),
"Apple Rd." to listOf(1000.87f, 9000.58f, 16544.81f, 100444.87f)
)
val dataSet = MultiChartDataSet(
items = items,
prefix = "$",
categories = listOf("Jan", "Feb", "Mar", "Apr"),
title = stringResource(id = R.string.line_chart)
)
LineChartView(
dataSet = dataSet, style = MultiLineDemoStyle.default()
)
}
![](https://private-user-images.githubusercontent.com/7049715/306668975-7a2dd09b-5c71-4ce6-a96d-5e3fd79e682f.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2ODk3NS03YTJkZDA5Yi01YzcxLTRjZTYtYTk2ZC01ZTNmZDc5ZTY4MmYuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9NjFlYWRkY2JhNDc2NDZkMzFkZTIxN2FlYWM4MDY1MjcyYjM2YjRlZDVlMjBmMmM5YWMxMTQxNjcwN2Q1NjZmNyZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.ByPnW96GqZB0-s_vbo_Mr4dLEuI2Q8eM61LhnJKNzMc)
@Composable
private fun AddCustomMultiLineChart() {
val lineColors = listOf(ColorPalette.DataColor.navyBlue, ColorPalette.DataColor.darkBlue, ColorPalette.DataColor.deepPurple, ColorPalette.DataColor.magenta)
val style = LineChartDefaults.style(
lineColors = lineColors,
dragPointVisible = false,
pointVisible = true,
pointColor = ColorPalette.DataColor.magenta,
dragPointColor = ColorPalette.DataColor.deepPurple,
chartViewStyle = ChartViewDemoStyle.custom()
)
val items = listOf(
"Cherry St." to listOf(26000.68f, 28000.34f, 32000.57f, 45000.57f),
"Strawberry Mall" to listOf(15261.68f, 17810.34f, 40000.57f, 85000f),
"Lime Av." to listOf(4000.87f, 5000.58f, 30245.81f, 135000.58f),
"Apple Rd." to listOf(1000.87f, 9000.58f, 16544.81f, 100444.87f)
)
val dataSet = MultiChartDataSet(
items = items,
prefix = "$",
categories = listOf("Jan", "Feb", "Mar", "Apr"),
title = stringResource(id = R.string.line_chart)
)
LineChartView(dataSet = dataSet, style = style)
}
![](https://private-user-images.githubusercontent.com/7049715/306669928-4de8c2be-0548-49b7-aba6-f72449c75298.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2OTkyOC00ZGU4YzJiZS0wNTQ4LTQ5YjctYWJhNi1mNzI0NDljNzUyOTguZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9MTgyN2QxYWE5NTA5NjkwMWU1NTg3Y2ZhZjEzYzdhN2RiM2I4YjNmMWJkMWI4Mzk5MWExN2MyMzY2MTQ1ZjBjYSZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.XMAHKzk0Xs2_0LU6M6QMm617ATVbkthvjN2anQJEDXg)
@Composable
private fun AddDefaultBarChart() {
BarChartView(
dataSet = ChartDataSet(
items = listOf(100f, 50f, 5f, 60f, -50f, 50f, 60f),
title = stringResource(id = R.string.bar_chart)
)
)
}
![](https://private-user-images.githubusercontent.com/7049715/306669956-2e8d4193-186e-4bb6-b71c-21f6bb289921.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY2OTk1Ni0yZThkNDE5My0xODZlLTRiYjYtYjcxYy0yMWY2YmIyODk5MjEuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9ZThjMTVhZGIxYWViNDBlZGUyYjQ0ZTc0OGMzZTE3OGMwZDNhNGNmMDE4ZGQzZmIyNzFjMzMxZDQ1MzNhZTUwMCZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.j0cLrL-UTLbBuBrplDDc8MLjCcK3J89wyGpzuyGFk10)
@Composable
private fun AddCustomBarChart() {
val style = BarChartDefaults.style(
barColor = ColorPalette.DataColor.deepPurple,
space = 12.dp,
chartViewStyle = ChartViewDemoStyle.custom(width = 200.dp)
)
BarChartView(
dataSet = ChartDataSet(
items = listOf(100f, 50f, 5f, 60f, 1f, 30f, 50f, 35f, 50f, -100f),
title = stringResource(id = R.string.bar_chart)
),
style = style
)
}
![](https://private-user-images.githubusercontent.com/7049715/306670184-9b526a26-d8e9-4779-8957-208231c9f518.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY3MDE4NC05YjUyNmEyNi1kOGU5LTQ3NzktODk1Ny0yMDgyMzFjOWY1MTguZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9MDNkY2IwMjRjZDA4NTAzMDAwZDU5MjkwNjMzZjUwYjM1ZTAxNTEwOGY2YjgzNzFjYjAwMmFhYTZlZTM0OTgzMyZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.-yh-goLvTzNhRe5JivEjSGMU6q8gbYSa-BAiteayCT8)
@Composable
private fun AddDefaultStackedBarChart() {
val items = listOf(
"Cherry St." to listOf(8261.68f, 8810.34f, 30000.57f),
"Strawberry Mall" to listOf(8261.68f, 8810.34f, 30000.57f),
"Lime Av." to listOf(1500.87f, 2765.58f, 33245.81f),
"Apple Rd." to listOf(5444.87f, 233.58f, 67544.81f)
)
val dataSet = MultiChartDataSet(
items = items,
prefix = "$",
categories = listOf("Jan", "Feb", "Mar"),
title = stringResource(id = R.string.bar_stacked_chart)
)
StackedBarChartView(dataSet = dataSet)
}
![](https://private-user-images.githubusercontent.com/7049715/306670224-942be853-f82b-420c-b829-a1fa431cfe57.gif?jwt=eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpc3MiOiJnaXRodWIuY29tIiwiYXVkIjoicmF3LmdpdGh1YnVzZXJjb250ZW50LmNvbSIsImtleSI6ImtleTUiLCJleHAiOjE3MTk4NzUxODIsIm5iZiI6MTcxOTg3NDg4MiwicGF0aCI6Ii83MDQ5NzE1LzMwNjY3MDIyNC05NDJiZTg1My1mODJiLTQyMGMtYjgyOS1hMWZhNDMxY2ZlNTcuZ2lmP1gtQW16LUFsZ29yaXRobT1BV1M0LUhNQUMtU0hBMjU2JlgtQW16LUNyZWRlbnRpYWw9QUtJQVZDT0RZTFNBNTNQUUs0WkElMkYyMDI0MDcwMSUyRnVzLWVhc3QtMSUyRnMzJTJGYXdzNF9yZXF1ZXN0JlgtQW16LURhdGU9MjAyNDA3MDFUMjMwMTIyWiZYLUFtei1FeHBpcmVzPTMwMCZYLUFtei1TaWduYXR1cmU9YWI0NDQ3OWQ5MjU1NmUyZjM1OWU5ZjdlY2YwYmZlMjZhNTZiZGI0ODFiYTdjOGU1YjkyZjM2NTIwNWVkMDYwYyZYLUFtei1TaWduZWRIZWFkZXJzPWhvc3QmYWN0b3JfaWQ9MCZrZXlfaWQ9MCZyZXBvX2lkPTAifQ.1PH8rmKaW-0tomwPjuYnRs8RmkYJDDC9IXvvyEWcuLE)
@Composable
private fun AddCustomStackedBarChart() {
val colors = listOf(
ColorPalette.DataColor.navyBlue,ColorPalette.DataColor.darkBlue,ColorPalette.DataColor.deepPurple
)
val style = StackedBarChartDefaults.style(
barColors = colors,
chartViewStyle = ChartViewDemoStyle.custom(width = 240.dp)
)
val items = listOf(
"Cherry St." to listOf(8261.68f, 8810.34f, 30000.57f),
"Strawberry Mall" to listOf(8261.68f, 8810.34f, 30000.57f),
"Lime Av." to listOf(1500.87f, 2765.58f, 33245.81f),
"Apple Rd." to listOf(5444.87f, 233.58f, 67544.81f)
)
val dataSet = MultiChartDataSet(
items = items,
prefix = "$",
categories = listOf("Jan", "Feb", "Mar"),
title = stringResource(id = R.string.bar_stacked_chart)
)
StackedBarChartView(dataSet = dataSet, style = style)
}
🌟 Thank you for your time! Before you start working on code, please create a new issue.