根据数据库数据画饼图

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

相关文章

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

鸿蒙中Axios数据请求的封装和配置方法

《鸿蒙中Axios数据请求的封装和配置方法》:本文主要介绍鸿蒙中Axios数据请求的封装和配置方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.配置权限 应用级权限和系统级权限2.配置网络请求的代码3.下载在Entry中 下载AxIOS4.封装Htt

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Ubuntu中远程连接Mysql数据库的详细图文教程

《Ubuntu中远程连接Mysql数据库的详细图文教程》Ubuntu是一个以桌面应用为主的Linux发行版操作系统,这篇文章主要为大家详细介绍了Ubuntu中远程连接Mysql数据库的详细图文教程,有... 目录1、版本2、检查有没有mysql2.1 查询是否安装了Mysql包2.2 查看Mysql版本2.

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Win11安装PostgreSQL数据库的两种方式详细步骤

《Win11安装PostgreSQL数据库的两种方式详细步骤》PostgreSQL是备受业界青睐的关系型数据库,尤其是在地理空间和移动领域,:本文主要介绍Win11安装PostgreSQL数据库的... 目录一、exe文件安装 (推荐)下载安装包1. 选择操作系统2. 跳转到EDB(PostgreSQL 的