package charts;
import java.awt.Color;
import java.awt.Font;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.text.DecimalFormat;
import javax.servlet.http.HttpSession;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartRenderingInfo;
import org.jfree.chart.ChartUtilities;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.CategoryAxis;
import org.jfree.chart.axis.CategoryLabelPositions;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.entity.StandardEntityCollection;
import org.jfree.chart.labels.StandardCategoryItemLabelGenerator;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.BarRenderer;
import org.jfree.chart.renderer.category.CategoryItemRenderer;
import org.jfree.chart.servlet.ServletUtilities;
import org.jfree.chart.title.TextTitle;
import org.jfree.data.category.CategoryDataset;
import org.jfree.data.category.DefaultCategoryDataset;
public class DataBaseBarChart
{
/**
* 根据SQL取结果集
* @param sql
* @return
*/
public static ResultSet getData(String sql)
{
// 数据库查询
Connection conn = null;
Statement stat = null;
ResultSet rs = null;
try
{
// 加载数据库驱动类
Class.forName("com.mysql.jdbc.Driver")
.newInstance();
// 数据库连接URL
String url = "jdbc:mysql://localhost:3306/pubs";
// 数据库用户名
String user = "root";
// 数据库密码
String password = "123456";
// 根据数据库参数取得一个数据库连接
conn = DriverManager.getConnection(url, user, password);
stat = conn.createStatement();
rs = stat.executeQuery(sql);
}
catch (Exception ex)
{
ex.printStackTrace();
}
return rs;
}
/**
* 构造报表的结果集
*
* @return
*/
private static CategoryDataset createDataset()
{
// 创建结果集对象
DefaultCategoryDataset dataset = new DefaultCategoryDataset();
// 向结果集中添加数据
String series1 = "商业银行贷存比";
String sql = "select * from bank";
ResultSet rs = getData(sql);
try
{
while (rs.next())
{
float percents = rs.getFloat("percents");
String bank = rs.getString("bank");
dataset.addValue(percents, series1, bank);
}
}
catch (SQLException e)
{
e.printStackTrace();
}
return dataset;
}
/**
* 根据结果集构造JFreechart报表对象
* @param dataSet
* @return
*/
private static JFreeChart createChart(CategoryDataset dataSet)
{
JFreeChart jfreechart = ChartFactory.createBarChart(
"全球WCDMA产业联盟成员构成情况", // 报表标题
"成员", // 柱体排列轴标签
"数量", // 柱体数值范围轴标签
dataSet, // 结果集
PlotOrientation.VERTICAL, // 柱状图的方向
false, // 是否显示图例
true, // 是否有工具条提示
false // 是否有链接
);
// 设置图表背景颜色
jfreechart.setBackgroundPaint(Color.WHITE);
jfreechart.addSubtitle(new TextTitle("------《2008年银行业行业报告》", new Font(
"Dialog", Font.ITALIC, 10)));
// 取得CategoryPlot对象的引用,通过这个对象可以对图表进行具体的设置
CategoryPlot plot = (CategoryPlot) jfreechart.getPlot();
plot.setRangeGridlinePaint(Color.BLACK);
// 显示柱体代表的值
CategoryItemRenderer renderer = plot.getRenderer();
renderer
.setBaseItemLabelGenerator(new StandardCategoryItemLabelGenerator(
"{2}", java.text.NumberFormat.getPercentInstance()));
renderer.setItemLabelsVisible(true);
// 设置柱体的外观
BarRenderer barrenderer = (BarRenderer) plot.getRenderer();
barrenderer.setDrawBarOutline(true);
barrenderer.setMaximumBarWidth(0.05);
barrenderer.setSeriesPaint(0, Color.PINK);
// 设置坐标
NumberAxis rangeAxis = (NumberAxis) plot.getRangeAxis();
rangeAxis.setUpperMargin(0.15);
rangeAxis.setNumberFormatOverride(new DecimalFormat("0.0%"));
CategoryAxis domainAxis = plot.getDomainAxis();
domainAxis.setCategoryLabelPositions(CategoryLabelPositions.UP_45);
return jfreechart;
}
/**
* 生成二维柱状图的图片,返回图片文件的名称
* @param session
* @param pw
* @return
*/
public static String generateBarChart(HttpSession session, PrintWriter pw)
{
String filename = null;
CategoryDataset dataset = createDataset();
JFreeChart chart = createChart(dataset);
ChartRenderingInfo info = new ChartRenderingInfo(
new StandardEntityCollection());
try
{
filename = ServletUtilities.saveChartAsPNG(chart, 500, 300, info,
session);
}
catch (IOException e)
{
e.printStackTrace();
}
try
{
ChartUtilities.writeImageMap(pw, filename, info, false);
}
catch (IOException e)
{
e.printStackTrace();
}
pw.flush();
return filename;
}
}
最近下载更多
wusiyin LV14
2022年9月15日
微信网友_5957378031800320 LV3
2022年5月18日
xcj456 LV8
2020年9月12日
15838634741 LV18
2020年7月3日
peterLi LV3
2019年12月30日
zjjhzjb LV15
2019年12月7日
wl2301821 LV7
2019年11月19日
906396135 LV7
2019年10月31日
wanglong_wang LV13
2019年8月1日
丷夏空丷 LV4
2019年5月19日
最近浏览更多
Solowen
4月16日
暂无贡献等级
fesfefe LV13
2023年11月1日
pnews88 LV8
2023年6月30日
abc562311934 LV4
2022年10月8日
wusiyin LV14
2022年9月15日
杠上炮 LV6
2022年6月28日
微信网友_5957378031800320 LV3
2022年5月18日
huzxiong
2022年2月24日
暂无贡献等级
wxh1234567 LV4
2022年1月17日
nickshen111 LV8
2021年12月13日

