Área sob a curva ggplotly R não renderizada conforme o esperado
Eu criei um gráfico com o seguinte conjunto de dados e ggplot2
Eu baixei o conjunto de dados em CSV no link abaixo
https://www.kaggle.com/dataset/e392d3cfbb5749653d5c82f4bec1daa03628fb06d374fad84eac319f1b3f982422
O código que usei é o seguinte
library(readr)
library(ggplot2)
library(plotly)
Em seguida, crio o dataframe do arquivo CSV
DF <- read_csv("C:/Users/mysystem/Desktop/Random3.csv")####Please set your working directory here
Agora eu crio um gráfico usando ggplot
p2<-ggplot(DF, aes(x=Col1, y=Col2, group=ID)) +
geom_line(size=.5) + geom_ribbon(data=subset(DF, Col1>1 ),aes(x=Col1,ymax=Col2,
fill=ID),ymin=0,alpha=0.3 ) +
scale_fill_manual(name='Legend', values=c("green4", "red"), labels=c("A", "B" ))+labs(x="Col1",
y="Col2")+ xlim(0, 10000)+ theme_bw()# +theme(legend.position='none')
O gráfico acima mostra a área sob as curvas corretamente. No entanto, quando executo o ggplotly, a área sob as curvas é invertida
ggplotly(p2)
Existe uma maneira que isso pode ser evitado. A área sombreada parece mover-se além da área sob as curvas em alguns casos e, neste caso, parece mover-se para o inverso da curva. Peço a alguém que dê uma olhada.
Respostas
Eu acho que você está apenas querendo geom_area
em vez de geom_ribbon
. Você também pode definir o primeiro valor como 0 em vez de ignorá-lo para evitar o preenchimento reverso que o polígono resultante possui.
library(ggplot2)
library(plotly)
DF <- read.csv("Random3.csv")
DF$Col2[DF$Col1 == 0] <- 0
p2 <- ggplot(DF, aes(x = Col1, y = Col2, group = ID)) +
geom_line(size = 0.5) +
geom_area(aes(x = Col1, fill = ID), alpha = 0.3,
position = "identity") +
scale_fill_manual(name = 'Legend',
values = c("green4", "red"),
labels = c("A", "B")) +
labs(x = "Col1", y = "Col2") +
xlim(0, 10000) +
theme_bw()
p2
ggplotly(p2)
