jfreeChart柱状图各属性详细设置

一. 下载与环境配置 
此最新版本为 1.0.13 
解压jfreechart-1.0.13.zip 将lib目录下的jfreechart-1.0.13.jar 、jcommon-1.0.16.jar 复制到工程 WEB-INF\lib 文件夹中 
二. 配置 
我是用Struts1.2开发的。 
在工程的web.xml 文件中添加 
<servlet> 
            <servlet-name>DisplayChart</servlet-name> 
            <servlet-class>org.jfree.chart.servlet.DisplayChart</servlet-class> 
    </servlet> 
    <servlet-mapping> 
            <servlet-name>DisplayChart</servlet-name> 
            <url-pattern>/DisplayChart</url-pattern> 
    </servlet-mapping>

三. 生成柱形图 
新建个Action 最好是继承DispatchAction 
public ActionForward toBarPic(ActionMapping mapping, ActionForm form, 
HttpServletRequest request, HttpServletResponse response) {

DefaultCategoryDataset dataset = new DefaultCategoryDataset(); 
//添加数据 
dataset.addValue(440, "数据", "类型1"); 
dataset.addValue(360, "数据", "类型2"); 
dataset.addValue(510, "数据", "类型3"); 
dataset.addValue(390, "数据", "类型4"); 
        // 
JFreeChart  chart = ChartFactory.createBarChart3D("XXX统计图", "类型","数据额", dataset, PlotOrientation.VERTICAL, true, false, false);

HttpSession session=request.getSession(); 
String filename=""; 
try{ 
//生成宽600,高420 png格式的图,并将图片保存到session中,好像只能保存到session中,要不就设置为null

filename = ServletUtilities.saveChartAsPNG(chart,600,420, null, session); 
}catch(Exception ex){ 
ex.printStackTrace(); 

String graphURL = request.getContextPath() + "/DisplayChart?filename=" + filename; 
        request.setAttribute("graphURL", graphURL); 
        request.setAttribute("filename", filename); 
return mapping.findForward("success"); 
}

页面中 图片链接方式 
   <img src="${graphURL}" width=630 height=450 border=0 usemap="#${filename}">

生成的图如下: 

可见生成柱形图很简单,只需要以下几步 
1、 DefaultCategoryDataset dataset = new DefaultCategoryDataset(); 
2、 dataset.addValue(440, "数据", "类型1"); //封数据 
3、 JFreeChart  chart = ChartFactory.createBarChart3D("XXX统计图", "类型","数据额", dataset, PlotOrientation.VERTICAL, true, false, false); 
4、 String filename = ServletUtilities.saveChartAsPNG(chart,600,420, null, session);//返回图片名称 
//为图片生成url访问地址 
5、 String graphURL = request.getContextPath() + "/DisplayChart?filename=" + filename; 
6、 将 图片名称filename 和图片地址 graphURL 保存到作用域中,最后返回。

以上是生成柱形图最基本的步骤,但是生成的图往往是不合人意的,因为太粗糙了,好比刚盖好的房子还没有装修,下面就对图形进行美化,装修这个柱形房子。 
要设置图片高级属性先获得 CategoryPlot 和 BarRenderer3D 大部分修改都是在这上面 
CategoryPlot plot = chart.getCategoryPlot();//设置图的高级属性 
  BarRenderer3D renderer = new BarRenderer3D();//3D属性修改 
最后还得将renderer 放到plot 中 
  plot.setRenderer(renderer);//将修改后的属性值保存到图中

在JFreeChart  chart = ChartFactory.createBarChart3D()下面添加 
CategoryPlot plot = chart.getCategoryPlot();//设置图的高级属性 
  BarRenderer3D renderer = new BarRenderer3D();//3D属性修改 
plot.setRenderer(renderer);//将修改后的属性值保存到图中 
然后做的修改都是在 
BarRenderer3D renderer = new BarRenderer3D();//3D属性修改 
plot.setRenderer(renderer);//将修改后的属性值保存到图中 
这两行中间,也就是以下添加的任何代码都是在上面这两行中间添加。 
首先修改颜色 
  
          //设置网格竖线颜色 
  plot.setDomainGridlinePaint(Color.blue); 
  plot.setDomainGridlinesVisible(true); 
          //设置网格横线颜色 
  plot.setRangeGridlinePaint(Color.blue); 
  plot.setRangeGridlinesVisible(true); 
          //图片背景色 
  plot.setBackgroundPaint(Color.LIGHT_GRAY); 
  plot.setOutlineVisible(true); 
          //图边框颜色 
  plot.setOutlinePaint(Color.magenta); 
          //边框颜色 
  renderer.setBaseOutlinePaint(Color.ORANGE); 
  renderer.setDrawBarOutline(true); 
          //设置墙体颜色 
  renderer.setWallPaint(Color.gray); 
效果图如下

 
  
接下来修改字体,看上图还是乱码,下面就对字体做调整 
    //对X轴做操作 
CategoryAxis domainAxis = plot.getDomainAxis(); 
//对Y轴做操作 
ValueAxis rAxis = plot.getRangeAxis(); 
  
/*----------设置消除字体的锯齿渲染(解决中文问题)--------------*/ 
      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, 12)); 
//设置Y轴的标题文字 
rAxis.setLabelFont(new Font("黑体", Font.PLAIN, 12));      
//底部汉字乱码的问题  
chart.getLegend().setItemFont(new Font("宋体",Font.PLAIN,12)); 
效果图如下 

在上面基础上在做一下高级设计,设计字体颜色和节段 
//对X轴做操作 
  CategoryAxis domainAxis = plot.getDomainAxis(); 
  //对Y轴做操作 
  ValueAxis rAxis = plot.getRangeAxis(); 
  
  /*--------设置消除字体的锯齿渲染(解决中文问题)---------*/ 
   chart.getRenderingHints().put(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_OFF); 
      
      //设置标题字体 
      TextTitle textTitle = chart.getTitle(); 
      textTitle.setFont(new Font("黑体", Font.PLAIN, 20)); 
          textTitle.setBackgroundPaint(Color.LIGHT_GRAY);//标题背景色 
          textTitle.setPaint(Color.cyan);//标题字体颜色 
          textTitle.setText("类型统计图");//标题内容  
      //设置X轴坐标上的文字 
domainAxis.setTickLabelFont(new Font("宋体", Font.PLAIN, 11)); 
      //设置X轴的标题文字 
      domainAxis.setLabelFont(new Font("宋体", Font.PLAIN, 12)); 
      
      domainAxis.setTickLabelPaint(Color.red);//X轴的标题文字颜色 
      domainAxis.setTickLabelsVisible(true);//X轴的标题文字是否显示 
      domainAxis.setAxisLinePaint(Color.red);//X轴横线颜色 
      domainAxis.setTickMarksVisible(true);//标记线是否显示 
      domainAxis.setTickMarkOutsideLength(3);//标记线向外长度 
      domainAxis.setTickMarkInsideLength(3);//标记线向内长度 
      domainAxis.setTickMarkPaint(Color.red);//标记线颜色 
      /**  Y轴设计同X轴相类似  **/ 
      //设置Y轴坐标上的文字 
      rAxis.setTickLabelFont(new Font("宋体", Font.PLAIN, 12)); 
      rAxis.setMinorTickCount(7);//显示有多少标记段 
      rAxis.setMinorTickMarksVisible(true);

rAxis.setRange(100, 600); //Y轴取值范围(或者如下设置) 
     // rAxis.setLowerBound(100);  //Y轴以开始的最小值 
     // rAxis.setUpperBound(600);Y轴的最大值 
      //设置Y轴的标题文字 
      rAxis.setLabelFont(new Font("黑体", Font.PLAIN, 12));      
     //底部汉字乱码的问题  
     chart.getLegend().setItemFont(new Font("宋体",Font.PLAIN,12)); 
 
  
大多数情况下都需要在柱子上显示对应的数值,设置如下: 
       renderer.setBaseItemLabelGenerator(new StandardCategoryItemLabelGenerator()); 
   renderer.setBaseItemLabelsVisible(true); 
   renderer.setBaseItemLabelPaint(Color.BLUE);//设置数值颜色,默认黑色 
   用下面设置也能达到同样效果 
       renderer.setItemLabelGenerator( new  StandardCategoryItemLabelGenerator()); 
renderer.setItemLabelsVisible( true ); 
renderer.setItemLabelPaint(Color.BLUE); 
效果图如下: 
   
默认的数值如上图所示,但是大多数情况下我们要应对不同的需求对数值显示的位置等进行调整。具体调整如下:
         //搭配ItemLabelAnchor TextAnchor 这两项能达到不同的效果,但是 
ItemLabelAnchor最好选OUTSIDE,因为INSIDE显示不出来 
renderer.setBasePositiveItemLabelPosition(new ItemLabelPosition(ItemLabelAnchor.OUTSIDE12, TextAnchor.CENTER_LEFT)); 
     //下面可以进一步调整数值的位置,但是得根据ItemLabelAnchor选择情况,例 
如我选的是OUTSIDE12,那么下面设置为正数时,数值就会向上调整,负数则向下 
       renderer.setItemLabelAnchorOffset(10); 
效果图如图六: 

有时候柱子过多,而且图大小有限,就得将柱子类型倾斜显示,或者将其放到上面等。看如下配置: 
    //将类型放到上面 
plot.setDomainAxisLocation(AxisLocation.TOP_OR_RIGHT); 
    //横轴上的 Lable 45度倾斜 
      domainAxis.setCategoryLabelPositions(CategoryLabelPositions.DOWN_45); 
//将默认放到左边的数值放到右边 
plot.setRangeAxisLocation(AxisLocation.BOTTOM_OR_RIGHT);

效果图如下: 
  

看上面的柱子太粗,实在不好看,下面就是调整柱子的宽度和透明度等: 
           //设置距离图片左端距离 
      domainAxis.setUpperMargin(0.2); 
       //设置距离图片右端距离 
      domainAxis.setLowerMargin(0.2); 
          //数据轴精度 
       NumberAxis na = (NumberAxis) plot.getRangeAxis(); 
          na.setAutoRangeIncludesZero(true); 
      DecimalFormat df = new DecimalFormat("#0.000"); 
      //数据轴数据标签的显示格式 
      na.setNumberFormatOverride(df); 
          //设置柱的透明度 
      plot.setForegroundAlpha(1.0f);

详细设置如下:DefaultCategoryDataset dataset = new DefaultCategoryDataset(); 
//添加数据 
dataset.addValue(440, "数据", "类型1"); 
dataset.addValue(360, "数据", "类型2"); 
dataset.addValue(510, "数据", "类型3"); 
dataset.addValue(390, "数据", "类型4"); 
/**参数分别为:图表标题 ,目录轴的显示标签 ,数值轴的显示标签 ,数据集 ,是否生成URL链接 
图表方向:水平、垂直, 是否显示图例(对于简单的柱状图必须是false) ,是否生成工具 */ 
JFreeChart chart = ChartFactory.createBarChart3D("XXX统计图", "类型","数据额", dataset, PlotOrientation.VERTICAL, true, false, true);

/*----------设置消除字体的锯齿渲染(解决中文问题)--------------*/ 
chart.getRenderingHints().put(RenderingHints.KEY_TEXT_ANTIALIASING, 
RenderingHints.VALUE_TEXT_ANTIALIAS_OFF); 
//底部汉字乱码的问题 
chart.getLegend().setItemFont(new Font("宋体",Font.PLAIN,12)); 
//设置标题字体 
TextTitle textTitle = chart.getTitle(); 
textTitle.setFont(new Font("黑体", Font.PLAIN, 20)); 
textTitle.setBackgroundPaint(Color.LIGHT_GRAY);//标题背景色 
textTitle.setPaint(Color.cyan);//标题字体颜色 
textTitle.setText("类型统计图");//标题内容

CategoryPlot plot = chart.getCategoryPlot();//设置图的高级属性 
BarRenderer3D renderer = new BarRenderer3D();//3D属性修改 
CategoryAxis domainAxis = plot.getDomainAxis();//对X轴做操作 
ValueAxis rAxis = plot.getRangeAxis();//对Y轴做操作

/*** 
* domainAxis设置(x轴一些设置) 
**/

//设置X轴坐标上的文字 
domainAxis.setTickLabelFont(new Font("sans-serif", Font.PLAIN, 11)); 
//设置X轴的标题文字 
domainAxis.setLabelFont(new Font("宋体", Font.PLAIN, 12)); 
domainAxis.setLabel("");//X轴的标题内容 
domainAxis.setTickLabelPaint(Color.red);//X轴的标题文字颜色 
domainAxis.setTickLabelsVisible(true);//X轴的标题文字是否显示 
domainAxis.setAxisLinePaint(Color.red);//X轴横线颜色 
domainAxis.setTickMarksVisible(true);//标记线是否显示 
domainAxis.setTickMarkOutsideLength(3);//标记线向外长度 
domainAxis.setTickMarkInsideLength(3);//标记线向内长度 
domainAxis.setTickMarkPaint(Color.red);//标记线颜色 
domainAxis.setUpperMargin(0.2);//设置距离图片左端距离 
domainAxis.setLowerMargin(0.2); //设置距离图片右端距离 
//横轴上的 Lable 是否完整显示 
domainAxis.setMaximumCategoryLabelWidthRatio(0.6f); 
//横轴上的 Lable 45度倾斜 
domainAxis.setCategoryLabelPositions(CategoryLabelPositions.DOWN_45);

/** 
* rAxis设置 Y轴设置 

**/

//设置Y轴坐标上的文字 
rAxis.setTickLabelFont(new Font("sans-serif", Font.PLAIN, 12)); 
//设置Y轴的标题文字 
rAxis.setLabelFont(new Font("黑体", Font.PLAIN, 12)); 
//Y轴取值范围(下面不能出现 rAxis.setAutoRange(true) 否则不起作用) 
rAxis.setRange(100, 600); 
// rAxis.setLowerBound(100); //Y轴以开始的最小值 
// rAxis.setUpperBound(600);//Y轴的最大值 
rAxis.setLabel("content");//Y轴内容 
rAxis.setLabelAngle(1.6);//标题内容显示角度(1.6时候水平) 
rAxis.setLabelPaint(Color.red);//标题内容颜色 
rAxis.setMinorTickMarksVisible(true);//标记线是否显示 
rAxis.setMinorTickCount(7);//节段中的刻度数 
rAxis.setMinorTickMarkInsideLength(3);//内刻度线向内长度 
rAxis.setMinorTickMarkOutsideLength(3);//内刻度记线向外长度 
rAxis.setTickMarkInsideLength(3);//外刻度线向内长度 
rAxis.setTickMarkPaint(Color.red);//刻度线颜色 
rAxis.setTickLabelsVisible(true);//刻度数值是否显示 
// 所有Y标记线是否显示(如果前面设置rAxis.setMinorTickMarksVisible(true); 则其照样显示) 
rAxis.setTickMarksVisible(true); 
rAxis.setAxisLinePaint(Color.red);//Y轴竖线颜色 
rAxis.setAxisLineVisible(true);//Y轴竖线是否显示 
//设置最高的一个 Item 与图片顶端的距离 (在设置rAxis.setRange(100, 600);情况下不起作用) 
rAxis.setUpperMargin(0.15); 
//设置最低的一个 Item 与图片底端的距离 
rAxis.setLowerMargin(0.15); 
rAxis.setAutoRange(true);//是否自动适应范围 
rAxis.setVisible(true);//Y轴内容是否显示

//数据轴精度 
NumberAxis na = (NumberAxis) plot.getRangeAxis(); 
na.setAutoRangeIncludesZero(true); 
DecimalFormat df = new DecimalFormat("#0.000"); 
//数据轴数据标签的显示格式 
na.setNumberFormatOverride(df);

/** 
* renderer设置 柱子相关属性设置 
*/renderer.setBaseOutlinePaint(Color.ORANGE); //边框颜色 
renderer.setDrawBarOutline(true); 
renderer.setWallPaint(Color.gray);//设置墙体颜色 
renderer.setMaximumBarWidth(0.08); //设置柱子宽度 
renderer.setMinimumBarLength(0.1); //设置柱子高度 
renderer.setSeriesPaint(0,Color.ORANGE); //设置柱的颜色 
renderer.setItemMargin(0); //设置每个地区所包含的平行柱的之间距离 
//在柱子上显示相应信息 
renderer.setBaseItemLabelGenerator(new StandardCategoryItemLabelGenerator()); 
renderer.setBaseItemLabelsVisible(true); 
renderer.setBaseItemLabelPaint(Color.BLACK);//设置数值颜色,默认黑色 
//搭配ItemLabelAnchor TextAnchor 这两项能达到不同的效果,但是ItemLabelAnchor最好选OUTSIDE,因为INSIDE显示不出来 
renderer.setBasePositiveItemLabelPosition(new ItemLabelPosition(ItemLabelAnchor.OUTSIDE12, TextAnchor.CENTER_LEFT)); 
//下面可以进一步调整数值的位置,但是得根据ItemLabelAnchor选择情况. 
renderer.setItemLabelAnchorOffset(10);

/** 
* plot 设置 
***/ 
//设置网格竖线颜色 
plot.setDomainGridlinePaint(Color.blue); 
plot.setDomainGridlinesVisible(true); 
//设置网格横线颜色 
plot.setRangeGridlinePaint(Color.blue);

plot.setRangeGridlinesVisible(true); 
//图片背景色 
plot.setBackgroundPaint(Color.LIGHT_GRAY); 
plot.setOutlineVisible(true); 
//图边框颜色 
plot.setOutlinePaint(Color.magenta); 
//设置柱的透明度 
plot.setForegroundAlpha(1.0f); 
//将类型放到上面 
plot.setDomainAxisLocation(AxisLocation.TOP_OR_RIGHT); 
//将默认放到左边的数值放到右边 
plot.setRangeAxisLocation(AxisLocation.BOTTOM_OR_RIGHT); 
plot.setRenderer(renderer);//将修改后的属性值保存到图中

HttpSession session=request.getSession(); 
String filename="";

try{ 
//生成宽600,高420 png格式的图,并将图片保存到session中,好像只能保存到session中,要不就设置为null 
filename = ServletUtilities.saveChartAsPNG(chart,600,420, null, session); 
}catch(Exception ex){ 
ex.printStackTrace(); 

String graphURL = request.getContextPath() + "/DisplayChart?filename=" + filename; 
request.setAttribute("graphURL", graphURL); 
request.setAttribute("filename", filename);

时间: 2024-10-26 18:20:24

jfreeChart柱状图各属性详细设置的相关文章

Ext属性详细信息

Ext.window属性详细信息 Ext.Window扩展自Ext.Panel,其xtype值为window. 1.主要配置项 closable:是否允许关闭窗口,默认为true.       closeAction:关闭窗口的动作,包括以下两种:        close:从DOM删除窗口,销毁窗口及其所属组件,窗口不再可用,重新显示需要调   用show方法.此为默认值.        hide:通过设置可见性隐藏窗口,窗口还可用,调用show方法后重新显示.       constrain

Win2008远程多用户登陆的配置方法 另附详细设置: Windows server 2008 R2实现多用户远程连接

Win2008远程多用户登陆的配置方法 在使用Windows 2008远程登录功能时,如果需要进行多用户登录,可以采用以下配置方法:  首先要启用远程桌面这一功能:右击"我的电脑"→ 属性 → 远程配置 → 远程桌面,就可以配置相应的远程桌面功能了.下面是配置多用户登陆的方法:   打开 控制面板 → 管理工具 → 终端服务(Terminal Services) → 终端服务配置(Terminal Services Configuration)   1.(修改可以同时登陆的人数,包括自

jfreechart 柱状图的重叠显示 LayeredBarRenderer

由于jfreechart中 LayeredBarRenderer在绘制时,即便将两个series设置成相同宽度,也会显示为不同宽度.可以通过如下方式实现重叠显示. LayeredBarRenderer renderer = new LayeredBarRenderer (); renderer.setSeriesBarWidth(0, 1); renderer.setSeriesBarWidth(1, 0.6); jfreechart 柱状图的重叠显示 LayeredBarRenderer,布布

如何在App中实现朋友圈功能之五点赞、评论属性详细解析——箭扣科技Arrownock

如何在App中实现朋友圈功能 之五 点赞.评论属性详细解析 快速查看评论和点赞数量: 当我们创建一个墙贴后,这个墙贴会自动带有评论数量commentCount.赞数量likeCount.讨厌数量dislikeCount三个属性. 当有用户对这个墙贴进行了评论,该墙贴的commentCount属性会自动增长,无需开发者来手动操作实现. 如果用户建立的Like中like=true,那么likeCount会自动增长,反之,dislikeCount会自动增长. 如果用户把评论删除了,或者是把点赞撤销了,

问题.NET--win7 IIS唯一密钥属性“VALUE”设置为“DEFAULT.ASPX”时,无法添加类型为“add”的重复集合

问题现象:.NET--win7 IIS唯一密钥属性“VALUE”设置为“DEFAULT.ASPX”时,无法添加类型为“add”的重复集合 问题处理: 内容摘要: HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效. 错误摘要 HTTP 错误 500.19 - Internal Server Error 无法访问请求的页面,因为该页的相关配置数据无效. 详细错误信息模块 DefaultDocumentModule 通知 Ex

c# webConfig中的session超时详细设置

webConfig中的session超时详细设置 我们在webConfig中设置Session超时的时候,如果最后发行的地址是远程服务器,我们很多不是必须的属性并不用设置,如果设之后,倒不能让 session超时奏效.我在做现在的程序的时候,就是这样,写sessionState的时候,按照如下的方式设置之后,session设置的 timeout时间不能够起作用:但是不用了一些属性之后,就能够起作用了. 服务器上发行后不能起作用的设置: <sessionState mode="InProc&

[转]图解CSS的padding,margin,border属性(详细介绍及举例说明)

图解CSS的padding,margin,border属性 W3C组织建议把所有网页上的对像都放在一个盒(box)中,设计师可以通过创建定义来控制这个盒的属性,这些对像包括段落.列表.标题.图片以及层.盒模型主要定义四个区域:内容(content).边框距(padding).边界(border)和边距(margin). 对于初学者,经常会搞不清楚margin,background-color,background-image,padding,content,border之间的层次.关系和相互影响

Eclipse详细设置护眼背景色和字体颜色并导出

Eclipse详细设置护眼背景色和字体颜色并导出 Eclipse是一款码农们喜闻乐见的集成开发平台,但是其默认的主题和惨白的背景色实在是太刺激眼球了.下面,将给大家详细介绍如何设置成护眼主题的方法,也做个抛砖引玉,希望能有更多的主题出现在Eclipse的大家庭中. 随后,本文将介绍如何将设置好的主题导出保存,用于重装系统或者分享给朋友. 最后,介绍三种笔者用过的,适合Eclipse使用的编程字体作为彩蛋. 工具/原料 Eclipse 设置背景色和文字颜色 1 首先,是设置背景色的方式,打开Ecl

java 反射 根据属性 动态设置值

package com.jhl.jvm.lesson8; import java.lang.reflect.Field; /** * * @author jhl * java 反射 根据属性 动态设置值 demo * */ public class ExceptionLog { private String exceptionLogId; private String processingType; private String type; private String content; pub