亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android圖表庫HelloCharts的實例詳解

 更新時間:2022年01月06日 15:27:56   作者:曲幽  
這篇文章主要介紹了Android中的圖標庫HelloCharts的一些簡單使用實例,文中的示例代碼講解詳細,對我們學習有一定的參考價值,需要的可以參考一下

概述

效果圖,數(shù)據(jù)可平移查看歷史

build.gradle

implementation 'com.github.lecho:hellocharts-library:1.5.8@aar'

layout

直接在布局中加入相應(yīng)的圖表控件

<lecho.lib.hellocharts.view.LineChartView
    android:id="@+id/ChartLine"
    android:layout_width="0dp"
    android:layout_height="300dp"
    android:padding="6dp"/>

常用圖表類型

LineChartView

PointValue

圖表上每一點的數(shù)據(jù) PointValue(float x, float y)

第一個參數(shù)表示點的位置,第二個參數(shù)表示點上的數(shù)據(jù)。如果是多條折線,則需要為每一條拆線相同位置定義不同的PointValue

PointValue point1 = new PointValue(0, 1000);
PointValue point2 = new PointValue(1, 1500);
PointValue point1 = new PointValue(0, 1200);
PointValue point2 = new PointValue(1, 1600);

setLabel() 可以為數(shù)據(jù)點定義顯示文本

point1.setLabel("202101");

實例

List<PointValue> valuesR = new ArrayList<>();
List<PointValue> valuesS = new ArrayList<>();
for (int i = 0; i < dataEntities.size(); i++) {
    DataEntity dataEntity = dataEntities.get(i);
    if (dataEntity.getDataR() < 3000 || dataEntity.getDataS() < 3000)
        continue;
    valuesR.add(new PointValue(i, dataEntity.getDataR()).setLabel(String.valueOf(dataEntity.getDataR())));
    valuesS .add(new PointValue(i, dataEntity.getDataS()).setLabel(String.valueOf(dataEntity.getDataS())));
}

如果數(shù)據(jù)太小,則跳過。數(shù)據(jù)不加載入數(shù)據(jù)點集合,但 i 索引會增加,折線上會出現(xiàn)大的間隔。如果不想出現(xiàn)此情況,可更換 for 循環(huán)為 foreach 循環(huán),然后手動控制 i 的增長。

Line

定義線條上的數(shù)據(jù)和顏色等

構(gòu)造函數(shù)傳入包含PointValue的列表,有幾條折線就創(chuàng)建幾條并綁定不同的點數(shù)據(jù)列表

List<Line> lines = new ArrayList<>();
lines.add(new Line(valuesR).setColor(Color.RED).setCubic(false).setHasLabelsOnlyForSelected(true));
lines.add(new Line(valuesS).setColor(Color.BLUE).setCubic(false).setHasLabelsOnlyForSelected(true));

常用屬性方法

  • setColor() # 設(shè)置折線顏色
  • setCubic(true) # 折線是否平滑,即是曲線還是折線
  • setShape() # 折線上數(shù)據(jù)點的形狀,有三種 :ValueShape.SQUARE(方) ValueShape.CIRCLE(圓) ValueShape.DIAMOND(菱)
  • setFilled(false) # 是否填充曲線的面積
  • setHasLabels(true) # 曲線的數(shù)據(jù)坐標是否加上備注
  • setHasLabelsOnlyForSelected(true) # 同上,但是只有點擊數(shù)據(jù)坐標提示數(shù)據(jù),但設(shè)置了這個屬性,上面的屬性即失效
  • setHasLines(true) # 是否顯示線,為false則只顯示點
  • setHasPoints(true) # 是否顯示圓點,如果為false則每個數(shù)據(jù)點都是個大的圓點

Axis

X軸

List<AxisValue> xValue = new ArrayList<>();
for(int i = 0; i < dataEntities.size(); i++){
    DataEntity dataEntity = dataEntities.get(i);
    xValue.add(new AxisValue(i).setLabel(dataEntity .getDate()));
}
Axis axisX = new Axis();
axisX.setHasTiltedLabels(true);
axisX.setTextColor(Color.GRAY);
axisX.setValues(xValue);

Y軸

List<AxisValue> yValue = new ArrayList<>();
for(int i = 0; i < 8000; i = i + 1000){
    yValue.add(new AxisValue(i).setLabel(String.valueOf(i)));
}
Axis axisY  = new Axis();
axisY.setTextColor(Color.GRAY);
axisY.setValues(yValue);
axisY.setHasLines(true);
LineChartData data = new LineChartData();
data.setLines(lines);
data.setAxisXBottom(axisX);
data.setAxisYLeft(axisY);

AxisValue

創(chuàng)建實例

AxisValue v = new AxisValue(i).setLabel(String.valueOf(i));

常用屬性方法

  • setHasTiltedLabels(true) # 坐標軸字體是否顯示斜體
  • setValues() # 填充數(shù)據(jù)列表
  • setHasLines(true) # 是否顯示參考線

LineChartData

將以上包含了點數(shù)據(jù)列表的折線添加到 LineChartData 中并綁定給圖表控件

Chart

//設(shè)置是否允許平移以及平移的方向
bindingView.chartLine.setContainerScrollEnabled(true, ContainerScrollType.HORIZONTAL);
//填充數(shù)據(jù)
bindingView.chartLine.setLineChartData(data);

實現(xiàn)平移必須設(shè)置視圖大小

//實例化一個新的ViewPort 構(gòu)造函數(shù)中傳入填充數(shù)據(jù)后的默認最大視圖
Viewport viewport = new Viewport(bindingView.chartLine.getMaximumViewport()); 
//設(shè)置y軸的顯示
viewport.top = MyApplication.getSharedPreferences().getInt("max", 8000);
viewport.bottom = MyApplication.getSharedPreferences().getInt("min", 3000);
//一定要先設(shè)置最大視圖范圍
bindingView.chartLine.setMaximumViewport(viewport); //圖表最大視圖
//設(shè)置x軸的顯示
viewport.right = MyApplication.getSharedPreferences().getInt("chart_right", 7);
viewport.left = 0;
//最后設(shè)置當前顯示的視圖范圍
bindingView.chartLine.setCurrentViewport(viewport); //圖表當前視圖

完整代碼

private void initChart(List<DataEntity> dataEntities) {
    List<PointValue> valuesR = new ArrayList<>();
    List<PointValue> valuesS = new ArrayList<>();
    List<AxisValue> xValue = new ArrayList<>();
    List<AxisValue> yValue = new ArrayList<>();
    for (int i = 0; i < dataEntities.size(); i++) {
        DataEntity dataEntity = dataEntities.get(i);
        if (dataEntity.getDataR() < MyApplication.getSharedPreferences().getInt("min", 3000) || dataEntity.getDataS() < MyApplication.getSharedPreferences().getInt("min", 3000))
            continue;
        valuesR.add(new PointValue(i, dataEntity .getDataR()).setLabel(String.valueOf(dataEntity .getDataR())));
        valuesS.add(new PointValue(i, dataEntity .getDataS()).setLabel(String.valueOf(dataEntity .getDataS())));
        xValue.add(new AxisValue(i).setLabel(dataEntity .getDate()));
    }
    for (int i = 0; i < MyApplication.getSharedPreferences().getInt("salary_max", 8000); i = i + 500) {
        yValue.add(new AxisValue(i).setLabel(String.valueOf(i)));
    }
    List<Line> lines = new ArrayList<>();
    lines.add(new Line(valuesR).setColor(Color.RED).setCubic(false).setHasLabelsOnlyForSelected(true));
    lines.add(new Line(valuesS).setColor(Color.BLUE).setCubic(false).setHasLabelsOnlyForSelected(true));
    Axis axisX = new Axis();
    axisX.setHasTiltedLabels(true);
    axisX.setTextColor(Color.GRAY);
    axisX.setValues(xValue);
    Axis axisY = new Axis();
    axisY.setTextColor(Color.GRAY);
    axisY.setValues(yValue);
    axisY.setHasLines(true);


    LineChartData data = new LineChartData();
    data.setLines(lines);
    data.setAxisXBottom(axisX);
    data.setAxisYLeft(axisY);
    bindingView.chartLine.setContainerScrollEnabled(true, ContainerScrollType.HORIZONTAL);
    bindingView.chartLine.setLineChartData(data);
    //設(shè)置圖表顯示的大小
    Viewport viewport = new Viewport(bindingView.chartLine.getMaximumViewport()); //填充數(shù)據(jù)后的默認最大視圖
    viewport.top = MyApplication.getSharedPreferences().getInt("max", 8000);
    viewport.bottom = MyApplication.getSharedPreferences().getInt("min", 3000);
    bindingView.chartLine.setMaximumViewport(viewport); //圖表最大視圖
    viewport.right = MyApplication.getSharedPreferences().getInt("chart_right", 7);
    viewport.left = 0;
    bindingView.chartLine.setCurrentViewport(viewport); //圖表當前視圖
}

以上就是Android圖表庫HelloCharts的實例詳解的詳細內(nèi)容,更多關(guān)于Android圖表庫HelloCharts的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Android應(yīng)用程序更新并下載實例

    Android應(yīng)用程序更新并下載實例

    本篇文章主要介紹了Android應(yīng)用程序更新并下載實例,非常具有實用價值,需要的朋友可以參考下。
    2017-03-03
  • 深入Android Browser配置管理的詳解

    深入Android Browser配置管理的詳解

    本篇文章是對Android Browser的配置管理進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • Android實現(xiàn)APP在線下載更新

    Android實現(xiàn)APP在線下載更新

    這篇文章主要為大家詳細介紹了Android實現(xiàn)APP在線下載更新的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • 讓IjkPlayer支持插入自定義的GPU濾鏡方法

    讓IjkPlayer支持插入自定義的GPU濾鏡方法

    下面小編就為大家分享一篇讓IjkPlayer支持插入自定義的GPU濾鏡方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • Volley源碼之使用方式和使用場景詳解

    Volley源碼之使用方式和使用場景詳解

    這篇文章主要介紹了Volley源碼之使用方式和使用場景詳解,具有一定參考價值,需要的朋友可以了解下。
    2017-11-11
  • Android自定義滑動刪除效果的實現(xiàn)代碼

    Android自定義滑動刪除效果的實現(xiàn)代碼

    這篇文章將從現(xiàn)有 Android 滑動刪除的痛點,到搭建好一個基本的框架,到最終提供一份完整的 Demo為止,爭取為讀者提供最大的可定制化,需要的朋友可以參考下
    2018-03-03
  • Android自定義圓角ImageView

    Android自定義圓角ImageView

    這篇文章主要介紹了Android自定義圓角ImageView的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • Android自定義view之太極圖的實現(xiàn)教程

    Android自定義view之太極圖的實現(xiàn)教程

    這篇文章主要給大家介紹了關(guān)于Android自定義view之太極圖的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • Flutter 日期時間DatePicker控件及國際化

    Flutter 日期時間DatePicker控件及國際化

    這篇文章主要介紹了Flutter 日期時間DatePicker控件及國際化,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • Android實現(xiàn)MVVM架構(gòu)數(shù)據(jù)刷新詳解流程

    Android實現(xiàn)MVVM架構(gòu)數(shù)據(jù)刷新詳解流程

    MVVM架構(gòu)模式,即Model-View-ViewModel三個層級,MVVM模式出來的時間已經(jīng)很長了,網(wǎng)上關(guān)于MVVM模式的解析也有很多,我這里只說一下我自己的理解,基本上是和MVP模式相比較的一個差異
    2021-10-10

最新評論