Obszar pod krzywą ggplotly R nie jest renderowany zgodnie z oczekiwaniami
Utworzyłem wykres z następującym zestawem danych i ggplot2
Pobrałem zestaw danych w formacie CSV z poniższego linku
https://www.kaggle.com/dataset/e392d3cfbb5749653d5c82f4bec1daa03628fb06d374fad84eac319f1b3f982422
Kod, którego użyłem, jest następujący
library(readr)
library(ggplot2)
library(plotly)
Następnie tworzę ramkę danych z pliku CSV
DF <- read_csv("C:/Users/mysystem/Desktop/Random3.csv")####Please set your working directory here
Teraz tworzę działkę za pomocą 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')
Powyższy wykres poprawnie pokazuje obszar pod krzywymi. Kiedy jednak uruchomię ggplotly, obszar pod krzywymi zostanie odwrócony
ggplotly(p2)
Czy można tego uniknąć? W niektórych przypadkach zacieniony obszar wydaje się przesuwać poza obszar pod krzywymi, aw tym przypadku wydaje się, że przesuwa się w kierunku odwrotności krzywej. proszę kogoś, żeby spojrzał.
Odpowiedzi
Myślę, że po prostu chcesz geom_area
zamiast tego geom_ribbon
. Możesz również ustawić pierwszą wartość na 0 zamiast pomijać ją, aby zapobiec odwrotnemu wypełnieniu, które ma wynikowy wielokąt.
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)
