2种Android图表的简单介绍+折线图、饼图的例子

文章目录

  • 安卓图表的简单介绍

    • @[toc]
    • 一、MPAndroidChart
    • 1.添加依赖方式
    • 第一种:
  • Gradle Setup

  • Maven Setup

  • 第二种:

  • 【简单粗暴】本地导入依赖

  • 2.折线图

  • 3.饼图

  • 二、HelloCharts

      • 支持 Android 2.2 以上;支持折线图、柱状图、饼图、气泡图、组合图;支持预览、放大缩小,滚动,部分图表支持动画;
  • 1.添加依赖

    • 第一种:
  • Android Studio/Gradle

  • Maven Central/jCenter, add dependency to your `build.gradle`:

  • 第二种:

  • 【简单粗暴】本地导入依赖

  • 2.折线图

  • 3.饼图

  • MPAndroidChart官方图片


一、MPAndroidChart

MPAndroidChart 是一款开源的强大的图表库。支持折线图、饼图、柱状图、散点图网状图等,支持 Android 2.2 以上,支持横纵轴缩放,多指缩放,展现动画、高亮、保存到 sdcard、从文件读取图表。

官方项目地址:https://github.com/PhilJay/MPAndroidChart

1.添加依赖方式
第一种:
Gradle Setup

Project 的build.gradle文件中添加

repositories {

maven { url ‘https://jitpack.io’ }

}

在 module中的build,gradle 中添加

dependencies {

implementation ‘com.github.PhilJay:MPAndroidChart:v3.1.0’

}

Maven Setup

jitpack.io

https://jitpack.io

com.github.PhilJay

MPAndroidChart

v3.1.0

第二种:
【简单粗暴】本地导入依赖

下载MPAndroidChart-v3.0.3.jar

链接:https://pan.baidu.com/s/1tbjKVE_IMWudjLEiq3bXcg

提取码:g4yy

下载完后将包导入lib文件夹下,如下图

在这里插入图片描述

无论是 哪一种方法,添加后,点击sync按钮【小象图标】

在这里插入图片描述

2.折线图

①建一个布局文件

<com.github.mikephil.charting.charts.LineChart

android:id=“@+id/line”

android:layout_width=“match_parent”

android:layout_height=“match_parent”>

</com.github.mikephil.charting.charts.LineChart>

②建一个LineChartActivity.java ,需要完成创建一个list用来保存数据,对折线的形状、颜色等进行设计,导入数据以及最后实例化Dataset 。

import android.os.Bundle;

import android.view.WindowManager;

import com.github.mikephil.charting.data.Entry;

import androidx.appcompat.app.AppCompatActivity;

import com.github.mikephil.charting.charts.LineChart;

import com.github.mikephil.charting.data.LineData;

import com.github.mikephil.charting.data.LineDataSet;

import java.util.ArrayList;

import java.util.List;

import android.graphics.Color;

public class LineChartActivity extends AppCompatActivity {

//①实例化一个 List 用来保存你的数据

private LineChart line;

Listlist=new ArrayList<>();

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,

WindowManager.LayoutParams.FLAG_FULLSCREEN);

setContentView(R.layout.linechart);

setTitle(“LineChartActivity”);

//②findViewById方法获取到布局文件中的元素

line = (LineChart) findViewById(R.id.line);

//③line Style

// background color

line.setBackgroundColor(Color.WHITE);

// disable description text

line.getDescription().setEnabled(false);

// enable touch gestures

line.setTouchEnabled(true);

// enable scaling and dragging

line.setDragEnabled(true);

line.setScaleEnabled(true);

// line.setScaleXEnabled(true);

// line.setScaleYEnabled(true);

// force pinch zoom along both axis

line.setPinchZoom(true);

//④导入数据

//其中两个数字对应的分别是 X轴Y轴

list.add(new Entry(0,90));

list.add(new Entry(1,95));

list.add(new Entry(2,87));

list.add(new Entry(3,99));

list.add(new Entry(4,100));

list.add(new Entry(5,100));

//⑤实例化Dataset

//list是你这条线的数据 “android” 是你对这条线的描述(也就是图例上的文字)

LineDataSet lineDataSet=new LineDataSet(list,“Android”);

LineData lineData=new LineData(lineDataSet);

//有多条数据则使用adddataset()方法 参数是你的DataSet

//lineData.addDataSet(lineDataSet);

line.setData(lineData);

}

}

③在AndroidManifest.xml里添加

④实现结果:

在这里插入图片描述

3.饼图

①同样的先建一个布局文件

<com.github.mikephil.charting.charts.PieChart

android:id=“@+id/pie”

android:layout_width=“match_parent”

android:layout_height=“match_parent”>

</com.github.mikephil.charting.charts.PieChart>

②建一个pieChartActivity.java ,需要完成创建一个list用来保存数据,对饼图的颜色、相隔等进行设计,导入数据以及最后实例化Dataset 。

import android.graphics.Color;

import android.os.Bundle;

import androidx.appcompat.app.AppCompatActivity;

import android.view.WindowManager;

import com.github.mikephil.charting.charts.PieChart;;

import com.github.mikephil.charting.data.PieData;

import com.github.mikephil.charting.data.PieDataSet;

import com.github.mikephil.charting.data.PieEntry;

import java.util.ArrayList;

import java.util.List;

public class pieChartActivity extends AppCompatActivity {

private PieChart pie;

//①实例化一个 List 用来保存你的数据,这里是pieEntry

List list=new ArrayList<>();

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,

WindowManager.LayoutParams.FLAG_FULLSCREEN);

setContentView(R.layout.piechart);

setTitle(“PieChartActivity”);

pie = (PieChart) findViewById(R.id.pie);

//②输入数据

//其中两个数字对应的分别是 X轴Y轴

list.add(new PieEntry(25,“Cola”));

list.add(new PieEntry(10, “Sprite”));

list.add(new PieEntry(13, “Fanta”));

list.add(new PieEntry(20, “Suntory”));

list.add(new PieEntry(5, “Rio”));

list.add(new PieEntry(20, “Beer”));

list.add(new PieEntry(17, “Other”));

//③定义一下饼图的颜色

ArrayList colors = new ArrayList();

colors.add(Color.RED);

colors.add(Color.GREEN);

colors.add(Color.CYAN);

colors.add(Color.MAGENTA);

colors.add(getResources().getColor(R.color.blue));

colors.add(Color.LTGRAY);

colors.add(Color.GRAY);

//⑤实例化Dataset

//list是你这条线的数据 “销售比例” 是你对这个饼的描述

PieDataSet PieDataSet = new PieDataSet(list, “销售比例”);

PieDataSet.setSliceSpace(3f); //设置饼状Item之间的间隙

PieDataSet.setColors(colors); //为DataSet中的数据匹配上颜色集(饼图Item颜色)

PieData PieData = new PieData(PieDataSet);

pie.setData(PieData);

}

}

③在AndroidManifest.xml里添加

④实现结果:

在这里插入图片描述

二、HelloCharts

支持 Android 2.2 以上;支持折线图、柱状图、饼图、气泡图、组合图;支持预览、放大缩小,滚动,部分图表支持动画;

官方项目地址:https://github.com/lecho/hellocharts-android

1.添加依赖
第一种:
Android Studio/Gradle
Maven Central/jCenter, add dependency to your build.gradle:

dependencies{

compile ‘com.github.lecho:hellocharts-library:1.5.8@aar’

}

`Project 的build.gradle文件中添加

repositories {

maven {

url “https://jitpack.io”

}

}

在 module中的build,gradle 中添加

dependencies {

compile ‘com.github.lecho:hellocharts-android:v1.5.8’

}

第二种:
【简单粗暴】本地导入依赖

下载hellocharts-library-1.5.8.jar

链接:https://pan.baidu.com/s/1MQoHs__I1dSY2tgRs-X_eQ

提取码:ln12

也一样是无论是哪种方式,都需要点击【小象图标】

2.折线图

①创建一个布局文件

<lecho.lib.hellocharts.view.LineChartView

android:id=“@+id/line2”

android:layout_width=“match_parent”

android:layout_height=“match_parent”

android:background=“#fffff0”>

</lecho.lib.hellocharts.view.LineChartView>

②建一个LineChartActivity2.java,对折线的参数进行设置,以及输入数据。

import android.os.Bundle;

import androidx.appcompat.app.AppCompatActivity;

import android.view.View;

import java.util.ArrayList;

import java.util.List;

import android.graphics.Color;

最后

我这里整理了一份完整的学习思维以及Android开发知识大全PDF。

当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

id:background=“#fffff0”>

</lecho.lib.hellocharts.view.LineChartView>

②建一个LineChartActivity2.java,对折线的参数进行设置,以及输入数据。

import android.os.Bundle;

import androidx.appcompat.app.AppCompatActivity;

import android.view.View;

import java.util.ArrayList;

import java.util.List;

import android.graphics.Color;

最后

我这里整理了一份完整的学习思维以及Android开发知识大全PDF。

[外链图片转存中…(img-TwaJp6CY-1714249683343)]

当然实践出真知,即使有了学习线路也要注重实践,学习过的内容只有结合实操才算是真正的掌握。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

  • 7
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值