Oto kolejny sposób to zrobić, korzystając z funkcji line2user
z this post.
par(mfrow = c(2, 2))
plot(runif(100))
plot(runif(100))
text(line2user(line=mean(par('mar')[c(2, 4)]), side=2),
line2user(line=2, side=3), 'First title', xpd=NA, cex=2, font=2)
plot(runif(100))
plot(runif(100))
text(line2user(line=mean(par('mar')[c(2, 4)]), side=2),
line2user(line=2, side=3), 'Second title', xpd=NA, cex=2, font=2)

Tutaj tytuł ustawiony 2 linie wyższa niż górna krawędź działki, o czym świadczy line2user(2, 3)
. Wyśrodkowujemy ją, kompensując ją w odniesieniu do 2. i 4. poletka, o połowę łącznej szerokości lewego i prawego marginesu, tj. mean(par('mar')[c(2, 4)])
.
line2user
wyraża przesunięcie (liczbę linii) od osi współrzędnych w użytkownika i jest zdefiniowany jako:
line2user <- function(line, side) {
lh <- par('cin')[2] * par('cex') * par('lheight')
x_off <- diff(grconvertX(0:1, 'inches', 'user'))
y_off <- diff(grconvertY(0:1, 'inches', 'user'))
switch(side,
`1` = par('usr')[3] - line * y_off * lh,
`2` = par('usr')[1] - line * x_off * lh,
`3` = par('usr')[4] + line * y_off * lh,
`4` = par('usr')[2] + line * x_off * lh,
stop("side must be 1, 2, 3, or 4", call.=FALSE))
}
Doing że rodzaj przesłaniać „title”, prawda? Dlaczego nie chcesz, aby był na szczycie wszystkich fabuł? – A5C1D2H2I1M1N2O1R2T1
Co mam na myśli, to jeden tytuł dla 2 górnych działek i jeden tytuł dla 2 niższych działek. Poprawiłem moją Q – ECII