关于JFreeChart横轴子标题的竖直显示问题 急

wang1ss 2010-01-23 10:46:21
/* -------------------------
* StackedBarChartDemo4.java
* -------------------------
* (C) Copyright 2004, 2005, by Object Refinery Limited.
*
*/

package demo;

import java.awt.Color;
import java.awt.GradientPaint;
import java.awt.Paint;

import javax.swing.JPanel;

import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartPanel;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.LegendItem;
import org.jfree.chart.LegendItemCollection;
import org.jfree.chart.axis.SubCategoryAxis;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.Plot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.GroupedStackedBarRenderer;
import org.jfree.data.KeyToGroupMap;
import org.jfree.data.category.CategoryDataset;
import org.jfree.data.category.DefaultCategoryDataset;
import org.jfree.ui.ApplicationFrame;
import org.jfree.ui.GradientPaintTransformType;
import org.jfree.ui.RefineryUtilities;
import org.jfree.ui.StandardGradientPaintTransformer;

/**
* A simple demonstration application showing how to create a stacked bar chart
* using data from a {@link CategoryDataset}.
*/
public class StackedBarChartDemo4 extends ApplicationFrame {

/**
* Creates a new demo.
*
* @param title the frame title.
*/
public StackedBarChartDemo4(String title) {
super(title);
JPanel chartPanel = createDemoPanel();
chartPanel.setPreferredSize(new java.awt.Dimension(590, 350));
setContentPane(chartPanel);
}

/**
* Creates a sample dataset.
*
* @return A sample dataset.
*/
private static CategoryDataset createDataset() {
DefaultCategoryDataset result = new DefaultCategoryDataset();

result.addValue(20.3, "Product 1 (US)", "Jan 04");
result.addValue(27.2, "Product 1 (US)", "Feb 04");
result.addValue(19.7, "Product 1 (US)", "Mar 04");
result.addValue(19.4, "Product 1 (Europe)", "Jan 04");
result.addValue(10.9, "Product 1 (Europe)", "Feb 04");
result.addValue(18.4, "Product 1 (Europe)", "Mar 04");
result.addValue(16.5, "Product 1 (Asia)", "Jan 04");
result.addValue(15.9, "Product 1 (Asia)", "Feb 04");
result.addValue(16.1, "Product 1 (Asia)", "Mar 04");
result.addValue(13.2, "Product 1 (Middle East)", "Jan 04");
result.addValue(14.4, "Product 1 (Middle East)", "Feb 04");
result.addValue(13.7, "Product 1 (Middle East)", "Mar 04");

result.addValue(23.3, "Product 2 (US)", "Jan 04");
result.addValue(16.2, "Product 2 (US)", "Feb 04");
result.addValue(28.7, "Product 2 (US)", "Mar 04");
result.addValue(12.7, "Product 2 (Europe)", "Jan 04");
result.addValue(17.9, "Product 2 (Europe)", "Feb 04");
result.addValue(12.6, "Product 2 (Europe)", "Mar 04");
result.addValue(15.4, "Product 2 (Asia)", "Jan 04");
result.addValue(21.0, "Product 2 (Asia)", "Feb 04");
result.addValue(11.1, "Product 2 (Asia)", "Mar 04");
result.addValue(23.8, "Product 2 (Middle East)", "Jan 04");
result.addValue(23.4, "Product 2 (Middle East)", "Feb 04");
result.addValue(19.3, "Product 2 (Middle East)", "Mar 04");

result.addValue(11.9, "Product 3 (US)", "Jan 04");
result.addValue(31.0, "Product 3 (US)", "Feb 04");
result.addValue(22.7, "Product 3 (US)", "Mar 04");
result.addValue(15.3, "Product 3 (Europe)", "Jan 04");
result.addValue(14.4, "Product 3 (Europe)", "Feb 04");
result.addValue(25.3, "Product 3 (Europe)", "Mar 04");
result.addValue(23.9, "Product 3 (Asia)", "Jan 04");
result.addValue(19.0, "Product 3 (Asia)", "Feb 04");
result.addValue(10.1, "Product 3 (Asia)", "Mar 04");
result.addValue(13.2, "Product 3 (Middle East)", "Jan 04");
result.addValue(15.5, "Product 3 (Middle East)", "Feb 04");
result.addValue(10.1, "Product 3 (Middle East)", "Mar 04");

return result;
}

/**
* Creates a sample chart.
*
* @param dataset the dataset for the chart.
*
* @return A sample chart.
*/
private static JFreeChart createChart(CategoryDataset dataset) {

JFreeChart chart = ChartFactory.createStackedBarChart(
"Stacked Bar Chart Demo 4", // chart title
"Category", // domain axis label
"Value", // range axis label
dataset, // data
PlotOrientation.VERTICAL, // the plot orientation
true, // legend
true, // tooltips
false // urls
);

GroupedStackedBarRenderer renderer = new GroupedStackedBarRenderer();
KeyToGroupMap map = new KeyToGroupMap("G1");
map.mapKeyToGroup("Product 1 (US)", "G1");
map.mapKeyToGroup("Product 1 (Europe)", "G1");
map.mapKeyToGroup("Product 1 (Asia)", "G1");
map.mapKeyToGroup("Product 1 (Middle East)", "G1");
map.mapKeyToGroup("Product 2 (US)", "G2");
map.mapKeyToGroup("Product 2 (Europe)", "G2");
map.mapKeyToGroup("Product 2 (Asia)", "G2");
map.mapKeyToGroup("Product 2 (Middle East)", "G2");
map.mapKeyToGroup("Product 3 (US)", "G3");
map.mapKeyToGroup("Product 3 (Europe)", "G3");
map.mapKeyToGroup("Product 3 (Asia)", "G3");
map.mapKeyToGroup("Product 3 (Middle East)", "G3");
renderer.setSeriesToGroupMap(map);

renderer.setItemMargin(0.10);
renderer.setDrawBarOutline(false);
Paint p1 = new GradientPaint(0.0f, 0.0f, new Color(0x22, 0x22, 0xFF),
0.0f, 0.0f, new Color(0x88, 0x88, 0xFF));
renderer.setSeriesPaint(0, p1);
renderer.setSeriesPaint(4, p1);
renderer.setSeriesPaint(8, p1);

Paint p2 = new GradientPaint(0.0f, 0.0f, new Color(0x22, 0xFF, 0x22),
0.0f, 0.0f, new Color(0x88, 0xFF, 0x88));
renderer.setSeriesPaint(1, p2);
renderer.setSeriesPaint(5, p2);
renderer.setSeriesPaint(9, p2);

Paint p3 = new GradientPaint(0.0f, 0.0f, new Color(0xFF, 0x22, 0x22),
0.0f, 0.0f, new Color(0xFF, 0x88, 0x88));
renderer.setSeriesPaint(2, p3);
renderer.setSeriesPaint(6, p3);
renderer.setSeriesPaint(10, p3);

Paint p4 = new GradientPaint(0.0f, 0.0f, new Color(0xFF, 0xFF, 0x22),
0.0f, 0.0f, new Color(0xFF, 0xFF, 0x88));
renderer.setSeriesPaint(3, p4);
renderer.setSeriesPaint(7, p4);
renderer.setSeriesPaint(11, p4);
renderer.setGradientPaintTransformer(
new StandardGradientPaintTransformer(
GradientPaintTransformType.HORIZONTAL));

SubCategoryAxis domainAxis = new SubCategoryAxis("Product / Month");
domainAxis.setCategoryMargin(0.05);
domainAxis.addSubCategory("Product 1");
domainAxis.addSubCategory("Product 2");
domainAxis.addSubCategory("Product 3");

CategoryPlot plot = (CategoryPlot) chart.getPlot();
plot.setDomainAxis(domainAxis);
//plot.setDomainAxisLocation(AxisLocation.TOP_OR_RIGHT);
plot.setRenderer(renderer);
plot.setFixedLegendItems(createLegendItems());
return chart;

}

/**
* Creates the legend items for the chart. In this case, we set them
* manually because we only want legend items for a subset of the data
* series.
*
* @return The legend items.
*/
private static LegendItemCollection createLegendItems() {
LegendItemCollection result = new LegendItemCollection();
LegendItem item1 = new LegendItem("US", "-", null, null,
Plot.DEFAULT_LEGEND_ITEM_BOX, new Color(0x22, 0x22, 0xFF));
LegendItem item2 = new LegendItem("Europe", "-", null, null,
Plot.DEFAULT_LEGEND_ITEM_BOX, new Color(0x22, 0xFF, 0x22));
LegendItem item3 = new LegendItem("Asia", "-", null, null,
Plot.DEFAULT_LEGEND_ITEM_BOX, new Color(0xFF, 0x22, 0x22));
LegendItem item4 = new LegendItem("Middle East", "-", null, null,
Plot.DEFAULT_LEGEND_ITEM_BOX, new Color(0xFF, 0xFF, 0x22));
result.add(item1);
result.add(item2);
result.add(item3);
result.add(item4);
return result;
}

/**
* Creates a panel for the demo (used by SuperDemo.java).
*
* @return A panel.
*/
public static JPanel createDemoPanel() {
JFreeChart chart = createChart(createDataset());
return new ChartPanel(chart);
}

/**
* Starting point for the demonstration application.
*
* @param args ignored.
*/
public static void main(String[] args) {
StackedBarChartDemo4 demo = new StackedBarChartDemo4(
"Stacked Bar Chart Demo 4");
demo.pack();
RefineryUtilities.centerFrameOnScreen(demo);
demo.setVisible(true);
}

}


在这里面我要将Product 1、2、3竖直显示 如何处理?
...全文
856 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
huhong19830916 2011-05-24
  • 打赏
  • 举报
回复
针对这个分组柱状图,做成3D效果,同问这个有谁实现了
wang1ss 2010-02-14
  • 打赏
  • 举报
回复
GroupedStackedBarRenderer renderer = new GroupedStackedBarRenderer();
KeyToGroupMap map = new KeyToGroupMap("G1");
map.mapKeyToGroup("Product 1 (US)", "G1");
map.mapKeyToGroup("Product 1 (Europe)", "G1");
map.mapKeyToGroup("Product 1 (Asia)", "G1");
map.mapKeyToGroup("Product 1 (Middle East)", "G1");
map.mapKeyToGroup("Product 2 (US)", "G2");
map.mapKeyToGroup("Product 2 (Europe)", "G2");
map.mapKeyToGroup("Product 2 (Asia)", "G2");
map.mapKeyToGroup("Product 2 (Middle East)", "G2");
map.mapKeyToGroup("Product 3 (US)", "G3");
map.mapKeyToGroup("Product 3 (Europe)", "G3");
map.mapKeyToGroup("Product 3 (Asia)", "G3");
map.mapKeyToGroup("Product 3 (Middle East)", "G3");
renderer.setSeriesToGroupMap(map);

也就是 org.jfree.chart.renderer.category.BarRenderer3D renderer;
renderer = new org.jfree.chart.renderer.category.BarRenderer3D();
不支持renderer.setSeriesToGroupMap(map);
wang1ss 2010-02-14
  • 打赏
  • 举报
回复
楼上的这个3D效果是简单的,现在最主要的是在3D下如何处理如下代码
GroupedStackedBarRenderer renderer = new GroupedStackedBarRenderer();

KeyToGroupMap map = new KeyToGroupMap("G1");
Iterator<String> iter2=rowList.keySet().iterator();
String str = "";
int i = 0;
while(iter2.hasNext())
{
Object key=iter2.next();
if(!str.equalsIgnoreCase((String)key))
{
i++;
}

map.mapKeyToGroup(rowList.get(key)+" (得分)", "G"+i);
map.mapKeyToGroup(rowList.get(key)+" (差额)", "G"+i);

}
renderer.setSeriesToGroupMap(map);
  • 打赏
  • 举报
回复
package lucky.Editor;

import java.awt.Color;

public class ChartEditor extends EditorPartAdapter {
public ChartEditor() {
super();
}

public void createPartControl(Composite parent) {
System.out.println("打开报表.........");

CategoryDataset dataset = createDataset();
JFreeChart chart = createChart(dataset);
// 将报表放入容器ChartComposite中进行显示Display;
ChartComposite frame = new ChartComposite(parent, SWT.NONE, chart, true);
FillLayout fillLayout = new FillLayout();
fillLayout.type = SWT.VERTICAL;
frame.setLayout(fillLayout);
frame.setSize(1366, 768);

frame.setDisplayToolTips(true);
frame.setHorizontalAxisTrace(false);
frame.setVerticalAxisTrace(false);

}

@SuppressWarnings("deprecation")
private JFreeChart createChart(CategoryDataset dataset) {
JFreeChart chart = ChartFactory.createBarChart("报文传输情况统计", "报文传输情况类型",
"数量", dataset, PlotOrientation.VERTICAL, true, true, true);
CategoryPlot plot = chart.getCategoryPlot();// 获得图表区域对象

// 以下是解决报表不能显示中文或者显示乱码问题时的设置;

// 设置图表的纵轴和横轴org.jfree.chart.axis.CategoryAxis,org.jfree.chart.axis.ValueAxis
org.jfree.chart.axis.CategoryAxis domainAxis = plot.getDomainAxis();
// 设置报表标题的中文格式;
chart.getTitle().setFont(new Font("隶体", Font.BOLD, 16));
/*------设置X轴坐标上的文字-----------*/
domainAxis.setTickLabelFont(new Font("黑体", Font.BOLD, 12));
/*------设置X轴的标题文字------------*/
domainAxis.setLabelFont(new Font("黑体", Font.BOLD, 12));
/*------设置Y轴坐标上的文字-----------*/
org.jfree.chart.axis.ValueAxis numberaxis = plot.getRangeAxis();
numberaxis.setTickLabelFont(new Font("黑体", Font.BOLD, 12));
/*------设置Y轴的标题文字------------*/
numberaxis.setLabelFont(new Font("黑体", Font.BOLD, 12));
/*------这句代码解决了底部汉字乱码的问题-----------*/
chart.getLegend().setItemFont(new Font("黑体", Font.BOLD, 12));

domainAxis.setLowerMargin(0.1);// 设置距离图片左端距离此时为10%
domainAxis.setUpperMargin(0.1);// 设置距离图片右端距离此时为百分之10
domainAxis.setCategoryLabelPositionOffset(20);// 图表横轴与标签的距离(10像素)
domainAxis.setCategoryMargin(0.2);// 横轴标签之间的距离20%
domainAxis.setMaximumCategoryLabelLines(1);
domainAxis.setMaximumCategoryLabelWidthRatio(0);

// 设定柱子的属性
org.jfree.chart.axis.ValueAxis rangeAxis = plot.getRangeAxis();
rangeAxis.setUpperMargin(0.1);// 设置最高的一个柱与图片顶端的距离(最高柱的10%)

// 设置图表的颜色
org.jfree.chart.renderer.category.BarRenderer3D renderer;
renderer = new org.jfree.chart.renderer.category.BarRenderer3D();
renderer.setBaseOutlinePaint(Color.red);
renderer.setSeriesPaint(0, new Color(0, 255, 255));// 计划柱子的颜色为青色
renderer.setSeriesOutlinePaint(0, Color.yellow);// 边框为黑色
renderer.setSeriesPaint(1, new Color(0, 255, 0));// 实报柱子的颜色为绿色
renderer.setSeriesOutlinePaint(1, Color.red);// 边框为红色
renderer.setItemMargin(0.2);// 组内柱子间隔为组宽的10%
// 显示每个柱的数值,并修改该数值的字体属性
renderer
.setItemLabelGenerator(new StandardCategoryItemLabelGenerator());
renderer.setItemLabelFont(new Font("黑体", Font.BOLD, 12));// 12号黑体加粗
renderer.setItemLabelPaint(Color.BLUE);// 字体为黑色
renderer.setItemLabelsVisible(true);
plot.setRenderer(renderer);// 使用我们设计的效果

// 设置纵横坐标的显示位置
plot.setDomainAxisLocation(AxisLocation.BOTTOM_OR_LEFT);// 学校显示在下端(柱子竖直)或左侧(柱子水平)
plot.setRangeAxisLocation(AxisLocation.BOTTOM_OR_LEFT); // 人数显示在下端(柱子水平)或左侧(柱子竖直)

return chart;
}

private CategoryDataset createDataset() {
// 接收数据填充报表;
DefaultCategoryDataset dataset = new DefaultCategoryDataset();
dataset.addValue(320, "ok", "ok");
dataset.addValue(520, "no response", "no response");
dataset.addValue(125, "error", "error");
return dataset;
}

}

看看我的这个,你就知道了.
wang1ss 2010-02-08
  • 打赏
  • 举报
回复
另外,针对这个分组柱状图,做成3D效果,我试了很多种办法都不行,有谁实现过的?
zchcs 2010-01-25
  • 打赏
  • 举报
回复
你写这个显示没错,但是你到底要显示什么,没说清楚
zchcs 2010-01-25
  • 打赏
  • 举报
回复
要显示什么样,这个显示jfreechart官方的模型类型吧
stl0 2010-01-25
  • 打赏
  • 举报
回复
网上看下JFreeChart文档,好像没有设置这个的方法,也只有像lz说的那样,横轴调整成90度显示的办法了。

本来想设置dataSet的时候可以用换行符,比如:"产/n品/n一",试了下不可行,遗憾。。.
wang1ss 2010-01-25
  • 打赏
  • 举报
回复
domainAxis.setCategoryLabelPositions(CategoryLabelPositions.UP_90);
这个只能改变 Jan 04 这个的现实,不能改变 产品一 这个现实模式。
wang1ss 2010-01-25
  • 打赏
  • 举报
回复
这是官方模板,目前的产品一 产品二 这三个字是横显
我要让他竖显即如下:





因为这样 柱状图多的时候 文字才显示的清楚

但是 目前SubCategory不知道怎么设置,对Category可以设置成90度显示

81,091

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧