Search code examples
rggplot2dplyrtidyverse

add gaps in circular plot in R


I used these codes here R Grahp Gallery to make a circular plot.

It works but I do not have the gaps (the spaces).

it appears like this. How can I justify this?

enter image description here

The used Code is below.

library(tidyverse)
 
# Create dataset
data <- data.frame(
  individual=paste( "Mister ", seq(1,60), sep=""),
  group=c( rep('A', 10), rep('B', 30), rep('C', 14), rep('D', 6)) ,
  value=sample( seq(10,100), 60, replace=T)
)
 
# Set a number of 'empty bar' to add at the end of each group
empty_bar <- 4
to_add <- data.frame( matrix(NA, empty_bar*nlevels(data$group), ncol(data)) )
colnames(to_add) <- colnames(data)
to_add$group <- rep(levels(data$group), each=empty_bar)
data <- rbind(data, to_add)
data <- data %>% arrange(group)
data$id <- seq(1, nrow(data))
 
# Get the name and the y position of each label
label_data <- data
number_of_bar <- nrow(label_data)
angle <- 90 - 360 * (label_data$id-0.5) /number_of_bar     # I substract 0.5 because the letter must have the angle of the center of the bars. Not extreme right(1) or extreme left (0)
label_data$hjust <- ifelse( angle < -90, 1, 0)
label_data$angle <- ifelse(angle < -90, angle+180, angle)
 
# Make the plot
p <- ggplot(data, aes(x=as.factor(id), y=value, fill=group)) +       # Note that id is a factor. If x is numeric, there is some space between the first bar
  geom_bar(stat="identity", alpha=0.5) +
  ylim(-100,120) +
  theme_minimal() +
  theme(
    legend.position = "none",
    axis.text = element_blank(),
    axis.title = element_blank(),
    panel.grid = element_blank(),
    plot.margin = unit(rep(-1,4), "cm") 
  ) +
  coord_polar() + 
  geom_text(data=label_data, aes(x=id, y=value+10, label=individual, hjust=hjust), color="black", fontface="bold",alpha=0.6, size=2.5, angle= label_data$angle, inherit.aes = FALSE ) 
 
p ```

Solution

  • It's because this line:

    to_add <- data.frame( matrix(NA, empty_bar*nlevels(data$group), ncol(data)) )
    

    expects data$group to a factor. This used to be true, because data.frame used to convert strings to factors by default.

    The only change necessary is therefore:

    data <- data.frame(
        individual=paste( "Mister ", seq(1,60), sep=""),
        group=c( rep('A', 10), rep('B', 30), rep('C', 14), rep('D', 6)) ,
        value=sample( seq(10,100), 60, replace=T), 
        stringsAsFactors = TRUE # <- add this right here
    )