效果视频

引用

描述

本示例采用的是非常、非常、非常好用的一款第三方SDK——helloCharts
传送门

导包

第一步 :导入maven

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

第二步:导入依赖

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

代码分析

本示例总共采用了三条折线,分别为温度、湿度、光照

初始化

初始化三条折线颜色

TmpLine = new Line( mTmpChart ).setColor( Color.parseColor( "#cc00ff" ) );
 HumLine= new Line( mHumChart ).setColor( Color.parseColor( "#0033ff" ) );
 LightLine = new Line( mLightChart ).setColor( Color.parseColor( "#cc0000" ) );

初始化三条折线样式

        TmpLine.setShape( ValueShape.SQUARE);
        TmpLine.setCubic(true);//曲线是否平滑,即是曲线还是折线
        TmpLine.setFilled(true);//是否填充曲线的面积
        TmpLine.setHasLabels(true);//曲线的数据坐标是否加上备注
        TmpLine.setHasLines(true);//是否用线显示。如果为false 则没有曲线只有点显示
        TmpLine.setHasPoints(true);//是否显示圆点 如果为false 则没有原点只有点显示(每个数据点都是个大的圆点)

        HumLine.setShape( ValueShape.CIRCLE);//折线图上每个数据点的形状  这里是圆形 (有三种 :ValueShape.SQUARE  ValueShape.CIRCLE  ValueShape.DIAMOND)
        HumLine.setCubic(true);//曲线是否平滑,即是曲线还是折线
        HumLine.setFilled(true);//是否填充曲线的面积
        HumLine.setHasLabels(true);//曲线的数据坐标是否加上备注
        HumLine.setHasLines(true);//是否用线显示。如果为false 则没有曲线只有点显示
        HumLine.setHasPoints(true);//是否显示圆点 如果为false 则没有原点只有点显示(每个数据点都是个大的圆点)

        LightLine.setShape( ValueShape.DIAMOND);//折线图上每个数据点的形状  这里是圆形 (有三种 :ValueShape.SQUARE  ValueShape.CIRCLE  ValueShape.DIAMOND)
        LightLine.setCubic(true);//曲线是否平滑,即是曲线还是折线
        LightLine.setFilled(true);//是否填充曲线的面积
        LightLine.setHasLabels(true);//曲线的数据坐标是否加上备注
        LightLine.setHasLines(true);//是否用线显示。如果为false 则没有曲线只有点显示
        LightLine.setHasPoints(true);//是否显示圆点 如果为false 则没有原点只有点显示(每个数据点都是个大的圆点)

将三条折线添加到折线集合内

        lines.add( TmpLine );
        lines.add( HumLine );
        lines.add( LightLine );

添加折线

        data = new LineChartData();
        data.setLines(lines);

初始化X轴、Y轴样式属性

        Axis axisX = new Axis(); //X轴
        axisX.setHasTiltedLabels(false);  //X坐标轴字体是斜的显示还是直的,true是斜的显示
        axisX.setTextColor(Color.RED);  //设置字体颜色
        //axisX.setName("时间");  //表格名称
        axisX.setTextSize(7);//设置字体大小
        axisX.setMaxLabelChars(10); //最多几个X轴坐标,意思就是你的缩放让X轴上数据的个数7<=x<=mAxisXValues.length
        axisX.setValues(mAxisXValues);  //填充X轴的坐标名称
        data.setAxisXBottom(axisX); //x 轴在底部
        //data.setAxisXTop(axisX);  //x 轴在顶部
        axisX.setHasLines(true); //x 轴分割线

        // Y轴是根据数据的大小自动设置Y轴上限(在下面我会给出固定Y轴数据个数的解决方案)
        Axis axisY = new Axis();  //Y轴
        axisY.setName("历史数据");//y轴标注
        axisY.setTextSize(10);//设置字体大小
        axisY.setTextColor( Color.RED );
        axisX.setLineColor( Color.GREEN );
        data.setAxisYLeft(axisY);  //Y轴设置在左边

设置折线图支持滑动、缩放、平移等功能

        lineChart.setInteractive(true);
        lineChart.setZoomType( ZoomType.HORIZONTAL);
        lineChart.setMaxZoom((float) 2);//最大方法比例
        lineChart.setContainerScrollEnabled(true, ContainerScrollType.HORIZONTAL);
        lineChart.setLineChartData(data);
        lineChart.setVisibility( View.VISIBLE);

        Viewport v = new Viewport(lineChart.getMaximumViewport());
        v.left = 0;
        v.right = 7;
        lineChart.setCurrentViewport(v);

动态添加数据

采用Timer动态添加数据

  private void getValue(){
      timer = new Timer(  );
      timer.schedule( new TimerTask() {
          @Override
          public void run() {
           runOnUiThread( ()->{
               getTmp();
               getHum();
               getLight();
           } );
          }
      } ,100,2000);
  }

温度数据

从云获取数据

 float tmp = Float.parseFloat( pointDTO.get( i ).Value );

刷新数据,(很重要)

 lineChart.setLineChartData(data);
private void getTmp(){
      business.getSensorData( Param.DEVICEID, Param.TMPTAG, "1", "1", null, null, "ASC", "20", "1", new NCallBack<BaseResponseEntity<SensorDataPageDTO>>(context) {
          @Override
          protected void onResponse(BaseResponseEntity<SensorDataPageDTO> response) {

          }

          @Override
          public void onResponse(Call<BaseResponseEntity<SensorDataPageDTO>> call, Response<BaseResponseEntity<SensorDataPageDTO>> response) {
              super.onResponse( call, response );
              BaseResponseEntity<SensorDataPageDTO> dto = response.body();
              if (dto != null && dto.getStatus() == 0){
                  List<SensorDataPageDTO.VR> pointDTO = dto.getResultObj().DataPoints.get( 0 ).PointDTO;
                  if (pointDTO != null){
                      for (int i = 0; i <pointDTO.size() ; i  ) {
                          float tmp = Float.parseFloat( pointDTO.get( i ).Value );
                          //Toast.makeText( context,tmp "",Toast.LENGTH_SHORT ).show();
                          mTmpChart.add( new PointValue( i,tmp ) );
                          lineChart.setLineChartData(data);
                      }
                  }else {
                   Toast.makeText( context,"数据为空",Toast.LENGTH_SHORT ).show();
                  }
              }
          }
      } );
  }

湿度数据

business.getSensorData( Param.DEVICEID, Param.HUMTAG, "1", "1", null, null, "ASC", "20", "1", new NCallBack<BaseResponseEntity<SensorDataPageDTO>>(context) {
          @Override
          protected void onResponse(BaseResponseEntity<SensorDataPageDTO> response) {

          }

          @Override
          public void onResponse(Call<BaseResponseEntity<SensorDataPageDTO>> call, Response<BaseResponseEntity<SensorDataPageDTO>> response) {
              super.onResponse( call, response );
              BaseResponseEntity<SensorDataPageDTO> dto = response.body();
              if (dto != null && dto.getStatus() == 0){
                  List<SensorDataPageDTO.VR> pointDTO = dto.getResultObj().DataPoints.get( 0 ).PointDTO;
                  if (pointDTO != null){
                      for (int i = 0; i <pointDTO.size() ; i  ) {
                          float hum = Float.parseFloat( pointDTO.get( i ).Value );
                          //Toast.makeText( context,tmp "",Toast.LENGTH_SHORT ).show();
                          mHumChart.add( new PointValue( i,hum ) );
                          lineChart.setLineChartData(data);
                      }
                  }else {
                      Toast.makeText( context,"数据为空",Toast.LENGTH_SHORT ).show();
                  }
              }
          }
      } );
  }

光照数据

 private void getLight(){
      business.getSensorData( Param.DEVICEID, Param.LIGHTTAG, "1", "1", null, null, "ASC", "20", "1", new NCallBack<BaseResponseEntity<SensorDataPageDTO>>(context) {
          @Override
          protected void onResponse(BaseResponseEntity<SensorDataPageDTO> response) {

          }

          @Override
          public void onResponse(Call<BaseResponseEntity<SensorDataPageDTO>> call, Response<BaseResponseEntity<SensorDataPageDTO>> response) {
              super.onResponse( call, response );
              BaseResponseEntity<SensorDataPageDTO> dto = response.body();
              if (dto != null && dto.getStatus() == 0){
                  List<SensorDataPageDTO.VR> pointDTO = dto.getResultObj().DataPoints.get( 0 ).PointDTO;
                  if (pointDTO != null){
                      for (int i = 0; i <pointDTO.size() ; i  ) {
                          float light = Float.parseFloat( pointDTO.get( i ).Value );
                          //Toast.makeText( context,tmp "",Toast.LENGTH_SHORT ).show();
                          mLightChart.add( new PointValue( i,light ) );
                          lineChart.setLineChartData(data);
                      }
                  }else {
                      Toast.makeText( context,"数据为空",Toast.LENGTH_SHORT ).show();
                  }
              }
          }
      } );
  }

动态添加X轴时间值

初始化

X轴自动刷新时间依旧采用Timer实现
这俩属性较为重要

        axisX.setTextSize(7);//设置字体大小
        axisX.setMaxLabelChars(10); //最多几个X轴坐标,意思就是你的缩放让X轴上数据的

X轴属性初始化

        Axis axisX = new Axis(); //X轴
        axisX.setHasTiltedLabels(false);  //X坐标轴字体是斜的显示还是直的,true是斜的显示
        axisX.setTextColor(Color.RED);  //设置字体颜色
        //axisX.setName("时间");  //表格名称
        axisX.setTextSize(7);//设置字体大小
        axisX.setMaxLabelChars(10); //最多几个X轴坐标,意思就是你的缩放让X轴上数据的个数7<=x<=mAxisXValues.length
        axisX.setValues(mAxisXValues);  //填充X轴的坐标名称
        data.setAxisXBottom(axisX); //x 轴在底部
        //data.setAxisXTop(axisX);  //x 轴在顶部
        axisX.setHasLines(true); //x 轴分割线

自动刷新时间实现

    private void getAxis() {
        timerY = new Timer(  );
        timerY.schedule( new TimerTask() {
            @Override
            public void run() {
                test();
            }
        },100,2000 );

    }
private void test(){
                business.getSensorData( Param.DEVICEID, Param.TMPTAG, "1", "1", null,null, "ASC", "20", "1", new NCallBack<BaseResponseEntity<SensorDataPageDTO>>(context) {
            @Override
            protected void onResponse(BaseResponseEntity<SensorDataPageDTO> response) {

            }

            @Override
            public void onResponse(Call<BaseResponseEntity<SensorDataPageDTO>> call, Response<BaseResponseEntity<SensorDataPageDTO>> response) {
                super.onResponse( call, response );
                BaseResponseEntity<SensorDataPageDTO> dto = response.body();
                if (dto != null && dto.getStatus() == 0){
                    List<SensorDataPageDTO.VR> pointDTO = dto.getResultObj().DataPoints.get( 0 ).PointDTO;
                    SensorDataPageDTO.VR[] array = new SensorDataPageDTO.VR[pointDTO.size()];
                    pointDTO.toArray(array);
                    mAxisXValues.clear();
                    mTime = new String[array.length];
                        for (int i = 0; i < array.length ; i  ) {
                            //mAxisXValues.clear();
                            mTime[i] = pointDTO.get( i ).RecordTime;
                            mAxisXValues.add(new AxisValue(i).setLabel(mTime[i]));
                        }
                    runOnUiThread( ()->{
                        lineChart.setLineChartData(data);
                    } );
                }
            }
        } );
    }

尾言

如有不足之处,望君海涵
需要源码,call我

到此这篇关于Android实现动态添加数据与堆叠折线图详解流程的文章就介绍到这了,更多相关Android 动态添加数据 内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

Android实现动态添加数据与堆叠折线图详解流程的更多相关文章

  1. html5 canvas合成海报所遇问题及解决方案总结

    这篇文章主要介绍了html5 canvas合成海报所遇问题及解决方案总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. Html5 video标签视频的最佳实践

    这篇文章主要介绍了Html5 video标签视频的最佳实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

  3. HTML5在微信内置浏览器下右上角菜单的调整字体导致页面显示错乱的问题

    HTML5在微信内置浏览器下,在右上角菜单的调整字体导致页面显示错乱的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

  4. ios – containerURLForSecurityApplicationGroupIdentifier:在iPhone和Watch模拟器上给出不同的结果

    我使用默认的XCode模板创建了一个WatchKit应用程序.我向iOSTarget,WatchkitAppTarget和WatchkitAppExtensionTarget添加了应用程序组权利.(这是应用程序组名称:group.com.lombax.fiveminutes)然后,我尝试使用iOSApp和WatchKitExtension访问共享文件夹URL:延期:iOS应用:但是,测试NSURL

  5. Ionic – Splash Screen适用于iOS,但不适用于Android

    我有一个离子应用程序,其中使用CLI命令离子资源生成的启动画面和图标iOS版本与正在渲染的启动画面完美配合,但在Android版本中,只有在加载应用程序时才会显示白屏.我检查了config.xml文件,所有路径看起来都是正确的,生成的图像出现在相应的文件夹中.(我使用了splash.psd模板来生成它们.我错过了什么?这是config.xml文件供参考,我觉得我在这里做错了–解决方法在config.xml中添加以下键:它对我有用!

  6. ios – 无法启动iPhone模拟器

    /Library/Developer/CoreSimulator/Devices/530A44CB-5978-4926-9E91-E9DBD5BFB105/data/Containers/Bundle/Application/07612A5C-659D-4C04-ACD3-D211D2830E17/ProductName.app/ProductName然后,如果您在Xcode构建设置中选择标准体系结构并再次构建和运行,则会产生以下结果:dyld:lazysymbolbindingFailed:Symbol

  7. Xamarin iOS图像在Grid内部重叠

    heyo,所以在Xamarin我有一个使用并在其中包含一对,所有这些都包含在内.这在Xamarin.Android中看起来完全没问题,但是在Xamarin.iOS中,图像与标签重叠.我不确定它的区别是什么–为什么它在Xamarin.Android中看起来不错但在iOS中它的全部都不稳定?

  8. 在iOS上向后播放HTML5视频

    我试图在iPad上反向播放HTML5视频.HTML5元素包括一个名为playbackRate的属性,它允许以更快或更慢的速率或相反的方式播放视频.根据Apple’sdocumentation,iOS不支持此属性.通过每秒多次设置currentTime属性,可以反复播放,而无需使用playbackRate.这种方法适用于桌面Safari,但似乎在iOS设备上的搜索限制为每秒1次更新–在我的情况下太慢了.有没有办法在iOS设备上向后播放HTML5视频?解决方法iOS6Safari现在支持playbackRat

  9. 使用 Swift 语言编写 Android 应用入门

    Swift标准库可以编译安卓armv7的内核,这使得可以在安卓移动设备上执行Swift语句代码。做梦,虽然Swift编译器可以胜任在安卓设备上编译Swift代码并运行。这需要的不仅仅是用Swift标准库编写一个APP,更多的是你需要一些框架来搭建你的应用用户界面,以上这些Swift标准库不能提供。简单来说,构建在安卓设备上使用的Swiftstdlib需要libiconv和libicu。通过命令行执行以下命令:gitclonegit@github.com:SwiftAndroid/libiconv-libi

  10. Android – 调用GONE然后VISIBLE使视图显示在错误的位置

    我有两个视图,A和B,视图A在视图B上方.当我以编程方式将视图A设置为GONE时,它将消失,并且它正下方的视图将转到视图A的位置.但是,当我再次将相同的视图设置为VISIBLE时,它会在视图B上显示.我不希望这样.我希望视图B回到原来的位置,这是我认为会发生的事情.我怎样才能做到这一点?编辑–代码}这里是XML:解决方法您可以尝试将两个视图放在RelativeLayout中并相对于彼此设置它们的位置.

随机推荐

  1. Flutter 网络请求框架封装详解

    这篇文章主要介绍了Flutter 网络请求框架封装详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. Android单选按钮RadioButton的使用详解

    今天小编就为大家分享一篇关于Android单选按钮RadioButton的使用详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

  3. 解决android studio 打包发现generate signed apk 消失不见问题

    这篇文章主要介绍了解决android studio 打包发现generate signed apk 消失不见问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  4. Android 实现自定义圆形listview功能的实例代码

    这篇文章主要介绍了Android 实现自定义圆形listview功能的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  5. 详解Android studio 动态fragment的用法

    这篇文章主要介绍了Android studio 动态fragment的用法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. Android用RecyclerView实现图标拖拽排序以及增删管理

    这篇文章主要介绍了Android用RecyclerView实现图标拖拽排序以及增删管理的方法,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下

  7. Android notifyDataSetChanged() 动态更新ListView案例详解

    这篇文章主要介绍了Android notifyDataSetChanged() 动态更新ListView案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下

  8. Android自定义View实现弹幕效果

    这篇文章主要为大家详细介绍了Android自定义View实现弹幕效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. Android自定义View实现跟随手指移动

    这篇文章主要为大家详细介绍了Android自定义View实现跟随手指移动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. Android实现多点触摸操作

    这篇文章主要介绍了Android实现多点触摸操作,实现图片的放大、缩小和旋转等处理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部