用Jfree实现条形柱状图表,java代码实现

用Jfree实现条形柱状图表,java代码实现。可经常用于报表的制作,代码自动生成后可以自由查看。可以自由配置图表的各个属性,用来达到自己的要求和目的
package test1;

import org.jfree.chart.*;
import org.jfree.chart.plot.*;
import org.jfree.chart.labels.*;
import org.jfree.data.category.*;

import java.awt.*;
import java.io.FileOutputStream;
import java.io.IOException;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;

import org.jfree.ui.*;
import org.jfree.chart.renderer.category.BarRenderer;
import org.jfree.chart.renderer.category.BarRenderer3D;
import org.jfree.chart.servlet.*;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.data.general.DatasetUtilities;

import com.dao.DBConnection;

public class JfreeChart {

	public static void main(String[] args) throws IOException, SQLException {
		// TODO Auto-generated method stub
		double[][] data = new double[][] {
				{ 1230, 1110, 1120, 1210, 720, 750, 860, 800, 1230, 1110, 1120,
						1210, 720, 750, 860, 800, 1230, 1110, 1120, 1210, 720,
						750, 860, 800 },
				{ 720, 750, 860, 800, 1230, 1110, 1120, 1210, 720, 750, 860,
						800, 720, 750, 860, 800, 1230, 1110, 1120, 1210, 720,
						750, 860, 800 } };
		String[] rowKeys = { "a", "b" };
		String[] columnKeys = { "0", "1", "2", "3", "4", "5", "6", "7", "8",
				"9", "10", "11", "12", "13", "14", "15", "16", "17", "18",
				"19", "20", "21", "22", "23" };
		CategoryDataset dataset = DatasetUtilities.createCategoryDataset(
				rowKeys, columnKeys, data);
		JFreeChart chart = ChartFactory.createBarChart(getNextDay() + "日交易量",
				"时间(/h)", "交易量", dataset, PlotOrientation.VERTICAL, true, true,
				false);
		CategoryPlot plot = chart.getCategoryPlot();
		// 设置网格背景颜色
		plot.setBackgroundPaint(Color.white);
		// 设置网格竖线颜色
		plot.setDomainGridlinePaint(Color.pink);
		// 设置网格横线颜色
		plot.setRangeGridlinePaint(Color.pink);

		// 显示每个柱的数值,并修改该数值的字体属性
		BarRenderer renderer = new BarRenderer();
		// renderer.setBaseItemLabelGenerator(new
		// StandardCategoryItemLabelGenerator());
		// renderer.setBaseItemLabelsVisible(true);

		// 默认的数字显示在柱子中,通过如下两句可调整数字的显示
		// 注意:此句很关键,若无此句,那数字的显示会被覆盖,给人数字没有显示出来的问题
		// renderer.setBasePositiveItemLabelPosition(new ItemLabelPosition(
		// ItemLabelAnchor.OUTSIDE12, TextAnchor.BASELINE_LEFT));
		// renderer.setItemLabelAnchorOffset(10D);

		// 设置每个地区所包含的平行柱的之间距离
		renderer.setItemMargin(0.05);
		plot.setRenderer(renderer);

		// 设置地区、销量的显示位置
		// 将下方的“标注”放到上方
		// plot.setDomainAxisLocation(AxisLocation.TOP_OR_RIGHT);
		// 将默认放在左边的“销量”放到右方
		// plot.setRangeAxisLocation(AxisLocation.BOTTOM_OR_RIGHT);
		drawToOutputStream("src//a.jpg", chart);
	}

	/**
	 * step3: 输出图表到指定的磁盘
	 * 
	 * @param destPath
	 * @param chart
	 */
	public static void drawToOutputStream(String destPath, JFreeChart chart) {
		FileOutputStream fos = null;
		try {
			fos = new FileOutputStream(destPath);
			// ChartUtilities.writeChartAsJPEG(
			ChartUtilities.writeChartAsPNG(fos, // 指定目标输出流
					chart, // 图表对象
					1000, // 宽
					500, // 高
					null); // ChartRenderingInfo信息
		} catch (IOException e) {
			e.printStackTrace();
		} finally {
			try {
				fos.close();
			} catch (IOException e) {
				e.printStackTrace();
			}
		}
	}

	public static String getNextDay() {
		Calendar calendar = Calendar.getInstance();
		calendar.add(Calendar.DATE, -1); // 得到前一天
		Date date = calendar.getTime();
		DateFormat df = new SimpleDateFormat("yyyy-MM-dd");
		// System.out.println(df.format(date));
		return df.format(date);
	}
}

显示生成结果:


  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是Java实现Excel导出柱状图的示例代码: ```java import java.io.FileOutputStream; import java.io.IOException; import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook; import org.jfree.chart.ChartFactory; import org.jfree.chart.JFreeChart; import org.jfree.chart.plot.PlotOrientation; import org.jfree.data.category.DefaultCategoryDataset; public class ExcelBarChartExporter { public static void export(String filePath) throws IOException { // 创建工作簿 Workbook workbook = new XSSFWorkbook(); // 创建工作 Sheet sheet = workbook.createSheet("Bar Chart"); // 创建数据集 DefaultCategoryDataset dataset = new DefaultCategoryDataset(); dataset.addValue(1.0, "Series 1", "Category 1"); dataset.addValue(2.0, "Series 1", "Category 2"); dataset.addValue(3.0, "Series 1", "Category 3"); dataset.addValue(4.0, "Series 1", "Category 4"); dataset.addValue(5.0, "Series 1", "Category 5"); // 创建柱状图 JFreeChart chart = ChartFactory.createBarChart( "Bar Chart", // 图标题 "Category", // X轴标签 "Value", // Y轴标签 dataset, // 数据集 PlotOrientation.VERTICAL, // 图方向 true, // 是否显示图例 true, // 是否显示工具提示 false // 是否显示URL链接 ); // 将图插入工作 Drawing<?> drawing = sheet.createDrawingPatriarch(); ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 5, 10, 20); ChartUtils.generateChartImage(chart, anchor, workbook); // 保存工作簿 FileOutputStream outputStream = new FileOutputStream(filePath); workbook.write(outputStream); workbook.close(); outputStream.close(); } } ``` 该示例使用了Apache POI和JFreeChart两个库,其中Apache POI用于操作Excel文件,JFreeChart用于绘制图。示例中创建了一个柱状图,并将其插入到Excel工作中,最后将工作簿保存到指定的文件路径。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值