根据数据库数据画饼图

2024-03-03 16:48
文章标签 数据 数据库 画饼

本文主要是介绍根据数据库数据画饼图,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

 

       数据库传入数据为   (分类、该分类下消费金额)

 

       效果图:

 

	private HashMap<String,Integer> getMonthData(){HashMap<String,Integer> map = new HashMap<String,Integer>();ArrayList<String>kindlist = (ArrayList<String>) kdao.find();for(int i=0;i<kindlist.size();i++){int kindsum = mdao.findSumOfKind(application.getUser_id(),kindlist.get(i),null,(String) year_pic_time.getText());map.put(kindlist.get(i),kindsum);}yearDataMap = map;return map;}/***  画饼图*/private void CreatePicBingTu(){year_pic.removeAllViews();CategorySeries dataset=buildCategoryDataset("月统计饼图", getMonthData());ArrayList<Integer>colors = new ArrayList<Integer>();colors.add(Color.BLACK);colors.add(Color.BLUE);colors.add(Color.GRAY);colors.add(Color.DKGRAY);colors.add(Color.RED);colors.add(Color.GREEN);ArrayList<Integer> colorlist= new ArrayList<Integer>();for(int i=0;i<yearDataMap.size();i++){colorlist.add(colors.get(i));}DefaultRenderer renderer=buildCategoryRenderer(colorlist);graphicalView=ChartFactory.getPieChartView(getBaseContext(), dataset, renderer);//饼状图year_pic.addView(graphicalView);}protected CategorySeries buildCategoryDataset(String title, HashMap<String, Integer> map) {CategorySeries series = new CategorySeries(title);Set set = map.entrySet();Iterator it = set.iterator();	         Double sum = 0.0;while(it.hasNext()){java.util.Map.Entry entry = (java.util.Map.Entry)it.next();sum+=Double.parseDouble(entry.getValue().toString());}it = set.iterator();while(it.hasNext()){double hundred;java.util.Map.Entry entry = (java.util.Map.Entry)it.next();String key = entry.getKey().toString();double value = Double.parseDouble(entry.getValue().toString());if(sum>0){hundred = value/sum*100;series.add(key+"  "+doubleFormat.format(hundred)+"%",value);}else series.add(key+"  "+"0%",value);}return series;}protected DefaultRenderer buildCategoryRenderer(ArrayList<Integer> colorlist) {DefaultRenderer renderer = new DefaultRenderer();renderer.setLegendTextSize(23);//设置左下角表注的文字大小renderer.setLabelsTextSize(28.0f);renderer.setMargins(new int[] { 20, 30, 15,0 });//margins - an array containing the margin size values, in this order: top, left, bottom, rightfor (int i=0;i<colorlist.size();i++) {SimpleSeriesRenderer r = new SimpleSeriesRenderer();r.setColor(colorlist.get(i));renderer.addSeriesRenderer(r);}return renderer;}


 

这篇关于根据数据库数据画饼图的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi

mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据

《mysql通过frm和ibd文件恢复表_mysql5.7根据.frm和.ibd文件恢复表结构和数据》文章主要介绍了如何从.frm和.ibd文件恢复MySQLInnoDB表结构和数据,需要的朋友可以参... 目录一、恢复表结构二、恢复表数据补充方法一、恢复表结构(从 .frm 文件)方法 1:使用 mysq

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

golang获取prometheus数据(prometheus/client_golang包)

《golang获取prometheus数据(prometheus/client_golang包)》本文主要介绍了使用Go语言的prometheus/client_golang包来获取Prometheu... 目录1. 创建链接1.1 语法1.2 完整示例2. 简单查询2.1 语法2.2 完整示例3. 范围值

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

javaScript在表单提交时获取表单数据的示例代码

《javaScript在表单提交时获取表单数据的示例代码》本文介绍了五种在JavaScript中获取表单数据的方法:使用FormData对象、手动提取表单数据、使用querySelector获取单个字... 方法 1:使用 FormData 对象FormData 是一个方便的内置对象,用于获取表单中的键值

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python使用Pandas对比两列数据取最大值的五种方法

《Python使用Pandas对比两列数据取最大值的五种方法》本文主要介绍使用Pandas对比两列数据取最大值的五种方法,包括使用max方法、apply方法结合lambda函数、函数、clip方法、w... 目录引言一、使用max方法二、使用apply方法结合lambda函数三、使用np.maximum函数

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

使用 sql-research-assistant进行 SQL 数据库研究的实战指南(代码实现演示)

《使用sql-research-assistant进行SQL数据库研究的实战指南(代码实现演示)》本文介绍了sql-research-assistant工具,该工具基于LangChain框架,集... 目录技术背景介绍核心原理解析代码实现演示安装和配置项目集成LangSmith 配置(可选)启动服务应用场景