您可以輕鬆地使用ggplot2從一層到另一層(使用geom_rect和geom_text)構建此圖。不是一個閃亮的解決方案,但你可以得到由圖片:
產生一些數據要在情節中:
df <- data.frame(A=sort(runif(20)), B=sort(runif(20)))
df <- rbind(df, c(1,1))
產生上述數據表的修改版本將被繪製成「內部」軸(注:我只計算兩個份中位數):
df_rect <- data.frame(xmin=c(0, median(df$A), -0.01, -0.01), xmax=c(median(df$A), 1, 0, 0), ymin=c(-0.01, -0.01, 0, median(df$B)), ymax=c(0, 0, median(df$B), 1), color=grey(c(0.7, 0.2)), alpha=c(0.8, 0.4, 0.8, 0.4))
生成類似的東西爲繪製文本:
df_text <- data.frame(x=c(median(df$A)/2, median(df$A) + (1-median(df$A))/2, 0.05, 0.05), y=c(0.02, 0.02, median(df$B)/2, median(df$B) + (1-median(df$B))/2), label=rep('50%', 4))
,最後所有的情節:
ggplot(df, aes(A, B)) + geom_point() +
geom_line() +
geom_rect(data=df_rect, aes(xmin=xmin,xmax=xmax,ymin=ymin,ymax=ymax, fill=color, alpha=alpha), inherit.aes = FALSE) + scale_fill_grey() +
geom_text(data=df_text, aes(x=x, y=y, label=label), inherit.aes = FALSE) +
theme_bw() + scale_y_continuous(limits=c(-0.01, 1), formatter='percent') + scale_x_continuous(limits=c(-0.01, 1), formatter='percent') + opts(legend.position="none")
凡geom_point
點給定值和geom_line
連接所有(如我在您的示例圖像所看到的)。所有參數均爲geom_rect
,繪製灰色「內軸」,文字部分爲geom_text
。您將必須使用生成的(輸入)數據幀(在上例中:df_rext
和df_text
)來獲取您所需的數據。 theme_bw
代表黑色和白色主題,兩個scale_continous
選項代表設置0和1之間的限制,並設置百分比formatter
。
導致: 
我希望你將能夠定製和升級這個小例子,以您的需求!
您可以使用'geom_rect'和'geom_text'手動添加這些值。如果你可以提供關於計算值的額外細節,那將是非常好的,因爲不清楚你在內部「軸」上顯示的是什麼。 – daroczig 2011-04-22 13:33:53
@daroczig:我編輯了更多信息的帖子 – Barata 2011-04-22 18:54:41