关于achartengine的使用一些小经验 - Mentos

2023-12-07 13:58

本文主要是介绍关于achartengine的使用一些小经验 - Mentos,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


最近项目上要使用图表,便开始在网上找各种图表架包,好看的都是收费的,最后还是决定用google的achartengine.achartengine使用起来还算好,就是修改样式很烦.下面就分享下开发经验吧. 

所有的chart都分两块,一块是Renderer(如XYMultipleSeriesRenderer,我的理解是,这个renderer为视图render的模板,就是你想用什么图标,一个图图表基本分2层,这个是最下面一层),一块是Dataset(如XYMultipleSeriesDataset,用于对视图数值的处理).  
这边我就拿折线图举例吧.  
首先需要  
        XYMultipleSeriesRenderer mRenderer = new XYMultipleSeriesRenderer();//创建你需要的图表最下面的图层  
        XYSeriesRenderer seriesRenderer = new XYSeriesRenderer();//创建你需要在图层上显示的具体内容的图层  
        mRenderer.addSeriesRenderer(seriesRenderer);//添加进去  
        XYMultipleSeriesDataset mDataset = new XYMultipleSeriesDataset()//创建数据层  
        XYSeries series = new XYSeries("标题");//创建具体的数据层  
        series .add(x, y);//添加数据,一般都是for循环数据不断操作这一步添加的  
        mDataset.addSeries(series);  
      然后调用ChartFactory.getLineChartIntent(context, mDataset, mRenderer),得到一个Intent类型的intent,startActivity(intent)就能得到图表了.这边需要在AndroidManifest.xml加上<activity android:name="org.achartengine.GraphicalActivity" />.这边是跳界面查看图表,是全屏的.ChartFactory可以得到很多视图,ChartFactory.getBarChartIntent(context, dataset, renderer, type, activityTitle)就可以得到一个柱状图.以此类推啊.  
有时候项目中开发,需要在界面的某一块展示视图,这时候我们可以通过 ChartFactory.getLineChartView(context, mDataset, mRenderer)得到一个GraphicalView类型的视图.(这边就不要需要在AndroidManifest.xml加上<activity android:name="org.achartengine.GraphicalActivity" />.)  
其实图表的使用流程就是这样.但要做一个自己想要的视图,就需要设置mRenderer 的样式,seriesRenderer 的样式.  
mRenderer样式设置:  
        mRenderer.setShowAxes(false);//设置是否需要显示坐标轴  
        mRenderer.setXAxisMin(1.3d);//设置X轴最小值  
        mRenderer.setXAxisMax(10d);//设置X轴最大值  
        mRenderer.setYAxisMin(0d); //设置Y轴最小值  
        mRenderer.setYAxisMax(maxY + maxY / 6); // 设置Y轴最大值  
        mRenderer.setChartTitleTextSize(0);//设置图表标题字体大小,我这边设置0是把标题隐藏掉  
        mRenderer.setYLabels(7);//设置Y轴标签数  
        mRenderer.setExternalZoomEnabled(true);//设置是否可以缩放  
        mRenderer.setZoomInLimitY(maxY + maxY / 6);//设置Y轴最大缩放限  
        mRenderer.setZoomInLimitX(5);//设置X轴最大缩放限  
        mRenderer.setPanEnabled(true, false);//设置滑动,这边是横向可以滑动,竖向不可滑动  
        mRenderer.setXLabels(XLabel.size() - 1);//设置X标签数量  
        mRenderer.setXLabelsPadding(200);//设置标签的间距  
        mRenderer.setXLabelsAngle(-45f);//设置标签倾斜度  
        for (int i = 0; i < XLabel.size(); i++)  
        {  
            mRenderer.addXTextLabel(i, XLabel.get(i));//这边是自定义自己的标签,显示自己想要的X轴的标签,需要注意的是需要setXLabels(0)放在标签重叠(就是自定义的标签与图表默认的标签)  
        }        
        mRenderer.setPanLimits(new double[] {0, (XLabel.size()) * 2, 0, maxY});//设置滑动范围,这边我很好奇他的单位,一直有点小问题  
        mRenderer.setAxesColor(context.getResources().getColor(R.color.text_hui));//设置数轴的颜色  
        mRenderer.setGridColor(context.getResources().getColor(R.color.text_hui999999)); //设置网格的颜色     
        mRenderer.setShowGrid(true); /设置是否需要显示网格  
        mRenderer.setYTitle(label);//设置Y轴标题  
        mRenderer.setLabelsColor(Color.BLACK);//设置标签颜色  
        mRenderer.setYLabelsAlign(Align.LEFT, 0);//设置标签居Y轴的方向  
        mRenderer.setAxisTitleTextSize(20);  
        mRenderer.setYLabelsColor(0, context.getResources().getColor(R.color.text_hui));        mRenderer.setLabelsTextSize(14);  
        mRenderer.setZoomLimits(new double[] {0, maxX * 5, 0, maxY + maxY / 6});//设置缩放限制,setZoomInLimitY等一样  
        mRenderer.setXLabelsColor(context.getResources().getColor(R.color.text_hui));  
        mRenderer.setMarginsColor(context.getResources().getColor(R.color.chart_bg));//设置画布距数轴之间的颜色  
        mRenderer.setZoomRate(1.4f);//放大几倍  
seriesRenderer设置部分:  
        seriesRenderer.setFillBelowLine(false); // 设置折线下方是否填充  
        seriesRenderer.setFillBelowLineColor(context.getResources().getColor(R.color.chart_content_color));//填充色  
        seriesRenderer.setPointStyle(PointStyle.CIRCLE); /折线点的样式  
        seriesRenderer.setPointStrokeWidth(5f);//折线点的大小  
        seriesRenderer.setDisplayChartValues(true);//设置显示折线的点对应的值  
        seriesRenderer.setChartValuesTextSize(16);  
        seriesRenderer.setColor(Color.BLUE);  
        seriesRenderer.setChartValuesSpacing(7);  
        seriesRenderer.setLineWidth(3.0f)//折线宽度  
        seriesRenderer.setDisplayChartValuesDistance(5);///折线点的值距离折线点的距离  
        seriesRenderer.setChartValuesTextAlign(Align.RIGHT);  
        DecimalFormat df1 = new DecimalFormat(".00");  
        seriesRenderer.setChartValuesFormat(df1);//设置折线点的值的格式,显示小数点后2位  
大体就是这样,这边举例的是折线图,其实柱状图也是这样的流程.可以参考demo,样式我只能提供这么多了.一句话,不管什么视图,流程都是这个流程.  
如果有啥不对的,欢迎指出,不能把错的分享给别人了,嘿嘿.

这篇关于关于achartengine的使用一些小经验 - Mentos的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/466133

相关文章

使用Nginx配置文件服务器方式

《使用Nginx配置文件服务器方式》:本文主要介绍使用Nginx配置文件服务器方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 为什么选择 Nginx 作为文件服务器?2. 环境准备3. 配置 Nginx 文件服务器4. 将文件放入服务器目录5. 启动 N

使用nohup和--remove-source-files在后台运行rsync并记录日志方式

《使用nohup和--remove-source-files在后台运行rsync并记录日志方式》:本文主要介绍使用nohup和--remove-source-files在后台运行rsync并记录日... 目录一、什么是 --remove-source-files?二、示例命令三、命令详解1. nohup2.

Qt之QMessageBox的具体使用

《Qt之QMessageBox的具体使用》本文介绍Qt中QMessageBox类的使用,用于弹出提示、警告、错误等模态对话框,具有一定的参考价值,感兴趣的可以了解一下... 目录1.引言2.简单介绍3.常见函数4.按钮类型(QMessage::StandardButton)5.分步骤实现弹窗6.总结1.引言

Python使用Reflex构建现代Web应用的完全指南

《Python使用Reflex构建现代Web应用的完全指南》这篇文章为大家深入介绍了Reflex框架的设计理念,技术特性,项目结构,核心API,实际开发流程以及与其他框架的对比和部署建议,感兴趣的小伙... 目录什么是 ReFlex?为什么选择 Reflex?安装与环境配置构建你的第一个应用核心概念解析组件

Qt中Qfile类的使用

《Qt中Qfile类的使用》很多应用程序都具备操作文件的能力,包括对文件进行写入和读取,创建和删除文件,本文主要介绍了Qt中Qfile类的使用,具有一定的参考价值,感兴趣的可以了解一下... 目录1.引言2.QFile文件操作3.演示示例3.1实验一3.2实验二【演示 QFile 读写二进制文件的过程】4.

spring security 超详细使用教程及如何接入springboot、前后端分离

《springsecurity超详细使用教程及如何接入springboot、前后端分离》SpringSecurity是一个强大且可扩展的框架,用于保护Java应用程序,尤其是基于Spring的应用... 目录1、准备工作1.1 引入依赖1.2 用户认证的配置1.3 基本的配置1.4 常用配置2、加密1. 密

WinForms中主要控件的详细使用教程

《WinForms中主要控件的详细使用教程》WinForms(WindowsForms)是Microsoft提供的用于构建Windows桌面应用程序的框架,它提供了丰富的控件集合,可以满足各种UI设计... 目录一、基础控件1. Button (按钮)2. Label (标签)3. TextBox (文本框

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

如何合理使用Spring的事务方式

《如何合理使用Spring的事务方式》:本文主要介绍如何合理使用Spring的事务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、底层构造1.1.事务管理器1.2.事务定义信息1.3.事务状态1.4.联系1.2、特点1.3、原理2. Sprin

Vue中插槽slot的使用示例详解

《Vue中插槽slot的使用示例详解》:本文主要介绍Vue中插槽slot的使用示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、插槽是什么二、插槽分类2.1 匿名插槽2.2 具名插槽2.3 作用域插槽三、插槽的基本使用3.1 匿名插槽