如何创建堆叠线图

Bur*_*Leo 13 diagram charts r

有多种解决方案可以在R中创建堆叠条形图,但如何绘制堆叠线图?

在此输入图像描述

Sve*_*ein 23

可以使用ggplot2包创建堆叠线图.

一些示例数据:

set.seed(11)
df <- data.frame(a = rlnorm(30), b = 1:10, c = rep(LETTERS[1:3], each = 10))
Run Code Online (Sandbox Code Playgroud)

这种情节的功能是geom_area:

library(ggplot2)
ggplot(df, aes(x = b, y = a, fill = c)) + geom_area(position = 'stack')
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述


Bur*_*Leo 4

鉴于图表数据可用作数据框,列中包含“线”,行中包含 Y 值,并且 row.names 是 X 值,因此此脚本使用 Polygon 函数创建堆叠折线图。

stackplot = function(data, ylim=NA, main=NA, colors=NA, xlab=NA, ylab=NA) {
  # stacked line plot
  if (is.na(ylim)) {
    ylim=c(0, max(rowSums(data, na.rm=T)))
  }
  if (is.na(colors)) {
    colors = c("green","red","lightgray","blue","orange","purple", "yellow")
  }
  xval = as.numeric(row.names(data))
  summary = rep(0, nrow(data))
  recent = summary

  # Create empty plot
  plot(c(-100), c(-100), xlim=c(min(xval, na.rm=T), max(xval, na.rm=T)), ylim=ylim, main=main, xlab=xlab, ylab=ylab)

  # One polygon per column
  cols = names(data)
  for (c in 1:length(cols)) {
    current = data[[cols[[c]]]]
    summary = summary + current
    polygon(
      x=c(xval, rev(xval)),
      y=c(summary, rev(recent)),
      col=colors[[c]]
    )
    recent = summary
  }
}
Run Code Online (Sandbox Code Playgroud)