mysql怎么实现柱状图 如何建柱状图

php结合mysql如何制作柱状图

有很多的绘图类可以用,jpgraph phplot都可以,和mysql没什么直接关系,提供两组数据就可以了。

创新互联是一家集网站建设,五指山企业网站建设,五指山品牌网站建设,网站定制,五指山网站建设报价,网络营销,网络优化,五指山网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

如何用matlab获取到的MySql数据库中的数据作柱状图

从数据库中不是已经返回数据了吗,剩下的就是如何解析这些返回的数据,然后用绘图命令绘制出来了

怎样用柱状图实现mysql数据库中的数据,现在我不知道怎么将数据库中的数据读取出来显示在柱状图上

public class CategoryItemChart {

public static String generateBarChart(HttpSession session, PrintWriter pw,int w, int h,ArrayList list) {

String filename = null;

try {

CategoryDataset dataset = createDataset(list);

JFreeChart chart = ChartFactory.createBarChart(

"",//图表标题

"",//X轴标题

"",//Y轴标题

dataset,//数据集合

PlotOrientation.VERTICAL,//图表显示方向(水平、垂直)

true,//是否使用图例

true,//是否使用工具提示

false//是否为图表增加URL

);

/*------------配置图表属性--------------*/

chart.setBackgroundPaint(Color.white); // 1,设置整个图表背景颜色

CategoryPlot plot = chart.getCategoryPlot(); /*------------设定Plot参数-------------*/

plot.setBackgroundPaint(Color.white); // 2,设置详细图表的显示细节部分的背景颜色

plot.setDomainGridlinePaint(Color.black); // 3,设置垂直网格线颜色

plot.setDomainGridlinesVisible(false); // 4,设置是否显示垂直网格线

plot.setRangeGridlinePaint(Color.yellow); // 5,设置水平网格线颜色

plot.setRangeGridlinesVisible(false); //6,设置是否显示水平网格线

/*---------将所有数据转换为整数形式---------*/

final NumberAxis rangeAxis = (NumberAxis) plot.getRangeAxis();

rangeAxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());

/*---------设置是否在柱图的状态条上显示边框----*/

CategoryItemRenderer renderer = (CategoryItemRenderer) plot.getRenderer();

BarRenderer render = (BarRenderer) plot.getRenderer();

// render.setItemMargin(0.0);

// render.setMinimumBarLength(0.0);

/*---------设置状态条颜色的深浅渐变-----------*/

GradientPaint gp0 = new GradientPaint(0.0f, 0.0f, new Color(255,200, 80), 0.0f, 0.0f, new Color(255, 255, 40));

GradientPaint gp1 = new GradientPaint(0.0f, 0.0f, new Color(50,255, 50), 0.0f, 0.0f, new Color(100, 255, 100));

GradientPaint gp2 = new GradientPaint(0.0f, 0.0f, Color.red, 0.0f,0.0f, new Color(255, 100, 100));

GradientPaint gp3 = new GradientPaint(0.0f, 0.0f, new Color(108,108, 255), 0.0f, 0.0f, new Color(150, 150, 200));

renderer.setSeriesPaint(0, gp0);

renderer.setSeriesPaint(1, gp1);

renderer.setSeriesPaint(2, gp2);

renderer.setSeriesPaint(3, gp3);

/*

*

* 解决柱状体与图片边框的间距问题

*

*

* */

/*------设置X轴标题的倾斜程度----*/

CategoryAxis domainAxis = plot.getDomainAxis();

domainAxis.setCategoryLabelPositions(CategoryLabelPositions.createUpRotationLabelPositions(Math.E / 6.0));

/*------设置柱状体与图片边框的左右间距--*/

domainAxis.setLowerMargin(0.06);

domainAxis.setUpperMargin(0.06);

/*------设置柱状体与图片边框的上下间距---*/

ValueAxis rAxis = plot.getRangeAxis();

rAxis.setUpperMargin(0.3);

rAxis.setLowerMargin(0.3);

/*---------设置每一组柱状体之间的间隔---------*/

render.setItemMargin(0.01);

/*

*

* 解决柱状体与图片边框的间距问题

*

*

* */

/*

*

*

* 解决JFREECHART的中文显示问题

*

*

* */

/*----------设置消除字体的锯齿渲染(解决中文问题)--------------*/

chart.getRenderingHints().put(RenderingHints.KEY_TEXT_ANTIALIASING,RenderingHints.VALUE_TEXT_ANTIALIAS_OFF);

/*----------设置标题字体--------------------------*/

TextTitle textTitle = chart.getTitle();

textTitle.setFont(new Font("黑体", Font.PLAIN, 20));

/*------设置X轴坐标上的文字-----------*/

domainAxis.setTickLabelFont(new Font("sans-serif", Font.PLAIN, 11));

/*------设置X轴的标题文字------------*/

domainAxis.setLabelFont(new Font("宋体", Font.PLAIN, 12));

/*------设置Y轴坐标上的文字-----------*/

rAxis.setTickLabelFont(new Font("sans-serif", Font.PLAIN, 14));

/*------设置Y轴的标题文字------------*/

rAxis.setLabelFont(new Font("黑体", Font.PLAIN, 12));

/*---------设置柱状体上的显示的字体---------*/

renderer.setBaseItemLabelFont(new Font("宋体", Font.PLAIN, 12));

renderer.setBaseItemLabelGenerator(new LabelGenerator(0.0));

renderer.setBaseItemLabelsVisible(true);

/*

*

*

* 解决JFREECHART的中文显示问题

*

*

* */

/*------得到chart的保存路径----*/

ChartRenderingInfo info = new ChartRenderingInfo(new StandardEntityCollection());

filename = ServletUtilities.saveChartAsPNG(chart, w, h, info,session);

/*------使用printWriter将文件写出----*/

ChartUtilities.writeImageMap(pw, filename, info, true);

pw.flush();

} catch (Exception e) {

System.out.println("Exception - " + e.toString());

e.printStackTrace(System.out);

filename = "public_error_500x300.png";

}

return filename;

}

/*-------------设置柱状体顶端的数据显示--------------*/

static class LabelGenerator implements CategoryItemLabelGenerator {

private double threshold;

public LabelGenerator(double threshold) {

this.threshold = threshold;

}

public String generateLabel(CategoryDataset dataset, int row, int column) {

String result = null;

final Number value = dataset.getValue(row, column);

if (value != null) {

final double v = value.doubleValue();

if (v this.threshold) {

result = value.toString();

}

}

return result;

}

public String generateRowLabel(CategoryDataset dataset, int row) {

return null;

}

public String generateColumnLabel(CategoryDataset dataset, int column) {

return null;

}

}

/*-----------数据封装-------------*/

private static CategoryDataset createDataset(ArrayList list) {

String s1 = "1";

String s2 = "2";

String c1 = "1";

String c2 = "2";

DefaultCategoryDataset dataset = new DefaultCategoryDataset();

dataset.setValue(44, s1, c1);

dataset.setValue(48, s2, c2);

return dataset;

}

}

比较完整的一个得到柱图的代码,保存路径是临时文件,怎么从数据库取值应该会吧。把dataset处理一下就可以了。

highcharts jsp mysql三者结合起来做一个柱状图。跪求啊~给个思路也行 啊~

这个最好先去官网看看 demo 哪里面有代码 很详细。

等看懂 demo 后 就去试试谢谢。

你只要把 你要的数据返回成list集合再用map封装。转换成json数据传到页面就行了!


分享名称:mysql怎么实现柱状图 如何建柱状图
转载来源:http://pwwzsj.com/article/hhehie.html