`

JFreechart类柱状图

阅读更多

JFreechart 柱状图完整设置

2009-07-05 23:53:36|  分类: jfreechart |  标签:jfreechart     字号: 订阅

import java.awt.Color;
import java.awt.Font;
import java.text.DecimalFormat;

import org.jfree.chart.ChartFactory;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.CategoryAxis;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.BarRenderer3D;
import org.jfree.chart.title.TextTitle;
import org.jfree.data.category.CategoryDataset;
import org.jfree.data.category.DefaultCategoryDataset;

public class VoteChartAction extends BaseAction {
private static final long serialVersionUID = 2086339818803106472L;
private JFreeChart chart;
private static int supportCount = 0;
private static int blackballCount = 0;
private String voteType;

public JFreeChart getChart()
{
   chart = ChartFactory.createBarChart3D(
     "热点讨论投票结果", // 图表标题
     "", // 目录轴的显示标签
     "", // 数值轴的显示标签
     getDataSet(), // 数据集
     //PlotOrientation.HORIZONTAL , // 图表方向:水平
     PlotOrientation.VERTICAL , // 图表方向:垂直
     false, // 是否显示图例(对于简单的柱状图必须是false)
     true, // 是否生成工具
     true // 是否生成URL链接
     );
   //重新设置图标标题,改变字体
   chart.setTitle(new TextTitle("热点讨论投票结果", new Font("黑体", Font.ITALIC , 18)));
   //取得统计图标的第一个图例
   //LegendTitle legend = chart.getLegend(0);
   //修改图例的字体,必须把显示图例设置为true,否则会报空指针异常
   //legend.setItemFont(new Font("宋体", Font.BOLD, 14));

   //获得柱状图的Plot对象
   CategoryPlot plot = chart.getCategoryPlot();
   plot.setBackgroundPaint(Color.pink); // 设定图表数据显示部分背景色
   //取得横轴
   CategoryAxis categoryAxis = plot.getDomainAxis();
   //设置横轴显示标签的字体
   categoryAxis.setLabelFont(new Font("宋体" , Font.BOLD , 18));
   //分类标签以45度角倾斜
   //categoryAxis.setCategoryLabelPositions(CategoryLabelPositions.UP_45);
   categoryAxis.setTickLabelFont(new Font("宋体" , Font.BOLD , 18));
   //取得纵轴
   NumberAxis numberAxis = (NumberAxis)plot.getRangeAxis();
   //设置纵轴显示标签的字体
   numberAxis.setLabelFont(new Font("宋体" , Font.BOLD , 18));
   //设置最高的一个柱与图片顶端的距离
   numberAxis.setUpperMargin(0.1);
   //numberAxis.setFixedAutoRange(100);
   //设置整数显示
   //numberAxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());
   //numberAxis.setNegativeArrowVisible(true);
  
   //取最大数Math.max(supportCount, blackballCount)
   numberAxis.setUpperBound(1);
   numberAxis.setLowerBound(0.01);
   //设置百分比显示
   numberAxis.setNumberFormatOverride(new DecimalFormat("0%"));
   //numberAxis.setNumberFormatOverride(new DecimalFormat("0.00%"));
   //设置最小显示数,小于的话会显示在中间(正负)
   //numberAxis.setAutoRangeMinimumSize(1);
  
   plot.setNoDataMessage("没有可供使用的数据!");
   plot.setNoDataMessagePaint(Color.blue);
  
  
   BarRenderer3D renderer = new BarRenderer3D();
   //设置柱子宽度
   renderer.setMaximumBarWidth(0.1);
   //设置柱子高度
   renderer.setMinimumBarLength(0.2);
   //设置柱子的颜色
        renderer.setSeriesPaint(0, new Color(0, 0, 255));
       
        //设置柱子边框可见
        //renderer.setDrawBarOutline(true);
        //设置柱子默认的边框颜色,必须设置边框可见才起效
   //renderer.setBaseOutlinePaint(Color.gray);
        //设置分类柱子的边框色,覆盖默认的边框颜色,必须设置边框可见才起效
        //renderer.setSeriesOutlinePaint(0,Color.red);
        //设置柱子的纵横背景色
        //renderer.setWallPaint(Color.gray);
        //设置平行柱的之间距离
        renderer.setItemMargin(0.5);
        //显示每个柱的数值,并修改该数值的字体属性
        renderer.setIncludeBaseInRange(true);
        //将修改后的属性值保存到图中,这一步很重要,否则上面对颜色的设置都无效
        plot.setRenderer(renderer);
        
        //设置柱子的透明度,0.8相当于80%的透明度
        plot.setForegroundAlpha(0.8f);

   return chart;
}

//返回一个CategoryDataset实例
private static CategoryDataset getDataSet()
{
   DefaultCategoryDataset dataset = new DefaultCategoryDataset();
   int total = supportCount+blackballCount;
   if(total < 1) total = 1;
   dataset.addValue((double)supportCount/total, "" , "正方(" + supportCount + ")");
   dataset.addValue((double)blackballCount/total, "" , "反方(" + blackballCount + ")");
   //dataset.addValue(supportCount, "佛山" , "正方");
   //dataset.addValue(blackballCount, "佛山" , "反方");
   //dataset.addValue(supportCount , "广州" , "正方");
   //dataset.addValue(blackballCount , "广州" , "反方");
   return dataset;
}

public String showVoteChart()
{
   if("support".equals(voteType))
   {
    supportCount++;
   }
   else if("blackball".equals(voteType))
   {
    blackballCount++;
   }
   //supportCount = 0;//快速清零,不用重启系统
   //blackballCount = 0;//快速清零,不用重启系统
   this.chart = getChart();
   return SUCCESS;
}

/**
* @return the supportCount
*/
public static int getSupportCount()
{
   return supportCount;
}

/**
* @return the blackballCount
*/
public static int getBlackballCount()
{
   return blackballCount;
}

/**
* @return the voteType
*/
public String getVoteType()
{
   return voteType;
}

/**
* @param supportCount the supportCount to set
*/
public static void setSupportCount(int supportCount)
{
   VoteChartAction.supportCount = supportCount;
}

/**
* @param blackballCount the blackballCount to set
*/
public static void setBlackballCount(int blackballCount)
{
   VoteChartAction.blackballCount = blackballCount;
}

/**
* @param voteType the voteType to set
*/
public void setVoteType(String voteType)
{
   this.voteType = voteType;
}

}

=============================================

struts 配置

==========================

<package name="chart" extends="jfreechart-default">
   <action name="show_vote_chart" class="com.guosen.weblogger.web.action.VoteChartAction" method="showVoteChart">
    <result name="success" type="chart">
     <param name="width">420</param>
     <param name="height">250</param>
    </result>
   </action>
</package>

========================

页面代码

========================

<div style="width:420px;height:250px;padding-left:100px;">
    <iframe id="votechart" name="votechart" src="${base}/chart/show_vote_chart.action" frameborder="0" marginheight="0" marginwidth="0" scrolling="no" style="height:100%;width:100%"></iframe>
   </div>
   <div style="width:420px;height:25px;padding-left:100px;text-align:center;font-size:16px;">
    <a href="#this" onclick="changeChart('support')">支持</a>&nbsp;&nbsp;
    <a href="#this" onclick="changeChart('blackball')">反对</a>
   </div>
   <script type="text/javascript">
    function changeChart(type)
    {
     if(type == "support")
     {
      coos.$id("votechart").src = "${base}/chart/show_vote_chart.action?voteType=support";
     }
     else if(type == "blackball")
     {
      coos.$id("votechart").src = "${base}/chart/show_vote_chart.action?voteType=blackball";
     }
   
    }
   </script>
   <hr />

引自:http://dreampeter.blog.163.com/blog/static/7980324200965115336881/

分享到:
评论

相关推荐

    jfreechart 堆栈柱状图跟折线图结合拼接

    jfreechart 堆栈柱状图跟折线图结合拼接 jar包请戳http://download.csdn.net/detail/a156435646/7424707

    JFreeChart动态加载柱状图

    JFreeChart创建柱状图,之前网上很多都是创建柱状图的,静态的。数据更新之后柱状图随之改变,代码实现详见附件代码。所需要的jar包是jfreechart-1.0.13.jar,gnujaxp.jar,jcommon-1.0.16.jar

    JFreeChart画图 饼状图 单组柱状图 多组柱状图 堆积柱状图 折线图

    JFreeChart 饼状图 柱状图 柱状图 堆积柱状图 折线图 这个是我特地开发的一个用JFreeChart开发的用来画图的项目,已经开发成形了各种项目的各种需求的项目,并且自己可以拓展,根据需求修改代码,完成项目的需要。 ...

    jfreechart 绘制横向立体柱状图

    利用jfreechart绘制的横向立体柱状图,横坐标是数值,纵坐标是数据分类,需要提前引入jfreechart包文件到工程里,才不会报错

    jfreechart实现柱状图排序

    根据提供的信息,我们可以总结出以下关于使用 JFreeChart 实现柱状图排序的相关知识点: ### 一、背景介绍 在日常的数据分析与展示工作中,柱状图是非常常见的一种图表类型,它能直观地显示不同类别之间的数值差异...

    jfreechart 生成折线图,饼图,柱状图,堆栈柱状图

    JFreeChart是一个流行的Java库,用于生成各种类型的图表,包括折线图、饼图和柱状图,甚至堆栈柱状图。这个压缩包中的"CreateChartServiceImpl.java"文件很可能包含了一个实现这些功能的服务类。 首先,我们要理解...

    利用JFreeChart 实现柱状图,饼图,时序图,折线图等

    在Java编程环境中,JFreeChart库是一个非常强大的工具,它允许开发者轻松地创建各种图表,如柱状图、饼图、时序图和折线图等。这些图表在数据分析、报表展示以及各种可视化应用中非常常见。下面我们将详细介绍如何...

    java里用JFreeChart画柱状图、折线图、雷达图

    在Java编程环境中,JFreeChart库是一个强大的工具,用于创建各种复杂的图表,包括柱状图、折线图和雷达图。这些图表对于数据可视化和数据分析非常有用,可以帮助开发者直观地展示大量信息。以下是对给定文件中每个...

    JfreeChart柱状图饼图

    **JFreeChart——柱状图与饼图详解** 在Java编程中,JFreeChart库是一个强大的图表绘制工具,它能够帮助开发者创建出多种类型的图表,包括柱状图、饼图等,广泛应用于数据分析和可视化展示。这篇博文中,我们将深入...

    JFreeChart设置柱状图的宽度

    JFreeChart设置柱状图的宽度,当一个元素时不让显示那么宽。

    java+jfreechart+struts 生成柱状图

    java+jfreechart+struts 生成柱状图 java jfreechart 柱状图 java jfreechart 柱状图 谁需要完整项目可以去http://download.csdn.net/source/2665347

    jfreechart的使用-柱状图

    **标题:“jfreechart的使用-柱状图”** **描述**:这篇博客文章主要探讨了如何使用jFreeChart库创建柱状图。jFreeChart是Java编程语言中一个广泛使用的开源图表库,它提供了丰富的图表类型,包括柱状图、饼图、...

    jfreechart柱状图

    **JFreeChart 柱状图** JFreeChart 是一个流行的开源 Java 图形库,它提供了丰富的图表类型,包括柱状图、饼图、线图、散点图等,广泛应用于数据分析、报告生成以及可视化应用中。这个压缩包提供的源代码示例,展示...

    JFreeChart生成3D饼状图及柱状图

    JFreeChart是一款强大的Java图表库,它允许开发者创建多种类型的2D和3D图表,包括折线图、柱状图、饼状图、散点图等,并且支持自定义样式和颜色,使得数据可视化变得更加直观和生动。在这个特定的场景中,我们将关注...

    自定义JFreeChart柱状图的详细说明

    综上所述,自定义JFreeChart柱状图涉及了数据准备、渲染器配置、外观调整、标签和提示信息等多个方面。通过深入理解这些知识点,开发者可以创建出满足各种需求的个性化柱状图。提供的文件如"JFreeChart中柱状图的...

    JFreeChart 折线、柱状组合图

    public JFreeChart createChart(String Ytitle, String title, CategoryDataset lineData, CategoryDataset barData) { //参考附件 return chart; } //struts 部分 &lt;!--begin 维优特例 --&gt; ...

    java制作jfreechart柱状图 饼状图 折线图

    Java中的JFreeChart库是一个强大的工具,用于生成各种类型的图表,包括柱状图、饼状图和折线图。在本教程中,我们将深入探讨如何使用JFreeChart创建这些图表,以及如何用随机生成的数据作为数据源。 首先,...

    JFreeChart编写柱状图和饼状图及3D饼状图方法

    JFreeChart是一款强大的Java库,用于创建各种图表,包括柱状图、饼状图和3D饼状图等。在Java编程中,JFreeChart是一个非常实用的工具,它允许开发者轻松地在应用程序中集成数据可视化功能。下面将详细介绍如何使用...

Global site tag (gtag.js) - Google Analytics