- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试生成一个堆叠条形图,每个类别都有一个上限。每个类别的上限都不同,并用水平线表示。
我能够生成堆积条形图,但被指示上限的水平线击中。
这是示例图表。
这是我生成堆积条形图的代码
import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.GradientPaint;
import java.awt.Paint;
import java.awt.Stroke;
import java.io.IOException;
import java.io.OutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartUtilities;
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.CategoryMarker;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.plot.ValueMarker;
import org.jfree.chart.plot.XYPlot;
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.GradientPaintTransformType;
import org.jfree.ui.Layer;
import org.jfree.ui.StandardGradientPaintTransformer;
public class StackedBarServlet extends HttpServlet{
private static final long serialVersionUID = 1L;
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException {
response.setContentType("image/png");
OutputStream outputStream = response.getOutputStream();
final CategoryDataset dataset = createDataset();
final JFreeChart chart = createChart(dataset);
int width = 800;
int height = 350;
ChartUtilities.writeChartAsPNG(outputStream, chart, width, height);
}
private 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(20.3, "Product 1 (US)", "Apr 04");
result.addValue(27.2, "Product 1 (US)", "May 04");
result.addValue(19.7, "Product 1 (US)", "Jun 04");
result.addValue(20.3, "Product 1 (US)", "Jul 04");
result.addValue(27.2, "Product 1 (US)", "Aug 04");
result.addValue(19.7, "Product 1 (US)", "Sep 04");
result.addValue(20.3, "Product 1 (US)", "Oct 04");
result.addValue(27.2, "Product 1 (US)", "Nov 04");
result.addValue(19.7, "Product 1 (US)", "Dec 04");
result.addValue(20.3, "Product 1 (US)", "Bab 04");
result.addValue(27.2, "Product 1 (US)", "Lal 04");
result.addValue(19.7, "Product 1 (US)", "Sha 04");
result.addValue(20.3, "Product 1 (UK)", "Jan 04");
result.addValue(27.2, "Product 1 (UK)", "Feb 04");
result.addValue(19.7, "Product 1 (UK)", "Mar 04");
result.addValue(20.3, "Product 1 (UK)", "Apr 04");
result.addValue(27.2, "Product 1 (UK)", "May 04");
result.addValue(19.7, "Product 1 (UK)", "Jun 04");
result.addValue(20.3, "Product 1 (UK)", "Jul 04");
result.addValue(27.2, "Product 1 (UK)", "Aug 04");
result.addValue(19.7, "Product 1 (UK)", "Sep 04");
result.addValue(20.3, "Product 1 (UK)", "Oct 04");
result.addValue(27.2, "Product 1 (UK)", "Nov 04");
result.addValue(19.7, "Product 1 (UK)", "Dec 04");
result.addValue(20.3, "Product 1 (UK)", "Bab 04");
result.addValue(27.2, "Product 1 (UK)", "Lal 04");
result.addValue(19.7, "Product 1 (UK)", "Sha 04");
result.addValue(20.3, "Product 1 (IND)", "Jan 04");
result.addValue(27.2, "Product 1 (IND)", "Feb 04");
result.addValue(19.7, "Product 1 (IND)", "Mar 04");
result.addValue(20.3, "Product 1 (IND)", "Apr 04");
result.addValue(27.2, "Product 1 (IND)", "May 04");
result.addValue(19.7, "Product 1 (IND)", "Jun 04");
result.addValue(20.3, "Product 1 (IND)", "Jul 04");
result.addValue(27.2, "Product 1 (IND)", "Aug 04");
result.addValue(19.7, "Product 1 (IND)", "Sep 04");
result.addValue(20.3, "Product 1 (IND)", "Oct 04");
result.addValue(27.2, "Product 1 (IND)", "Nov 04");
result.addValue(19.7, "Product 1 (IND)", "Dec 04");
result.addValue(20.3, "Product 1 (IND)", "Bab 04");
result.addValue(27.2, "Product 1 (IND)", "Lal 04");
result.addValue(19.7, "Product 1 (IND)", "Sha 04");
result.addValue(20.3, "Product 1 (EUROPE)", "Jan 04");
result.addValue(27.2, "Product 1 (EUROPE)", "Feb 04");
result.addValue(19.7, "Product 1 (EUROPE)", "Mar 04");
result.addValue(20.3, "Product 1 (EUROPE)", "Apr 04");
result.addValue(27.2, "Product 1 (EUROPE)", "May 04");
result.addValue(19.7, "Product 1 (EUROPE)", "Jun 04");
result.addValue(20.3, "Product 1 (EUROPE)", "Jul 04");
result.addValue(27.2, "Product 1 (EUROPE)", "Aug 04");
result.addValue(19.7, "Product 1 (EUROPE)", "Sep 04");
result.addValue(20.3, "Product 1 (EUROPE)", "Oct 04");
result.addValue(27.2, "Product 1 (EUROPE)", "Nov 04");
result.addValue(19.7, "Product 1 (EUROPE)", "Dec 04");
result.addValue(20.3, "Product 1 (EUROPE)", "Bab 04");
result.addValue(27.2, "Product 1 (EUROPE)", "Lal 04");
result.addValue(19.7, "Product 1 (EUROPE)", "Sha 04");
return result;
}
private JFreeChart createChart(final CategoryDataset dataset) {
final JFreeChart chart = ChartFactory.createStackedBarChart(
"Stacked Bar", // 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");
renderer.setSeriesToGroupMap(map);
renderer.setItemMargin(0.0);
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");
domainAxis.setCategoryMargin(0.15);
CategoryPlot plot = (CategoryPlot) chart.getPlot();
plot.setDomainAxis(domainAxis);
plot.setRenderer(renderer);
plot.setFixedLegendItems(createLegendItems());
/*
* This is used to draw a vertical line
*/
/* Stroke stroke = new BasicStroke(2.0f);
ValueMarker marker = new ValueMarker(100); // position is the value on the axis
marker.setPaint(Color.black);
marker.setStroke(stroke);
CategoryPlot plot1 = chart.getCategoryPlot();
plot1.addRangeMarker(marker,Layer.FOREGROUND); */
return chart;
}
private LegendItemCollection createLegendItems() {
LegendItemCollection result = new LegendItemCollection();
LegendItem item1 = new LegendItem("US", new Color(0x22, 0x22, 0xFF));
LegendItem item2 = new LegendItem("Europe", new Color(0x22, 0xFF, 0x22));
LegendItem item3 = new LegendItem("Asia", new Color(0xFF, 0x22, 0x22));
LegendItem item4 = new LegendItem("Middle East", new Color(0xFF, 0xFF, 0x22));
result.add(item1);
result.add(item2);
result.add(item3);
result.add(item4);
return result;
}
}
当我使用 addRangeMarker 时,它给了我一条连续的水平线。但就我而言,我需要为每个类别分别设置多条水平线。
这是带有 addRangeMarker 的示例图像。
提前致谢。
最佳答案
您需要创建第二个数据集,其中包含要使用水平黑线显示的值。将该数据集与 LevelRenderer
一起添加到您的图中。 。
关于java - 使用 jfreechart 具有上限线的堆积条形图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24382457/
我需要从图例中隐藏第二/第三/第四项。有没有办法在jFreeChart中实现这一目标? 谢谢! 最佳答案 我已经尝试了上述建议,但似乎对我没有用。如果您只想从图例中删除系列,则可以使用setSerie
我对 JFreeChart 中的异常值规则有一些疑问: 是否可以影响 JFreeChart 箱线图中的异常值规则? 我假设异常值的默认设置是 Q3+1.5*IQR 和 Q1-1.5*IQR? 对于 Q
使用的 JFreeChart 版本:1.5.0 我尝试了以下方法来获得散点图中的空心形状: PlotFrame.java文件内容: package javaapplication1; import j
如何自定义 JFreeChart 图形的颜色。 让我们看看我的 Java 代码: private StreamedContent chartImage ; public void init(){
在 JFreeChart , 是否可以将图例嵌入图表本身? 图例可以设置在图表的顶部、底部、左侧、右侧,如下所示,但是否可以将其嵌入图表中? LegendTitle legend=chart.getL
大家好,我是 jfreechart 的新手。 我想删除为 jfreechart 中的折线图图表面板的标题分配的空间。 因为我需要将图表面板的高度和宽度设置为包含图表面板的顶部面板的 10 像素边框。
在 JFreeChart 图形中,如果调整应用程序窗口的大小,图形将根据应用程序窗口大小重新绘制。是否可以将图表大小设置为固定值? 最佳答案 好。 我想建议一种不同的方法。不用担心在 jfreecha
我在 JFreeChart 中创建了一个饼图。但是,数值没有出现在“切片”上。我如何让它出现在那里? 最佳答案 在 PiePlot 上,可以使用 setter setSimpleLabels。 假设您
我正在使用 JFreeChart 生成 StackedBarChart。根据输入数据,我可以有很多类别(通常在 20 到 40 之间),导致标签重叠。在下面的屏幕截图中,您可以看到类别从 1 到 38
我正在尝试实现 a timeseries chart在 JFreeChart 中有一个特殊的要求。我可以绘制图表,但我不知道如何在图表中的最后一个值处实现垂直红线。它应该始终在同一个位置,并且应该始终
如何在 jfreechart 中加粗 x 和 y 轴值? 最佳答案 你试过其中之一吗: yourAxis.setTickLabelFont(new Font("Arial", Font.BOLD, 1
据我所知,DateTickUnitType 是一个无法在完全替换之外扩展或更改的枚举,它只指定天、月、年、分钟、小时、秒和毫秒的单位,但不是周,尽管有一个TimePeriod 的周类型。 这导致的问题
我需要使用 JFreeChart 生成图表然后使用 Apache PDFBOX 将它们导出为 PDF .我不想使用 iText,因为它不能用于专有软件。 我搜索了整个 Google,但没有成功!有人做
我刚刚发现,当我将 ChartPanel 添加到 JFrame 时,当 JFrame 拖动更大或更小时,ChartPanel 将调整大小以适应框架。但是,当我将 ChartPanel 添加到 JPan
我是 Java 新手,正在尝试掌握 JFreeChart。我正在尝试从该网站运行一些演示代码:https://www.tutorialspoint.com/jfreechart/jfreechart_
我正在尝试使用 DefaultCategoryDataset 绘制 LineChart 并且我面临的问题是, 当我尝试在两个值之间绘制一个空值时,两个点之间的连接丢失(即没有出现连接两个点的线),或者
是否可以将图像/BufferedImage 转换为 JFreeChart? 最佳答案 将图像转换到 JFree 是不可能的。要从 JFreechart 创建图像,您可以执行以下操作: Buffered
有人知道如何在Jfreechart中在给定坐标处绘制垂直虚线吗? 谢谢 最佳答案 Example 5显示图表的一系列虚线。这样设置您的行程: plot.getRenderer().setSeriesS
如我在图片中所示,我想将列标签(值 434、2562,....)稍微向上移动。有什么方法可以配置吗?我最初的问题是,由于列之间的差异,最后两列上的标签不再可见(它们实际上是 15 和 24 或类似的
如本模型所示: 我知道可以使用 org.jfree.chart.plot.CombinedDomainXYPlot 使图表彼此相邻显示,但是是否可以将它们重叠,可能使用不同的 Y 轴(一个)用于图表左
我是一名优秀的程序员,十分优秀!