Ich möchte eine alternative Lösung anbieten , eine robuste Lösung, die der von mir vorgeschlagenen ähnelt, war in der neuesten Version von ggtern erforderlich , da die Funktion zum Drehen der Zeichenfläche eingeführt wurde.
Grundsätzlich müssen Sie die relativen Positionen mithilfe der Trigonometrie bestimmen, indem Sie eine Funktion erstellen, die ein element_text
Objekt mit einem bestimmten Winkel (dh Grad) und einer Positionierungsinformation (dh einer von x, y, oben oder rechts) zurückgibt .
#Load Required Libraries
library(ggplot2)
library(gridExtra)
#Build Function to Return Element Text Object
rotatedAxisElementText = function(angle,position='x'){
angle = angle[1];
position = position[1]
positions = list(x=0,y=90,top=180,right=270)
if(!position %in% names(positions))
stop(sprintf("'position' must be one of [%s]",paste(names(positions),collapse=", ")),call.=FALSE)
if(!is.numeric(angle))
stop("'angle' must be numeric",call.=FALSE)
rads = (angle - positions[[ position ]])*pi/180
hjust = 0.5*(1 - sin(rads))
vjust = 0.5*(1 + cos(rads))
element_text(angle=angle,vjust=vjust,hjust=hjust)
}
Ehrlich gesagt denke ich, dass eine 'Auto'-Option ggplot2
für die Argumente hjust
und verfügbar gemacht werden sollte. vjust
Wenn Sie den Winkel angeben, können Sie trotzdem demonstrieren, wie das oben Genannte funktioniert.
#Demonstrate Usage for a Variety of Rotations
df = data.frame(x=0.5,y=0.5)
plots = lapply(seq(0,90,length.out=4),function(a){
ggplot(df,aes(x,y)) +
geom_point() +
theme(axis.text.x = rotatedAxisElementText(a,'x'),
axis.text.y = rotatedAxisElementText(a,'y')) +
labs(title = sprintf("Rotated %s",a))
})
grid.arrange(grobs=plots)
Welches erzeugt das folgende:
q + theme(axis.text.x=element_text(angle = -90, hjust = 0))