私の質問はこれに似ていますが、その答えを私のプロットで機能させることはできません。
geom_linerange
名前のグループ ( )を使用してタイムラインを作成しています1:20
。各名前はスポンサー ( ) に関連付けられていB:E
ます。名前/タイムラインがスポンサーごとにグループ化されるように、グラフを「ファセット」したいと考えています。これまでのところ、スポンサーと名前を含む「コンボ」ファクターを作成すると、結合されたプロットを取得できます。ただし、ファセットしようとすると、各スポンサーがすべての名前を取得します。
これが私のデータセットの(変更されたサブセット)です(lubridate
日付に使用しています...):
structure(list(Sponsor = structure(c(1L, 1L, 1L, 1L, 1L, 1L,
1L, 1L, 2L, 2L, 2L, 3L, 3L, 3L, 3L, 3L, 4L, 4L, 4L, 4L), .Label = c("B",
"C", "D", "E"), class = "factor"), Last = structure(1:20, .Label = c("1",
"2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13",
"14", "15", "16", "17", "18", "19", "20"), class = "factor"),
Grant = c(0, 0, 1, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 0, 0.5,
0, 1, 1, 0), Start = structure(c(844128000, 904003200, 1001289600,
1314835200, 1064188800, 1107561600, 1138838400, 1264896000,
1222819200, 1042502400, 1343779200, 904521600, 950832000,
1009929600, 1081209600, 1171929600, 821664000, 865209600,
979603200, 1209600000), class = c("POSIXct", "POSIXt"), tzone = "UTC"),
End = structure(c(929232000, 946684800, 1088035200, NA, 1109721600,
1324512000, 1232496000, NA, NA, 1101859200, 1388448000, 993859200,
1006819200, 1103500800, 1139529600, 1235952000, 919036800,
1030665600, 1047254400, 1272585600), class = c("POSIXct",
"POSIXt"), tzone = "UTC"), Combo = c("B_1", "B_2", "B_3",
"B_4", "B_5", "B_6", "B_7", "B_8", "C_9", "C_10", "C_11",
"D_12", "D_13", "D_14", "D_15", "D_16", "E_17", "E_18", "E_19",
"E_20")), .Names = c("Sponsor", "Last", "Grant", "Start",
"End", "Combo"), row.names = c(NA, 20L), class = "data.frame")
以下は、物事を順番にグループ化するが細分化しない非ファセット プロットを生成するコマンドです。
library(ggplot2)
require(lubridate)
YearLine = ymd(19960101) + years(seq(0,18))
ggplot(testdat,aes(Combo, Start, ymin=Start,ymax=End,color=as.factor(Grant),xticks)) + xlab("Sponsor") + geom_linerange(size=4,alpha=.7) + geom_point(size=4,shape=18) + coord_flip() + scale_colour_brewer(palette="Spectral") + scale_x_discrete(labels=testdat$Sponsor) + geom_hline(yintercept = as.numeric(YearLine),alpha=0.6,col="indianred1",linetype="dotted") + annotate("text", x = testdat$Combo, y = testdat$Start, label = testdat$Last, hjust=0,size=2.5)
そして、これが生成するプロットです。これは私が望んでいることのようなものです (冗長ではないという点で) が、スポンサーによって細分化されたいと思います:
+ facet_grid(Sponsor ~ .,scale="free_x",space="free_x")
(または)を追加するfree_y
と、希望どおりにスポンサーによってパネルがファセットされますが、その「スポンサー」B から E に関連していなくても、すべての名前がリストされます。