- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我一直在尝试模仿 flot.js
下图显示在 JFreeCharts 中。
到目前为止,我已经在大多数元素上取得了成功,例如具有透明度的单个条形颜色、x 和 y 网格线以及背景。
我现在需要实现的是:
对于单独的条形边框颜色,我找到了建议使用代码的线程“Adding border color/stroke to individual Bars in Bar Chart?”
Color borderColor = buildColorMap.get(build);
renderer.setDrawBarOutline(true);
renderer.setSeriesOutlinePaint(iterator, borderColor);
与我目前使用的适用于所有酒吧的那个不同
// other colors
renderer.setSeriesOutlinePaint(3, new Color(213, 94, 0));
renderer.setSeriesOutlinePaint(4, new Color(204, 121, 167));
renderer.setSeriesOutlineStroke(0, new BasicStroke(2.5f));
对于图表的大轮廓,我看到了 setOutlineStroke
但是 API 说
Deprecated. This method should no longer be used (as of version 1.0.6). It is sufficient to rely on
setSeriesOutlineStroke(int, Stroke)
andsetBaseOutlineStroke(Stroke)
. Sets the outline stroke for ALL series and sends aRendererChangeEvent
to all registered listeners.
因此我去了setBaseOutlineStroke
什么也没发生(仍然和上面的照片一样)!
renderer.setBaseOutlineStroke(new BasicStroke(2.5f), true);
flot.js
-类似 y 轴的处理和定位对于 flot.js
中的 y 轴编号,我能够使用函数(其中数据放在 double
数组中;只有五个实例,所以我不需要更复杂的数据结构):
private static double getHighestArrayValue(double[] array) {
double max = 0;
for (int i = 1; i < array.length; i++) {
if (array[i] > max) {
max = array[i];
}
}
return max;
}
private static double getRoundedUpMultipleOfTen(double number) {
return ((number + 9) / 10) * 10;
}
其中生成图表的用法是:
CategoryPlot plot = ...
final NumberAxis rangeAxis = (NumberAxis) plot.getRangeAxis();
rangeAxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());
rangeAxis.setRange(0,
getRoundedUpMultipleOfTen(getHighestArrayValue(dataValues)));
rangeAxis.setTickUnit(new NumberTickUnit(10));
导致
现在的问题是如何将 50
推到图表的顶部,我不知道该怎么做。
这是我为任何感兴趣的人提供的完整代码(“Generate Pie Chart/Bar Graph In PDF Using IText & JFreeChart”中 Viral Patel 的修改代码:
import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Graphics2D;
import java.awt.Paint;
import java.awt.geom.Rectangle2D;
import java.io.FileOutputStream;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.StandardChartTheme;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.axis.NumberTickUnit;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.BarRenderer;
import org.jfree.chart.renderer.category.CategoryItemRenderer;
import org.jfree.chart.renderer.category.StandardBarPainter;
import org.jfree.data.category.DefaultCategoryDataset;
import com.itextpdf.text.Document;
import com.itextpdf.text.Font;
import com.itextpdf.text.PageSize;
import com.itextpdf.text.pdf.PdfContentByte;
import com.itextpdf.text.pdf.PdfTemplate;
import com.itextpdf.text.pdf.PdfWriter;
public class ChartDemo {
public static void main(String[] args) {
writeChartToPDF(generateBarChart(), 800, 500, "D://barchart.pdf");
}
public static void writeChartToPDF(JFreeChart chart, int width, int height,
String fileName) {
PdfWriter writer = null;
Document document = new Document(PageSize.A4.rotate(), 0, 0, 0, 0);
try {
writer = PdfWriter.getInstance(document, new FileOutputStream(
fileName));
document.open();
PdfContentByte contentByte = writer.getDirectContent();
PdfTemplate template = contentByte.createTemplate(width, height);
Graphics2D graphics2d = template.createGraphics(width, height);
// controls size of image
Rectangle2D rectangle2d = new Rectangle2D.Double(10, -10, width,
height);
chart.draw(graphics2d, rectangle2d);
graphics2d.dispose();
contentByte.addTemplate(template, 0, 0);
} catch (Exception e) {
e.printStackTrace();
}
document.close();
}
static class CustomRenderer extends BarRenderer {
private Paint[] colors;
int transparency = 95;
// http://www.cookbook-r.com/Graphs/Colors_(ggplot2)/
public CustomRenderer() {
this.colors = new Paint[] { new Color(1, 158, 115, transparency),
new Color(240, 228, 66, transparency),
new Color(0, 114, 178, transparency),
new Color(213, 94, 0, transparency),
new Color(204, 121, 167, transparency) };
}
public Paint getItemPaint(final int row, final int column) {
return this.colors[column % this.colors.length];
}
}
public static JFreeChart generateBarChart() {
double[] dataValues = { 40.66, 37.82, 43.16, 32.62, 41.39 };
Paint[] colors = { new Color(1, 158, 115), new Color(240, 228, 66),
new Color(0, 114, 178), new Color(213, 94, 0),
new Color(204, 121, 167) };
DefaultCategoryDataset dataSet = new DefaultCategoryDataset();
for (int i = 0; i < dataValues.length; i++) {
dataSet.setValue(dataValues[i], "Population", (i + 1) * 2 + "");
}
ChartFactory.setChartTheme(StandardChartTheme.createLegacyTheme());
JFreeChart chart = ChartFactory.createBarChart("", "Team number",
"Solved problems (%)", dataSet, PlotOrientation.VERTICAL,
false, true, false);
chart.setBackgroundPaint(Color.WHITE);
final CategoryPlot plot = chart.getCategoryPlot();
((BarRenderer) plot.getRenderer())
.setBarPainter(new StandardBarPainter());
plot.setBackgroundPaint(Color.WHITE);
plot.setDomainGridlinesVisible(true);
plot.setRangeGridlinesVisible(true);
plot.setDomainGridlineStroke(new BasicStroke(0.25f));
plot.setRangeGridlineStroke(new BasicStroke(0.25f));
plot.setDomainGridlinePaint(new Color(204, 204, 204));
plot.setRangeGridlinePaint(new Color(204, 204, 204));
java.awt.Font fontGraphLabel = new java.awt.Font("Helvetica",
Font.NORMAL, 12);
java.awt.Font fontGraphTicks = new java.awt.Font("Helvetica",
Font.NORMAL, 10);
plot.getDomainAxis().setLabelFont(fontGraphLabel);
plot.getRangeAxis().setLabelFont(fontGraphLabel);
plot.getDomainAxis().setTickLabelFont(fontGraphTicks);
plot.getRangeAxis().setTickLabelFont(fontGraphTicks);
CategoryItemRenderer renderer = new CustomRenderer();
plot.setRenderer(renderer);
final NumberAxis rangeAxis = (NumberAxis) plot.getRangeAxis();
rangeAxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());
rangeAxis.setRange(0,
getRoundedUpMultipleOfTen(getHighestArrayValue(dataValues)));
rangeAxis.setTickUnit(new NumberTickUnit(10));
final BarRenderer renderer1 = (BarRenderer) plot.getRenderer();
renderer1.setDrawBarOutline(true);
renderer1.setShadowVisible(false);
renderer1.setSeriesOutlinePaint(0, new Color(204, 121, 167));
renderer1.setSeriesOutlinePaint(1, new Color(213, 94, 0));
renderer1.setSeriesOutlineStroke(0, new BasicStroke(2.5f));
renderer1.setBaseOutlineStroke(new BasicStroke(10f), true);
return chart;
}
private static double getHighestArrayValue(double[] array) {
double max = 0;
for (int i = 1; i < array.length; i++) {
if (array[i] > max) {
max = array[i];
}
}
return max;
}
private static double getRoundedUpMultipleOfTen(double number) {
return ((number + 9) / 10) * 10;
}
}
最佳答案
我不是 Java 专家,但我会尝试一下我的做法(所有代码都未经测试)...
假设您有如下所示的 flot 代码:
<div id="placeholder" style="width:300px;height:200px"></div>
$(function() {
var series = {data: [[0, 5.2], [1, 3], [2, 9.2], [3, 10]],
lines: {show: false},
bars: {show: true, barWidth: 0.75, align:'center'}}
somePlot = $.plot("#placeholder", [ series ], {});
});
您需要将此代码作为字符串,然后对其进行 Base64 编码(在变量 base64FlotCode 中)。
创建一个如下所示的 phantomJS 脚本(另存为 phantomJSScript.js):
var system = require('system');
var html = system.args[1];
var page = require('webpage').create();
page.onLoadFinished = function(status) {
var clipRect = page.evaluate(
function()
{
var el = document.querySelector('#placeholder');
return el.getBoundingClientRect();
}
);
page.clipRect = {
top: clipRect.top,
left: clipRect.left,
width: clipRect.width,
height: clipRect.height
};
page.render('/path/to/myPlot.png');
phantom.exit();
};
function b64_to_utf8(str) {
return decodeURIComponent(escape(window.atob(str)));
}
page.content = b64_to_utf8(html);
现在您可以将此脚本称为:
List<String> args = new ArrayList<String>();
args.add ("/path/to/phamtomjs.exe");
args.add ("/path/to/phantomJSScript.js");
args.add (base64FlotCode);
ProcessBuilder pb = new ProcessBuilder (args);
Process p = pb.start();
p.waitFor();
编辑
除了向 phantomJS 传递您的 flot 代码字符串,您还可以将其指向您的网页:
var system = require('system');
var page = require('webpage').create();
page.open('http://www.mywebpage.com', function() {
var clipRect = page.evaluate(
function()
{
var el = document.querySelector('#placeholder');
return el.getBoundingClientRect();
}
);
page.clipRect = {
top: clipRect.top,
left: clipRect.left,
width: clipRect.width,
height: clipRect.height
};
page.render('/path/to/myPlot.png');
phantom.exit();
};
关于java - 使 JFreeChart CategoryPlot 看起来像 Flot.js 条形图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21936750/
我想在我的 android 应用程序中实现一个反馈/评级图表。(就像当你打开 google play 并检查应用程序的反馈时,有一个来自投票它的用户的彩色图表)任何人都可以帮助我如何开始那个?感谢您提
我正在尝试使用 LaTeX 制作条形图。到目前为止我一直不成功,所以任何人都可以帮助我,也许是最近项目的副本?如何使用 pstricks 制作条形图?我会很感激最简单的解决方案,因为我最近才开始使用
我有一个包含 6 个事件及其发生时间跨度的 csv 表。我的变量是开始日期、结束日期和事件 ID。我打算创建一个水平直方图/条形图可视化来显示时间范围,即某些类型的事件持续了多长时间。 X 轴应该有多
我想制作可以指定条形最小值的条形图(很像盒须图中的盒子)。条形图可以做到吗?我怀疑答案在 ggplot 中,但我找不到示例。 这是一些数据: X Jan F
我想使用以下数据来创建可视化: > dput(data) structure(c(1264L, 2190L, 2601L, 1441L, 1129L, 2552L, 1820L, 306L,
我有一个包含正值和负值的数据框。我想显示一个显示两个条形的条形图,一个条形显示正值的百分比,另一个条形图显示负值的百分比。 dummy = pd.DataFrame({'A' : [-4, -3, -
我正在尝试在栏中插入自定义文本,我搜索了很多线程,但仍然没有得到任何解决方案。然后我想减小 y 轴的步长。我已附上我的代码。 jQuery( document ).ready(function() {
我正在使用 pandas 来创建条形图。这是一个例子: df=pd.DataFrame(np.random.rand(10, 4), columns=['a', 'b', 'c', 'd']) df.
我想在python中制作一个分类图来表示几个变量的范围。我想也许我会使用条形图并为条形设置范围。这是我的条形图 import matplotlib.pyplot as plt import numpy
我有一个显示 3 个条形的堆叠百分比条形图。 JSFiddle:https://jsfiddle.net/Lr0bszj6/ 由于某种原因,条形之间有很多空间并且没有与标签对齐(只有中间一个)。 设置
我正在尝试使用 aChartEngine 将 GPS 数据(正在查看或正在使用的卫星)显示为条形图,但我没有在此 View 中显示任何数据。这是我的代码,所以你能告诉我我犯了什么错误吗? public
我正在使用 this chart implementation . 但是,它分散了我的数据,而不是相互堆叠。 我想在 1970 年堆叠我的第一个数组,在 1975 年堆叠第二个数组。换句话说,我希望有
我正在尝试用不同颜色为条形图中的各个条形着色,比如蓝色表示正,红色表示负。我在互联网上找不到任何有用的东西。我在下面的代码中发现每个条形图都根据第一个条形图的值着色,而不是为每个条形图单独设置颜色:
我刚刚转移到 pandas 0.20/matplotlib 2.0 python 3.6。 (共构成以下版本)。我用 pandas 来绘制条形图,因为 matplotlib 的级别总是太低。着色列的行
我正在尝试制作一个图,其中 x 轴是时间,y 轴是一个条形图,其中的条形图覆盖特定时间段,如下所示: ______________
我有一些非常基本的代码,它可以正常工作,除了所有内容都与顶部对齐...理想情况下,条形图应与底部对齐。我想我可以使用固定定位,因为尺寸是 50px x 50px 的平方,但我更喜欢“固定”少一点的东西
这是我用来 Dim ejex As String, ejey As String Dim graficos As String Worksheets("Sheet1").Activate ejex =
我有一个生成如下条形图的 gnuplot 脚本: 输入数据位于具有多列的文件中,每一列最终都构成图表中的一个集群(示例中显示了 2 个集群)。每个文件都构成图表中的一个条形(示例中有 9 个)。每个文
我正在为我的数据 movies 使用库 ggplot2movies 请记住,我指的是 mpaa 评级和用户评级,这是两个不同的事物。如果您不想加载 ggplot2movies 库,这里是相关数据的示例
有没有一种简单的方法可以使用Pandas DataFrame.plot(kind='bar')方法按列名指定条形颜色? 我有一个脚本,可以从目录中的几个不同数据文件生成多个DataFrame。例如,它
我是一名优秀的程序员,十分优秀!