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  LV14 2019年12月7日
wl2301821  LV7 2019年11月19日
906396135  LV7 2019年10月31日
wanglong_wang  LV13 2019年8月1日
丷夏空丷  LV4 2019年5月19日
最近浏览更多
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日
James_hong  LV1 2021年10月14日
顶部 客服 微信二维码 底部
>扫描二维码关注最代码为好友扫描二维码关注最代码为好友