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

本文介绍了如何使用JFreeChart库在Java中生成3D条形图,适用于报表制作。代码示例展示了如何配置图表属性,如背景颜色、网格线颜色和柱状图的数值显示,最后将图表保存为图片文件。
摘要由CSDN通过智能技术生成

用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);

}

}

显示生成结果:

85a7948a120d07b24b6320f8c9d7f48c.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是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工作中,最后将工作簿保存到指定的文件路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值