JfreeChart(3)-------BarChart的简单使用

简介: 今天项目中用到了BarChart,其中的中文问题还是花了我比较多的时间的,所以就把这段代码记录下来,方便以后的查阅!感觉这个知识还真的是越用越活的,越用越熟的,用少了过段时间就忘了,用多了的话很长时间都记得!   private byte[] createChart(List data...

今天项目中用到了BarChart,其中的中文问题还是花了我比较多的时间的,所以就把这段代码记录下来,方便以后的查阅!感觉这个知识还真的是越用越活的,越
用越熟的,用少了过段时间就忘了,用多了的话很长时间都记得!

 

private byte[] createChart(List<Object[]> data, String title, String xtitle, String ytitle) {
		DefaultCategoryDataset dataset = new DefaultCategoryDataset();
		for (int i=0;i<data.size();i++) {
			Object[] objs = data.get(i);
			//由上知objs里面只含有两个元素,所以可以直接对它们进行取值;
			String name = (String)objs[0];
			long sumNumber = (Long)objs[1];
			dataset.addValue(sumNumber, name, name);
		}
		JFreeChart chart = ChartFactory.createBarChart3D(title, xtitle, ytitle, dataset, PlotOrientation.VERTICAL, true, true, false);
		//设置标题的字体,不设置中文会乱码
		chart.setTitle(new TextTitle(title,new Font("宋体",Font.BOLD,22)));
		
		CategoryPlot plot = (CategoryPlot) chart.getPlot();
		Font font = new Font("宋体",Font.BOLD,18);
		Font font2 = new Font("宋体", Font.PLAIN,16);
		plot.getRangeAxis().setLabelFont(font);//设置纵轴标签的字体,不设置中文会乱码
		plot.getDomainAxis().setLabelFont(font);//设置横轴的标题的字体
		plot.getDomainAxis().setTickLabelFont(font2);//设置X轴坐标上的字体
		chart.getLegend(0).setItemFont(font2);
//		File file = Util.getChartFile4Save(prefix);
		ByteArrayOutputStream out = new ByteArrayOutputStream();
		try {
//			ChartUtilities.saveChartAsJPEG(file, chart, 800, 600);
			ChartUtilities.writeChartAsJPEG(out, chart, 800, 600);
		} catch (IOException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		return out.toByteArray();
	}

 

目录
相关文章
|
JSON 数据可视化 JavaScript
pyecharts包的简单使用
第三方包使用
98 0
|
数据可视化 C++
QCustomplot基本使用(一)
QCustomplot基本使用(一)
368 0
QWebEngineView简单使用
QWebEngineView是提供一个访问web页面的widget,这里是一个简单的使用代码
181 0
ApplicationEventPublisher的简单使用
ApplicationEventPublisher的简单使用
435 0
MPPlayer的简单使用
MPPlayer的简单使用
210 0
|
缓存 JavaScript 编译器
Qt+ECharts开发笔记(三):ECharts的柱状图介绍、基础使用和Qt封装Demo
上一篇成功是EChart随着Qt窗口变化而变化,本篇将开始正式介绍柱状图介绍、基础使用,并将其封装一层Qt。   本篇的demo实现了隐藏js代码的方式,实现了一个条形图的基本交互方式,即Qt调用js脚本操作html。
Qt+ECharts开发笔记(三):ECharts的柱状图介绍、基础使用和Qt封装Demo
|
Web App开发 存储 监控
【ChromeDevTool】Performace的简单使用
【ChromeDevTool】Performace的简单使用
116 0
【ChromeDevTool】Performace的简单使用