画雷达图

  1. /**
  2. * @作者:Jcuckoo
  3. * @日期:2008-12-9
  4. * @版本:V 1.0
  5. */
  6. public class MySpriderWebPlotTest {
  7. public static void main(String args[]) {
  8. JFrame jf = new JFrame();
  9. jf.add(erstelleSpinnenDiagramm());
  10. jf.pack();
  11. jf.setVisible(true);
  12. }
  13. public static JPanel erstelleSpinnenDiagramm() {
  14. DefaultCategoryDataset dataset = new DefaultCategoryDataset();
  15. String group1 = "apple ";
  16. dataset.addValue(5, group1, "w1");
  17. dataset.addValue(6, group1, "w2");
  18. dataset.addValue(4, group1, "w3");
  19. dataset.addValue(2, group1, "w4");
  20. dataset.addValue(5, group1, "w5");
  21. dataset.addValue(5, group1, "w6");
  22. dataset.addValue(5, group1, "w7");
  23. dataset.addValue(8, group1, "w8");
  24. SpiderWebPlot spiderwebplot = new SpiderWebPlot(dataset);
  25. JFreeChart jfreechart = new JFreeChart("Test", TextTitle.DEFAULT_FONT,spiderwebplot, false);
  26. LegendTitle legendtitle = new LegendTitle(spiderwebplot);
  27. legendtitle.setPosition(RectangleEdge.BOTTOM);
  28. jfreechart.addSubtitle(legendtitle);
  29. ChartPanel chartpanel = new ChartPanel(jfreechart);
  30. return chartpanel;
  31. }
  32. }

蜘蛛网

  1. public class MySpriderWebPlotTest {
  2. public static void main(String args[]) {
  3. JFrame jf = new JFrame();
  4. jf.add(erstelleSpinnenDiagramm());
  5. jf.pack();
  6. jf.setVisible(true);
  7. }
  8. public static JPanel erstelleSpinnenDiagramm() {
  9. DefaultCategoryDataset dataset = new DefaultCategoryDataset();
  10. String group1 = "apple ";
  11. dataset.addValue(5, group1, "w1");
  12. dataset.addValue(6, group1, "w2");
  13. dataset.addValue(4, group1, "w3");
  14. dataset.addValue(2, group1, "w4");
  15. dataset.addValue(5, group1, "w5");
  16. dataset.addValue(5, group1, "w6");
  17. dataset.addValue(5, group1, "w7");
  18. dataset.addValue(8, group1, "w8");
  19. String group2 = "orange ";
  20. dataset.addValue(3, group2, "w1");
  21. dataset.addValue(3, group2, "w2");
  22. dataset.addValue(4, group2, "w3");
  23. dataset.addValue(7, group2, "w4");
  24. dataset.addValue(4, group2, "w5");
  25. dataset.addValue(5, group2, "w6");
  26. dataset.addValue(3, group2, "w7");
  27. dataset.addValue(3, group2, "w8");
  28. String group3 = "banana ";
  29. dataset.addValue(4, group3, "w1");
  30. dataset.addValue(5, group3, "w2");
  31. dataset.addValue(2, group3, "w3");
  32. dataset.addValue(5, group3, "w4");
  33. dataset.addValue(6, group3, "w5");
  34. dataset.addValue(6, group3, "w6");
  35. dataset.addValue(4, group3, "w7");
  36. dataset.addValue(4, group3, "w8");
  37. SpiderWebPlot spiderwebplot = new SpiderWebPlot(dataset);
  38. JFreeChart jfreechart = new JFreeChart("Test", TextTitle.DEFAULT_FONT,spiderwebplot, false);
  39. LegendTitle legendtitle = new LegendTitle(spiderwebplot);
  40. legendtitle.setPosition(RectangleEdge.BOTTOM);
  41. jfreechart.addSubtitle(legendtitle);
  42. ChartPanel chartpanel = new ChartPanel(jfreechart);
  43. return chartpanel;
  44. }
  45. }

带刻度问题比较复杂,JFreeChart本身没有提供其功能,需要继承SpiderWebPlot,覆盖drawLabel方法。
此处代码参考Jerry代码,友情感谢。
MySpriderWebPlotTest出自“王杰瑞的技术博客” 博客,请务必保留此出处http://wangjierui.blog.51cto.com/186879/116845

  1. /**
  2. * @本文出自 “王杰瑞的技术博客” 博客,请务必保留此出处 http://wangjierui.blog.51cto.com/186879/116845
  3. */
  4. public class MySpiderWebPlot extends SpiderWebPlot {
  5. private int ticks = DEFAULT_TICKS;
  6. private static final int DEFAULT_TICKS = 5;
  7. private NumberFormat format = NumberFormat.getInstance();
  8. private static final double PERPENDICULAR = 90;
  9. private static final double TICK_SCALE = 0.015;
  10. private int valueLabelGap = DEFAULT_GAP;
  11. private static final int DEFAULT_GAP = 10;
  12. private static final double THRESHOLD = 15;
  13. MySpiderWebPlot(CategoryDataset createCategoryDataset) {
  14. super(createCategoryDataset);
  15. }
  16. @Override
  17. protected void drawLabel(final Graphics2D g2, final Rectangle2D plotArea, final double value,
  18. final int cat, final double startAngle, final double extent) {
  19. super.drawLabel(g2, plotArea, value, cat, startAngle, extent);
  20. final FontRenderContext frc = g2.getFontRenderContext();
  21. final double[] transformed = new double[2];
  22. final double[] transformer = new double[2];
  23. final Arc2D arc1 = new Arc2D.Double(plotArea, startAngle, 0, Arc2D.OPEN);
  24. for (int i = 1; i <= ticks; i++) {
  25. final Point2D point1 = arc1.getEndPoint();
  26. final double deltaX = plotArea.getCenterX();
  27. final double deltaY = plotArea.getCenterY();
  28. double labelX = point1.getX() - deltaX;
  29. double labelY = point1.getY() - deltaY;
  30. final double scale = ((double) i / (double) ticks);
  31. final AffineTransform tx = AffineTransform.getScaleInstance(scale, scale);
  32. final AffineTransform pointTrans = AffineTransform.getScaleInstance(scale + TICK_SCALE, scale + TICK_SCALE);
  33. transformer[0] = labelX;
  34. transformer[1] = labelY;
  35. pointTrans.transform(transformer, 0, transformed, 0, 1);
  36. final double pointX = transformed[0] + deltaX;
  37. final double pointY = transformed[1] + deltaY;
  38. tx.transform(transformer, 0, transformed, 0, 1);
  39. labelX = transformed[0] + deltaX;
  40. labelY = transformed[1] + deltaY;
  41. double rotated = (PERPENDICULAR);
  42. AffineTransform rotateTrans = AffineTransform.getRotateInstance(Math.toRadians(rotated), labelX, labelY);
  43. transformer[0] = pointX;
  44. transformer[1] = pointY;
  45. rotateTrans.transform(transformer, 0, transformed, 0, 1);
  46. final double x1 = transformed[0];
  47. final double y1 = transformed[1];
  48. rotated = (-PERPENDICULAR);
  49. rotateTrans = AffineTransform.getRotateInstance(Math.toRadians(rotated), labelX, labelY);
  50. rotateTrans.transform(transformer, 0, transformed, 0, 1);
  51. final Composite saveComposite = g2.getComposite();
  52. g2.setComposite(AlphaComposite.getInstance(AlphaComposite.SRC_OVER, 1.0f));
  53. g2.draw(new Line2D.Double(transformed[0], transformed[1], x1, y1));
  54. if (startAngle == this.getStartAngle()) {
  55. final String label = format.format(((double) i / (double) ticks) * this.getMaxValue());
  56. final Rectangle2D labelBounds = getLabelFont().getStringBounds(label, frc);
  57. final LineMetrics lm = getLabelFont().getLineMetrics(label, frc);
  58. final double ascent = lm.getAscent();
  59. if (Math.abs(labelX - plotArea.getCenterX()) < THRESHOLD) {
  60. labelX += valueLabelGap;
  61. labelY += ascent / (float) 2;
  62. } else if (Math.abs(labelY - plotArea.getCenterY()) < THRESHOLD) {
  63. labelY += valueLabelGap;
  64. } else if (labelX >= plotArea.getCenterX()) {
  65. if (labelY < plotArea.getCenterY()) {
  66. labelX += valueLabelGap;
  67. labelY += valueLabelGap;
  68. } else {
  69. labelX -= valueLabelGap;
  70. labelY += valueLabelGap;
  71. }
  72. } else {
  73. if (labelY > plotArea.getCenterY()) {
  74. labelX -= valueLabelGap;
  75. labelY -= valueLabelGap;
  76. } else {
  77. labelX += valueLabelGap;
  78. labelY -= valueLabelGap;
  79. }
  80. }
  81. g2.setPaint(getLabelPaint());
  82. g2.setFont(getLabelFont());
  83. g2.drawString(label, (float) labelX, (float) labelY);
  84. }
  85. g2.setComposite(saveComposite);
  86. }
  87. }
  88. }

带刻度雷达图

  1. /**
  2. * @作者:Jcuckoo
  3. * @日期:2008-12-9
  4. * @版本:V 1.0
  5. */
  6. public class MySpriderWebPlotTest {
  7. public static void main(String args[]) {
  8. JFrame jf = new JFrame();
  9. jf.add(erstelleSpinnenDiagramm());
  10. jf.pack();
  11. jf.setVisible(true);
  12. }
  13. public static JPanel erstelleSpinnenDiagramm() {
  14. DefaultCategoryDataset dataset = new DefaultCategoryDataset();
  15. String group1 = "apple ";
  16. dataset.addValue(5, group1, "w1");
  17. dataset.addValue(6, group1, "w2");
  18. dataset.addValue(4, group1, "w3");
  19. dataset.addValue(2, group1, "w4");
  20. dataset.addValue(5, group1, "w5");
  21. dataset.addValue(5, group1, "w6");
  22. dataset.addValue(5, group1, "w7");
  23. dataset.addValue(8, group1, "w8");
  24. MySpiderWebPlot spiderwebplot = new MySpiderWebPlot(dataset);
  25. JFreeChart jfreechart = new JFreeChart("Test", TextTitle.DEFAULT_FONT,spiderwebplot, false);
  26. LegendTitle legendtitle = new LegendTitle(spiderwebplot);
  27. legendtitle.setPosition(RectangleEdge.BOTTOM);
  28. jfreechart.addSubtitle(legendtitle);
  29. ChartPanel chartpanel = new ChartPanel(jfreechart);
  30. return chartpanel;
  31. }
  32. }

带刻度蜘蛛网

  1. /**
  2. * @作者:Jcuckoo
  3. * @日期:2008-12-9
  4. * @版本:V 1.0
  5. */
  6. public class MySpriderWebPlotTest {
  7. public static void main(String args[]) {
  8. JFrame jf = new JFrame();
  9. jf.add(erstelleSpinnenDiagramm());
  10. jf.pack();
  11. jf.setVisible(true);
  12. }
  13. public static JPanel erstelleSpinnenDiagramm() {
  14. DefaultCategoryDataset dataset = new DefaultCategoryDataset();
  15. String group1 = "apple ";
  16. dataset.addValue(5, group1, "w1");
  17. dataset.addValue(6, group1, "w2");
  18. dataset.addValue(4, group1, "w3");
  19. dataset.addValue(2, group1, "w4");
  20. dataset.addValue(5, group1, "w5");
  21. dataset.addValue(5, group1, "w6");
  22. dataset.addValue(5, group1, "w7");
  23. dataset.addValue(8, group1, "w8");
  24. String group2 = "orange ";
  25. dataset.addValue(3, group2, "w1");
  26. dataset.addValue(3, group2, "w2");
  27. dataset.addValue(4, group2, "w3");
  28. dataset.addValue(7, group2, "w4");
  29. dataset.addValue(4, group2, "w5");
  30. dataset.addValue(5, group2, "w6");
  31. dataset.addValue(3, group2, "w7");
  32. dataset.addValue(3, group2, "w8");
  33. String group3 = "banana ";
  34. dataset.addValue(4, group3, "w1");
  35. dataset.addValue(5, group3, "w2");
  36. dataset.addValue(2, group3, "w3");
  37. dataset.addValue(5, group3, "w4");
  38. dataset.addValue(6, group3, "w5");
  39. dataset.addValue(6, group3, "w6");
  40. dataset.addValue(4, group3, "w7");
  41. dataset.addValue(4, group3, "w8");
  42. MySpiderWebPlot spiderwebplot = new MySpiderWebPlot(dataset);
  43. JFreeChart jfreechart = new JFreeChart("Test", TextTitle.DEFAULT_FONT,spiderwebplot, false);
  44. LegendTitle legendtitle = new LegendTitle(spiderwebplot);
  45. legendtitle.setPosition(RectangleEdge.BOTTOM);
  46. jfreechart.addSubtitle(legendtitle);
  47. ChartPanel chartpanel = new ChartPanel(jfreechart);
  48. return chartpanel;
  49. }
  50. }

JFreeChart画雷达图、带刻度雷达图、蜘蛛网、带刻度蜘蛛网相关推荐

  1. JFreeChart 生成 蜘蛛网/刻度 雷达图

    JFreeChart 实现雷达图 一. 效果展示 二.功能实现 2.1 添加maven依赖 <!-- poi依赖包 --> <dependency><groupId> ...

  2. 【Python基础】Python画王者荣耀英雄能力雷达图

    现有以下表格,我需要画成第二张图中的雷达图(类似fifa足球.王者荣耀里面的那种球员能力图) 雷达图函数用到以下包: import math import numpy as np import mat ...

  3. Python画王者荣耀英雄能力雷达图

    现有以下表格,我需要画成第二张图中的雷达图(类似fifa足球.王者荣耀里面的那种球员能力图) 雷达图函数用到以下包: import math import numpy as np import mat ...

  4. Python画王者荣耀英雄能力雷达图!谁才是最强上分英雄!

    现有以下表格,我需要画成第二张图中的雷达图(类似fifa足球.王者荣耀里面的那种球员能力图) 雷达图函数用到以下包: import math import numpy as np import mat ...

  5. python3__绘图__常用数据分析图形(热力图,雷达图,箱线图,平行坐标,3D图,混淆矩阵,饼状图)

    1.matplotlib.pyplot简介 matplotlib.pyplot是一个有命令风格的函数集合,它看起来和MATLAB很相似.每一个pyplot函数都使一副图像做出些许改变,例如创建一幅图, ...

  6. 数据可视化实验:python数据可视化-柱状图,条形图,直方图,饼图,棒图,散点图,气泡图,雷达图,箱线图,折线图

    数据可视化实验:python数据可视化 实验8-12:大数据可视化工具-python 目录 1柱状图 2条形图 3直方图 4饼图 5棒图 6散点图 7气泡图 8雷达图 9箱线图 10折线图 1柱状图 ...

  7. php雷达图,如何制作雷达图mac.docx

    如何制作雷达图mac 如何制作雷达图mac 导语: 说到雷达图,可能很多办公人士第一反应就是用Excel.Excel拥有强大的制图功能,能很好的满足我们平时处理数据的需求.但是想要在Excel中绘制出 ...

  8. MATLAB绘制雷达图并导出矢量图到Visio编辑(论文用图)

    MATLAB绘制雷达图并导出矢量图到Visio编辑(论文用图) 前言: matlab绘制雷达图   雷达图(Radar Chart)又被叫做蜘蛛网图(Spider Chart),适用于显示三个或更多的 ...

  9. R语言使用ggradar包可视化基本雷达图(radar chart、蜘蛛图spider plot)、可视化单个数据对象的雷达图、自定义雷达图的线条类型、线条宽度、数据点大小、色彩等

    R语言使用ggradar包可视化基本雷达图(radar chart.蜘蛛图spider plot).可视化单个数据对象的雷达图.自定义雷达图的线条类型.线条宽度.数据点大小.色彩等(Customize ...

最新文章

  1. NOIP模拟 蛋糕(DP+Dilworth定理)
  2. MySQL 数据库规范--开发篇
  3. 【物联网智能网关-15】WAV播放器(WinForm+WavPlay库实例)
  4. 产品经理必备知识之网页设计系列(二)-如何设计出一个优秀的界面
  5. Eclipse正确配置Tomcat之后仍然报错Type Target runtime Apache Tomcat v8.0 is not defined解决方式
  6. jvm fastdebug
  7. Edittext焦点处理
  8. window.location.href = basePath + paper/deleteExpertComment.action?expertId=+$(this).prev().val();
  9. Oracle日志切换及频率跟踪脚本
  10. 【Django 2021年最新版教程21】数据库查询 model 多条数据 queryset转dict字典 返回渲染到前端
  11. 微信朋友圈的测试用例
  12. 马斯克 超级计算机,超级计算机升空 马斯克的SpaceX负责运送
  13. 关于ksps(A/D转换速率单位)
  14. 谷歌语音合成_如何修改Google语音合成语音
  15. 基于JAVA社区养老服务管理系统计算机毕业设计源码+系统+mysql数据库+lw文档+部署
  16. 软电话 开源的和免费的大全
  17. 苹果App Store简介
  18. i3 1215U 和 i5 1235U选哪个好
  19. 再见,仙剑之父!再见,姚壮宪!
  20. pmsm仿真 matlab 转子转角波形,MATLAB/SIMULINK的永磁同步电机矢量控制系统仿真研究...

热门文章

  1. 智能网联云控车路协同的研究实践
  2. 嘉为蓝鲸CMP:跳出云管看云管(运维/混合云/一体化)
  3. Python批量修改文件名,文件再多也只要一秒,省时又不闹心
  4. Django(Celery+日志)
  5. aware java_Spring中Aware接口说明
  6. c语言将数组初始化为1_C语言数组如何初始化
  7. mac百度网盘下载文件无法找到
  8. 打字提速练习方法-by小鹤双拼QQ群友-微笑的军师
  9. Redis 9 种数据结构简述
  10. 适用于pc的优酷api调用方式和适用触屏端的api调用方式