Как удалить эстетику из легенды ggplot2

Я ищу способ скрыть одну из эстетических легенд из сюжета, созданного с помощью приведенного ниже кода. Чтобы масштабировать цвет точки по дате, мне пришлось преобразовать даты в числа, и я предпочел бы не показывать легенду даты на сюжете. С другой стороны, легенда формы - важная информация для отображения. Я понимаю, что legend.position="none" полностью удалит легенду, но затем это оставляет мне проблему с сообщением смысла за фигурами.

library(ggplot2)
w<-read.table("data.txt", header=TRUE)
pt.data <- w[w$dt==min(w$dt),]
p <- ggplot(data=w, aes(OAD,RtgValInt,color=dt,shape=Port)) +
     geom_jitter(size=3, alpha=0.75) +
     scale_colour_gradient(limits=c(min(w$dt), 
             max(w$dt)),
         low="#9999FF", high="#000066") +
     geom_point(data=pt.data, 
         color="red", size=3, aes(shape=Port))
print(p)

Файл data.txt содержит следующие строки.

Date          Port    OAD         RtgValInt   dt
12/31/2010  Grp1    1.463771    1.833333    14974
12/31/2010  Grp2    1.193307    2.071429    14974
11/30/2010  Grp1    1.454115    1.833333    14943
11/30/2010  Grp2    1.127755    2.071429    14943
10/29/2010  Grp1    1.434965    2.000000    14911
10/29/2010  Grp2    1.055758    2.071429    14911
09/30/2010  Grp1    1.441773    2.000000    14882
09/30/2010  Grp2    1.077799    2.071429    14882

enter image description here

Ответ 1

Вы можете подавлять легенды на уровне уровня. Если вы перемещаете цветную эстетику от начального вызова ggplot к слою джиттера, это, похоже, дает эффект, который вы после. Я немного смущен, но о том, почему вы хотите покрасить по дате и не дать ключ к тому, что означают цвета... но это более философский вопрос, который вы должны обдумать.

ggplot(data=w, aes(OAD,RtgValInt,shape=Port)) +
  geom_jitter(size=3, alpha=0.75, color=dt, legend = FALSE) +
  scale_colour_gradient(limits=c(min(w$dt), max(w$dt)),low="#9999FF", high="#000066") +
  geom_point(data=pt.data, color="red", size=3, aes(shape=Port))