Convert Figma logo to code with AI

PhilJay logoMPAndroidChart

A powerful 🚀 Android chart view / graph view library, supporting line- bar- pie- radar- bubble- and candlestick charts as well as scaling, panning and animations.

37,586
9,016
37,586
2,185

Top Related Projects

27,556

Beautiful charts for iOS/tvOS/OSX! The Apple side of the crossplatform MPAndroidChart.

📈📊🚀🚀🚀An elegant modern declarative data visualization chart framework for iOS, iPadOS and macOS. Extremely powerful, supports line, spline, area, areaspline, column, bar, pie, scatter, angular gauges, arearange, areasplinerange, columnrange, bubble, box plot, error bars, funnel, waterfall and polar chart types. 极其精美而又强大的现代化声明式数据可视化图表框架,支持柱状图、条形图、折线图、曲线图、折线填充图、曲线填充图、气泡图、扇形图、环形图、散点图、雷达图、混合图等各种类型的多达几十种的信息图图表,完全满足工作所需.

FL Chart is a highly customizable Flutter chart library that supports Line Chart, Bar Chart, Pie Chart, Scatter Chart, and Radar Chart.

Promises for Swift & ObjC.

Android Graph Library for creating zoomable and scrollable line and bar graphs.

Quick Overview

MPAndroidChart is a powerful and flexible charting library for Android applications. It provides a wide range of chart types and customization options, allowing developers to create visually appealing and interactive charts with ease.

Pros

  • Extensive chart types: Supports line, bar, pie, scatter, bubble, candlestick, and more chart types
  • High performance: Optimized for handling large datasets and smooth animations
  • Customizable: Offers numerous styling and configuration options for charts and their components
  • Active development: Regularly updated with new features and bug fixes

Cons

  • Steep learning curve: Due to its extensive features, it may take time to master all aspects of the library
  • Limited documentation: While documentation exists, it may not cover all use cases or be as comprehensive as desired
  • Android-specific: Not suitable for cross-platform development or web applications

Code Examples

  1. Creating a basic line chart:
val entries = ArrayList<Entry>()
for (i in 0 until 10) {
    entries.add(Entry(i.toFloat(), (Math.random() * 10).toFloat()))
}

val dataSet = LineDataSet(entries, "Sample Data")
val lineData = LineData(dataSet)

chart.data = lineData
chart.invalidate()
  1. Customizing chart appearance:
val dataSet = LineDataSet(entries, "Sample Data")
dataSet.color = Color.RED
dataSet.valueTextColor = Color.BLUE
dataSet.lineWidth = 2f
dataSet.setCircleColor(Color.GREEN)

chart.description.isEnabled = false
chart.setTouchEnabled(true)
chart.isDragEnabled = true
chart.setScaleEnabled(true)
  1. Adding animations to a bar chart:
val barDataSet = BarDataSet(entries, "Bar Data")
val barData = BarData(barDataSet)

chart.data = barData
chart.animateY(1000)

Getting Started

  1. Add the dependency to your app's build.gradle file:
dependencies {
    implementation 'com.github.PhilJay:MPAndroidChart:v3.1.0'
}
  1. Add the chart view to your layout XML:
<com.github.mikephil.charting.charts.LineChart
    android:id="@+id/chart"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />
  1. Initialize and use the chart in your Activity or Fragment:
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

class MainActivity : AppCompatActivity() {
    private lateinit var chart: LineChart

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_main)

        chart = findViewById(R.id.chart)
        // Configure and populate the chart
    }
}

Competitor Comparisons

27,556

Beautiful charts for iOS/tvOS/OSX! The Apple side of the crossplatform MPAndroidChart.

Pros of Charts

  • Written in Swift, providing better performance and native iOS integration
  • Supports both iOS and macOS platforms
  • More modern and actively maintained codebase

Cons of Charts

  • Limited to Apple platforms, not cross-platform like MPAndroidChart
  • Smaller community and fewer resources compared to MPAndroidChart
  • Steeper learning curve for developers not familiar with Swift

Code Comparison

MPAndroidChart (Java):

LineDataSet dataSet = new LineDataSet(entries, "Label");
LineData lineData = new LineData(dataSet);
chart.setData(lineData);
chart.invalidate();

Charts (Swift):

let dataSet = LineChartDataSet(entries: entries, label: "Label")
let data = LineChartData(dataSet: dataSet)
chartView.data = data
chartView.notifyDataSetChanged()

Both libraries offer similar functionality for creating charts, but Charts uses Swift syntax and conventions, while MPAndroidChart uses Java. The main difference lies in the language-specific features and the platforms they support. Charts is tailored for iOS and macOS development, while MPAndroidChart is designed for Android applications. Developers should choose based on their target platform and programming language preferences.

📈📊🚀🚀🚀An elegant modern declarative data visualization chart framework for iOS, iPadOS and macOS. Extremely powerful, supports line, spline, area, areaspline, column, bar, pie, scatter, angular gauges, arearange, areasplinerange, columnrange, bubble, box plot, error bars, funnel, waterfall and polar chart types. 极其精美而又强大的现代化声明式数据可视化图表框架,支持柱状图、条形图、折线图、曲线图、折线填充图、曲线填充图、气泡图、扇形图、环形图、散点图、雷达图、混合图等各种类型的多达几十种的信息图图表,完全满足工作所需.

Pros of AAChartKit

  • Cross-platform support for iOS, Android, and web applications
  • Simpler API and easier to use for basic charting needs
  • Extensive customization options for chart appearance

Cons of AAChartKit

  • Less comprehensive documentation compared to MPAndroidChart
  • Fewer advanced chart types and features
  • Smaller community and fewer third-party resources

Code Comparison

MPAndroidChart:

LineDataSet dataSet = new LineDataSet(entries, "Label");
LineData lineData = new LineData(dataSet);
chart.setData(lineData);
chart.invalidate();

AAChartKit:

let chartModel = AAChartModel()
    .chartType(.line)
    .title("Chart Title")
    .series([
        AASeriesElement()
            .name("Series Name")
            .data([1, 2, 3, 4, 5])
    ])

MPAndroidChart offers more granular control over chart elements, while AAChartKit provides a more concise and declarative approach to chart creation. MPAndroidChart is specifically designed for Android, offering deep integration with the platform, whereas AAChartKit aims for cross-platform compatibility at the expense of some platform-specific optimizations.

Both libraries have their strengths, with MPAndroidChart excelling in advanced customization and performance for Android, while AAChartKit offers simplicity and cross-platform support. The choice between them depends on the specific requirements of your project and the platforms you need to support.

FL Chart is a highly customizable Flutter chart library that supports Line Chart, Bar Chart, Pie Chart, Scatter Chart, and Radar Chart.

Pros of fl_chart

  • Cross-platform support for Flutter, allowing development for both iOS and Android
  • Simpler API and easier to use for basic charting needs
  • More modern and actively maintained, with frequent updates

Cons of fl_chart

  • Less feature-rich compared to MPAndroidChart
  • Limited to Flutter projects, not suitable for native Android development
  • Smaller community and fewer resources available online

Code Comparison

MPAndroidChart:

LineDataSet dataSet = new LineDataSet(entries, "Label");
LineData lineData = new LineData(dataSet);
chart.setData(lineData);
chart.invalidate();

fl_chart:

LineChartData data = LineChartData(
  lineBarsData: [
    LineChartBarData(spots: spots, isCurved: true),
  ],
);
LineChart(data);

Both libraries offer straightforward ways to create line charts, but fl_chart's syntax is more concise and Flutter-friendly. MPAndroidChart provides more customization options out of the box, while fl_chart focuses on simplicity and ease of use.

MPAndroidChart is specifically designed for Android development, offering deep integration with the Android ecosystem. fl_chart, being a Flutter library, provides cross-platform support but may lack some platform-specific optimizations.

Overall, the choice between these libraries depends on the project requirements, target platforms, and the developer's familiarity with the respective ecosystems.

Promises for Swift & ObjC.

Pros of PromiseKit

  • Simplifies asynchronous programming in Swift and Objective-C
  • Extensive ecosystem with extensions for popular iOS frameworks
  • Robust error handling and chaining capabilities

Cons of PromiseKit

  • Limited to iOS and macOS development, unlike MPAndroidChart's Android focus
  • Steeper learning curve for developers new to promise-based programming
  • Less suitable for data visualization tasks

Code Comparison

PromiseKit:

firstly {
    fetchUser()
}.then { user in
    fetchAvatar(for: user)
}.done { avatar in
    self.imageView.image = avatar
}.catch { error in
    print("Error: \(error)")
}

MPAndroidChart:

LineChart chart = findViewById(R.id.chart);
List<Entry> entries = new ArrayList<>();
entries.add(new Entry(1f, 10f));
entries.add(new Entry(2f, 20f));
LineDataSet dataSet = new LineDataSet(entries, "Label");
LineData lineData = new LineData(dataSet);
chart.setData(lineData);
chart.invalidate();

While PromiseKit excels in handling asynchronous operations and simplifying complex workflows, MPAndroidChart is specifically designed for creating charts and graphs in Android applications. The code examples demonstrate their different focuses, with PromiseKit handling asynchronous tasks and MPAndroidChart creating a simple line chart.

Android Graph Library for creating zoomable and scrollable line and bar graphs.

Pros of GraphView

  • Simpler API and easier to use for basic charting needs
  • Smaller library size, potentially reducing app bloat
  • Better documentation and examples for beginners

Cons of GraphView

  • Limited chart types and customization options
  • Less active development and community support
  • Fewer advanced features for complex data visualization

Code Comparison

MPAndroidChart:

LineChart chart = findViewById(R.id.chart);
LineDataSet dataSet = new LineDataSet(entries, "Label");
LineData lineData = new LineData(dataSet);
chart.setData(lineData);
chart.invalidate();

GraphView:

GraphView graph = findViewById(R.id.graph);
LineGraphSeries<DataPoint> series = new LineGraphSeries<>(dataPoints);
graph.addSeries(series);

Summary

MPAndroidChart offers more advanced features and customization options, making it suitable for complex charting needs. It has a steeper learning curve but provides greater flexibility. GraphView, on the other hand, is simpler to use and more lightweight, making it a good choice for basic charting requirements or projects with limited resources. The choice between the two depends on the specific needs of your project, the complexity of the charts you want to create, and your familiarity with charting libraries.

Convert Figma logo designs to code with AI

Visual Copilot

Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.

Try Visual Copilot

README

banner

Release API Android Arsenal Gitter Twitter

:zap: A powerful & easy to use chart library for Android :zap:

Charts is the iOS version of this library

Table of Contents

  1. Quick Start
    1. Gradle
    2. Maven
  2. Documentation
  3. Examples
  4. Questions
  5. Donate
  6. Social Media
  7. More Examples
  8. License
  9. Creators

Gradle Setup

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

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

Maven Setup

<!-- <repositories> section of pom.xml -->
<repository>
    <id>jitpack.io</id>
   <url>https://jitpack.io</url>
</repository>

<!-- <dependencies> section of pom.xml -->
<dependency>
    <groupId>com.github.PhilJay</groupId>
    <artifactId>MPAndroidChart</artifactId>
    <version>v3.1.0</version>
</dependency>

Documentation :notebook_with_decorative_cover:

See the documentation for examples and general use of MPAndroidChart.

See the javadocs for more advanced documentation.


Examples :eyes:

Download the MPAndroidChart Example App or look at the source code.

ScreenShot


Questions & Issues :thinking:

This repository's issue tracker is only for bugs and feature requests. The maintainers ask that you refrain from asking questions about how to use MPAndroidChart through the issue tracker.

Please read the documentation first, then ask all your questions on stackoverflow.com for the fastest answer.


This project needs you! If you would like to support this project's further development, the creator of this project or the continuous maintenance of this project, feel free to donate. Your donation is highly appreciated (and I love food, coffee and beer). Thank you!

PayPal

  • Donate 5 $: Thank's for creating this project, here's a coffee (or some beer) for you!
  • Donate 10 $: Wow, I am stunned. Let me take you to the movies!
  • Donate 15 $: I really appreciate your work, let's grab some lunch!
  • Donate 25 $: That's some awesome stuff you did right there, dinner is on me!
  • Or you can also choose what you want to donate, all donations are awesome!

Social Media :fire:

If you like this library, please tell others about it :two_hearts: :two_hearts:

Share on Twitter Share on Google+ Share on Facebook

If you like, you can follow me on Twitter @PhilippJahoda.


More Examples :+1:


LineChart (with legend, simple design)

alt tag

LineChart (with legend, simple design)

alt tag

LineChart (cubic lines)

alt tag

LineChart (gradient fill)

alt tag

BarChart (with legend, simple design)

alt tag

BarChart (grouped DataSets)

alt tag

Horizontal-BarChart

alt tag

Combined-Chart (bar- and linechart in this case)

alt tag

PieChart (with selection, ...)

alt tag

ScatterChart (with squares, triangles, circles, ... and more)

alt tag

CandleStickChart (for financial data)

alt tag

BubbleChart (area covered by bubbles indicates the yValue)

alt tag

RadarChart (spider web chart)

alt tag


License :page_facing_up:

Copyright 2020 Philipp Jahoda

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.


Special Thanks :heart:

These people rock!