循环雷达图传说

时间:2014-04-21 21:29:40

标签: r legend radar-chart

作为循环的一部分,我正在创建几个雷达图。每个图表都是一个国家,蜘蛛网中显示的信息是几年的数据(不同颜色的线条)。我正在尝试添加一个图例,以便明确哪一行(颜色)与哪一年相关。据我所知,雷达图上的帮助文件对此保持沉默。 (我在这件事上看到了之前的post,但不认为这是适用的,因为我在这里工作了一个循环)。我会很感激任何提示。

以下是与循环的一次迭代有关的数据:

require(fmsb)

Radar.tmp<–list(cowc = c("0", "0", "ZIM", "ZIM", "ZIM", "ZIM", 
"ZIM", "ZIM", "ZIM", "ZIM", "ZIM", "ZIM", "ZIM", "ZIM", "ZIM", 
"ZIM"), year = c(0, 0, 1996, 1998, 2000, 2002, 2003, 2004, 2005, 
2006, 2007, 2008, 2009, 2010, 2011, 2012), RoL.Estimate = c(2.5, 
-2.5, -0.82, -0.71, -1.33, -1.59, -1.68, -1.76, -1.77, -1.73, 
-1.78, -1.77, -1.84, -1.81, -1.79, -1.62), GovEff.Estimate = c(2.5, 
-2.5, -0.23, -0.37, -0.78, -0.9, -0.95, -0.95, -1.29, -1.3, -1.27, 
-1.5, -1.52, -1.5, -1.36, -1.21), RegQual.Estimate = c(2.5, -2.5, 
-0.98, -0.79, -1.46, -1.97, -2, -2.03, -2.21, -1.96, -2.16, -2.11, 
-2.1, -2.05, -1.92, -1.83), ControlCorruption.Estimate = c(2.5, 
-2.5, -0.25, -0.65, -0.95, -1.21, -1.25, -1.31, -1.28, -1.33, 
-1.36, -1.31, -1.32, -1.31, -1.38, -1.27), PolStab.Estimate = c(2.5, 
-2.5, -0.53, -0.88, -1.42, -1.6, -1.14, -1.26, -1.24, -0.91, 
-1.11, -1.2, -1.16, -1.12, -0.95, -0.79), VoiceAccount.Estimate = c(2.5, 
-2.5, -0.62, -0.82, -1.11, -1.41, -1.44, -1.55, -1.66, -1.54, 
-1.57, -1.54, -1.54, -1.48, -1.47, -1.45)), .Names = c("cowc", 
"year", "RoL.Estimate", "GovEff.Estimate", "RegQual.Estimate", 
"ControlCorruption.Estimate", "PolStab.Estimate", "VoiceAccount.Estimate"
), row.names = c(1L, 2L, 2689L, 2690L, 2691L, 2692L, 2693L, 2694L, 
2695L, 2696L, 2697L, 2698L, 2699L, 2700L, 2701L, 2702L), class = "data.frame")

这里是雷达图的命令:

 radarchart(Radar.tmp[,c("RoL.Estimate","GovEff.Estimate","RegQual.Estimate","ControlCorruption.Estimate","PolStab.Estimate","VoiceAccount.Estimate")], 
             axistype=2, seg=10, pcol=1:8, pty=16, plty=1, maxmin=TRUE, axislabcol="grey", title=c)

以下是目前的图表:enter image description here

请注意,循环中的年数(行数)将从迭代更改为迭代。

我知道雷达图有一些严重的缺点,但是会要求你暂时将它们放在一边。

非常感谢任何提示/建议!

1 个答案:

答案 0 :(得分:1)

enter image description here找到了我要找的东西:

legend(1.5,1, legend=unique(Radar.tmp$year), seg.len=0.5, title="year", pch=1, 
    bty="n" ,lwd=3, y.intersp=0.5, horiz=FALSE, col=unique(Radar.tmp$year))