diff --git a/README.md b/README.md index 4a568f3a..44a5e334 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,60 @@ # YCharts -YCharts is a light and extensible chart library for Jetpack Compose system. It comprises two main modules: +YCharts is a Jetpack-compose based charts library which enables developers to easily integrate various types of charts/graphs into their existing ui to visually represent statistical data. YCharts supports both cartesian(XY-charts) and polar charts(Radial charts), which include: + +A. Cartesian charts: + 1. Line chart +
+
+ +
+
+ + 2. Bar chart +
+
+ +
+
+ + 3. Wave chart +
+
+ +
+
+ + 4. Bubble chart +
+
+ +
+
+ 5. Combined chart +
+
+ +
+
+ +B.Radial charts: + 1. Pie chart +
+
+ +
+
+ 2. Donut chart +
+
+ +
+
+ + + + + It comprises two main modules: - `YChartslib` (Chart components for Jetpack Compose) - `app` (sample app to showcase chart components) @@ -12,7 +66,7 @@ You can add the library via Maven: Gradle: ```groovy -implementation 'co.yml:ycharts:2.0.0' +implementation 'co.yml:ycharts:2.1.0' ``` ## Modules @@ -100,11 +154,18 @@ Let's see how we can use the chart components and style them with available cust
- -

Line chart looks like this!

+ +

Line chart looks like this!

+ + +

Line chart with dots looks like this!

+
+ + + ### 2. Bar Chart: - Create list of barChartData using the random generator extension and `BarData` data class. @@ -152,11 +213,15 @@ Let's see how we can use the chart components and style them with available cust
- +

Bar chart looks like this!

+ +

Horizontal Bar chart looks like this!

+
+ ### 3. Grouped Bar Chart: - Create list of grouped combinations of bar chart data using the random generator extension and `BarPlotData` data class. @@ -208,8 +273,10 @@ Let's see how we can use the chart components and style them with available cust
- +

Grouped Bar chart looks like this!

+ +

Stacked Bar chart looks like this!

@@ -253,11 +320,20 @@ Let's see how we can use the chart components and style them with available cust
- +

Pie chart looks like this!

+ + +

Pie chart with lables like this!

+
+ + + + + ### 5. Donut Chart: - Similar to pie chart here we need create list of slices using the `PieChartData` data class. @@ -300,11 +376,14 @@ Let's see how we can use the chart components and style them with available cust
- +

Donut chart looks like this!

+ + + ### 6. Combined Chart: - Similar to line and bar chart we can combine both entities in one chart, just need to initialize the line and bar plot data using the random generator extension and add styling related to individual component. @@ -374,12 +453,162 @@ Let's see how we can use the chart components and style them with available cust _Note_ : To show legends infomartion related to bar, `Legends` component can be used.
- +

Combined bar with line chart looks like this!


+ + +### 7. Wave Chart: + +- Wave charts, also referred to as waveform charts or waveform displays, are specialized visualizations used primarily in the field of signal processing and electronics. These charts illustrate the amplitude (vertical axis) and time (horizontal axis) of a waveform. + + ```kotlin + val waveChartData = WaveChartData( + wavePlotData = WavePlotData( + lines = listOf( + Wave( + dataPoints = pointsData, + waveStyle = LineStyle(color = Color.Black), + selectionHighlightPoint = SelectionHighlightPoint(), + shadowUnderLine = ShadowUnderLine(), + selectionHighlightPopUp = SelectionHighlightPopUp(), + waveFillColor = WaveFillColor(topColor = Color.Green, bottomColor = Color.Red), + ) + ) + ), + xAxisData = xAxisData, + yAxisData = yAxisData, + gridLines = GridLines() + ) + ``` + +- Initialize X and Y Axis builders using the `AxisData` data class. + + ```kotlin + val xAxisData = AxisData.Builder() + .axisStepSize(30.dp) + .steps(maxOf(barChartData.size - 1, lineChartData.size - 1)) + .bottomPadding(40.dp) + .labelData { index -> index.toString() } + .build() + + val yAxisData = AxisData.Builder() + .steps(yStepSize) + .labelAndAxisLinePadding(20.dp) + .axisOffset(20.dp) + .labelData { index -> (index * (maxRange / yStepSize)).toString() } + .build() + ``` + +- Initialize the Wave chart config data with `WaveChartData` data class in order to achieve styling and configurations related to same. + + ```kotlin + val waveChartData = WaveChartData( + wavePlotData = WavePlotData( + lines = listOf( + Wave( + dataPoints = pointsData, + waveStyle = LineStyle(color = Color.Black), + selectionHighlightPoint = SelectionHighlightPoint(), + shadowUnderLine = ShadowUnderLine(), + selectionHighlightPopUp = SelectionHighlightPopUp(), + waveFillColor = WaveFillColor(topColor = Color.Green, bottomColor = Color.Red), + ) + ) + ), + xAxisData = xAxisData, + yAxisData = yAxisData, + gridLines = GridLines() + ) + ``` + +- Finally, use the _**`WaveChart`**_ component to render the chart. + ```kotlin + WaveChart( + modifier = Modifier + .fillMaxWidth() + .height(300.dp), + waveChartData = data + ) + ``` + _Note_ : To show legends infomartion related to bar, `Legends` component can be used. +
+
+ +

Wavechart looks like this!

+ +

Sinewavechart looks like this!

+
+
+
+ +### 8. Bubble Chart: + +- Bubble charts are a variation of the scatter plot, where the data points are represented as bubbles or circles instead of simple dots. The bubbles' size represents the value of a third variable, in addition to the x-axis and y-axis variables. Bubble charts are effective in visualizing and comparing three different dimensions of data simultaneously. + + ```kotlin + val bubbleChartData = BubbleChartData( + DataUtils.getBubbleChartDataWithGradientStyle(pointsData), + xAxisData = xAxisData, + yAxisData = yAxisData, + gridLines = GridLines() + ) + ``` + +- Initialize X and Y Axis builders using the `AxisData` data class. + + ```kotlin + val xAxisData = AxisData.Builder() + .axisStepSize(30.dp) + .steps(maxOf(barChartData.size - 1, lineChartData.size - 1)) + .bottomPadding(40.dp) + .labelData { index -> index.toString() } + .build() + + val yAxisData = AxisData.Builder() + .steps(yStepSize) + .labelAndAxisLinePadding(20.dp) + .axisOffset(20.dp) + .labelData { index -> (index * (maxRange / yStepSize)).toString() } + .build() + ``` + +- Initialize the Bubble chart config data with `BubbleChartData` data class in order to achieve styling and configurations related to same. + + ```kotlin + val bubbleChartData = BubbleChartData( + DataUtils.getBubbleChartDataWithGradientStyle(pointsData), + xAxisData = xAxisData, + yAxisData = yAxisData, + gridLines = GridLines() + ) + + ``` + +- Finally, use the _**`BubbleChart`**_ component to render the chart. + ```kotlin + BubbleChart( + modifier = Modifier + .fillMaxWidth() + .height(500.dp), + bubbleChartData = data + ) + ``` + _Note_ : To show legends infomartion related to bar, `Legends` component can be used. +
+
+ +

Gradient-Bubble chart looks like this!

+ +

Bubble chart looks like this!

+
+
+
+ + ## Accessibility Support To interact with your device with touch and spoken feedback, you can turn on the TalkBack screen reader. TalkBack describes the graphs/charts when tapped on the graph container. diff --git a/YChartsLib/build.gradle.kts b/YChartsLib/build.gradle.kts index 0c79948c..b99e40b6 100644 --- a/YChartsLib/build.gradle.kts +++ b/YChartsLib/build.gradle.kts @@ -53,7 +53,7 @@ publishing { register("release") { groupId = "co.yml" artifactId = "ycharts" - version = "1.0.1" + version = "2.1.0" afterEvaluate { from(components["release"]) }