2011-11-11 19 views
5

enter image description here Mam kod jak poniżej. Ale nie otrzymuję wszystkich etykiet osi X i nie jest wyświetlana w 45 stopniach, gdy próbuję mieć to w formacie PDF. Ponieważ jestem nowy, pomóż mi poprawić tę opcję.wszystkie etykiety osi X nie są wyświetlane w 45 °

pdf(file="figure.pdf", height=3.5, width=5, onefile=TRUE) 
    Runtime <- c(579,0,581,610,830,828,592,651,596,596,591,581,587,594,604,606,447,434,445) 
    Runtime 
    g_range <- range(0,Runtime) 
    g_range 
    plot(Runtime, type="o", col="blue", ylim=g_range,axes=FALSE, ann=FALSE) 
    lab=c('2011-07-20','2011-08-03','2011-08-10','2011-08-17','2011-08-24','2011-08-25','2011-08-27','2011-08-31','2011-09-07','2011-09-10','2011-09-14','2011-09-21','2011-09-28','2011-10-05','2011-10-06','2011-10-07','2011-10-13','2011-10-19','2011-10-31') 
    box() 
    lab 
    axis(1, at=1:19, lab=F) 
    text(axTicks(1), par("usr")[3] - 2, srt=45, adj=1, labels=lab, xpd=T, cex=0.8) 
    axis(2, las=1, at=500*0:g_range[2]) 
    title(main="Runtime", col.main="red", font.main=4) 
    title(xlab="Build", col.lab=rgb(0,0.5,0)) 
    title(ylab="MS", col.lab=rgb(0,0.5,0)) 
    legend(1, g_range[2], c("AveElapsedTime"), cex=0.8, col=c("blue"), pch=21, lty=1); 
    dev.off() 
+1

Możesz używać tylko pionu lub poziomu używając 'las'. Jeśli chcesz mieć nachylone etykiety, musisz napisać je samemu, używając 'text': http://128.97.141.26/stat/R/faq/angled_labels.htm – James

+0

@James err, OP * is *. Zobacz wywołanie 'text()' za pomocą 'srt'. –

+0

Ooops! Właśnie zeskanował kod i widział tylko wywołania osi. – James

Odpowiedz

6

Kiedy uruchomić kod, robię nie uzyskać obraz, który show. Problemem jest to linia:

text(axTicks(1), par("usr")[3] - 2, srt=45, adj=1, labels=lab, xpd=T, cex=0.8) 

jak axTicks(1) powraca:

> axTicks(1) 
[1] 5 10 15 

Więc co się dzieje, jest to, że etykiety 19 są kreślone na tych lokalizacjach.

Jeśli chcesz wykreślić w miejscach tych kleszczy (1:19), a następnie:

text(1:19, par("usr")[3] - 2, srt=45, adj=1, labels=lab, xpd=T, cex=0.8) 

zadziała.

Oto pełny przykład oparty na kodzie.

Runtime <- c(579,0,581,610,830,828,592,651,596,596,591,581,587, 
      594,604,606,447,434,445) 
g_range <- range(0,Runtime) 
lab <- c('2011-07-20','2011-08-03','2011-08-10','2011-08-17','2011-08-24', 
     '2011-08-25','2011-08-27','2011-08-31','2011-09-07','2011-09-10', 
     '2011-09-14','2011-09-21','2011-09-28','2011-10-05','2011-10-06', 
     '2011-10-07','2011-10-13','2011-10-19','2011-10-31') 
## plot 
op <- par(mar = c(6,4,4,2) + 0.1) ## bigger bottom margin 
plot(Runtime, type="o", col="blue", ylim=g_range, axes=FALSE, ann=FALSE) 
box() 
axis(1, at=1:19, lab=FALSE) 
text(1:19, par("usr")[3] - 40, srt=45, adj=1.2, labels=lab, xpd=T, cex=0.7) 
axis(2, las=1, at=500*0:g_range[2]) 
title(main="Runtime", col.main="red", font.main=4) 
title(xlab="Build", col.lab=rgb(0,0.5,0), line = 4.5) 
title(ylab="MS", col.lab=rgb(0,0.5,0)) 
legend("topright", c("AveElapsedTime"), cex=0.8, col=c("blue"), pch=21, lty=1) 
## reset par 
par(op) 

To może być lepiej obsługiwane za pomocą funkcji w gridBase pakietu choć, co pozwala siatkę i bazową grafika do przenikają. Powodem, dla którego mówię, że może być lepiej, jest to, że możesz określić, że współrzędna y powinna być ustawiona pod względem liczby linii, zamiast próbować wyliczyć odpowiednią wartość dla y pod względem wykreślonych danych.

Oto przykład:

## load gridBase 
require(gridBase) 

## do the base plot parts 
op <- par(mar = c(6,4,4,2) + 0.1) ## bigger bottom margin 
plot(1:19, Runtime, type="o", col="blue", ylim=g_range, axes=FALSE, ann=FALSE) 
box() 
axis(1, at=1:19, lab=FALSE) 
axis(2, las=1, at=500*0:g_range[2]) 
title(main="Runtime", col.main="red", font.main=4) 
title(xlab="Build", col.lab=rgb(0,0.5,0), line = 4.5) 
title(ylab="MS", col.lab=rgb(0,0.5,0)) 
legend("topright", c("AveElapsedTime"), cex=0.8, col=c("blue"), pch=21, lty=1) 
## at this point, DO NOT alter the dimensions of the plotting window 

## now do the grid business 
vps <- baseViewports() 
pushViewport(vps$inner, vps$figure, vps$plot) 
## this adds the text 
grid.text(lab, x = unit(1:19, "native"), y = unit(-1, "lines"), 
      just = "right", rot = 60, gp = gpar(cex = 0.7)) 
## this finishes off the viewport - you have to do this or things will go wrong: 
popViewport(3) 
## reset par 
par(op) 

Uwaga może to być trochę wybredny na ekranie, ponowne uruchomienie przykład gridBase na mój R 2.13.2 instalacja nie powoduje żadnych etykiet. Zamknięcie urządzenia i ponowne uruchomienie kodu działa jednak. Nie sądzę, że powinien to być problem, jeśli rysujesz na urządzeniu pdf().

+1

+1 dla '" topright "' w legendzie. Lubię 'adj = 1.2' również w' tekście'; gdybym dalej szarpał, przesuwałbym etykietę x w dół (jest pokryta etykietami odcisków) i zwiększam margines, aby zrekompensować ... –

+0

@BenBolker Dobre punkty. Porzuciłem manipulowanie przy współrzędnej "y", ponieważ przypomniałem sobie, że jest lepszy sposób na zrobienie tego przy użyciu ** gridBase **. Kolejny przykład jest pokazany przy użyciu tego zamiast obcinania ze współrzędnymi użytkownika. –

+0

Dziękuję bardzo Gavin .. Działa wspaniale .. Dziękuję Ben, James za komentarze .. – Tamilan

Powiązane problemy