Skip to content

Legend in the Margins of a plot

1 message · Jim Lemon

#
Partha,

If you mean the style of legend below or above the plot as often seen in
charting programs, this might be what you need.  You may have to set the
margins to get this to work - e.g.
The function is as follows:
function (side = 1, xpos, ypos, legend, lty, pch, col)
{
    if (!missing(legend)) {
        oldpar <- par("adj","xpd)
        par(adj = 0, xpd = T)
        legendwidth <- strwidth(legend)
        markwidth <- strwidth("MM")
        totalwidth <- sum(legendwidth) + 3 * markwidth * length(legend)
        if (missing(xpos)) {
            xlim <- par("usr")[1:2]
            xcenter <- (xlim[1] + xlim[2])/2
            xpos <- xcenter - totalwidth/2
        }
        if (missing(ypos)) {
            ylim <- par("usr")[3:4]
            yoffset <- (ylim[2] - ylim[1])/6
            if (side != 1)
                ypos <- ylim[2] + yoffset
            else ypos <- ylim[1] - yoffset
        }
        if (missing(col))
            col <- rep(1, length(legend))
        for (i in 1:length(legend)) {
            if (!missing(pch))
                points(xpos, ypos, type = "p", pch = pch[i],
                  col = col[i])
            if (!missing(lty))
                lines(c(xpos - markwidth, xpos), c(ypos, ypos),
                  type = "l", lty = lty[i], col = col[i])
            xpos <- xpos + markwidth
            text(xpos, ypos, legend[i])
            xpos <- xpos + legendwidth[i] + 2 * markwidth
        }
        par(oldpar)
    }
    else cat("Usage: legend.mar([side=1] [, xpos] [, ypos], legend [,
lty] [, pch] [, col=1])\n")
}


Bit rough, but I hope it helps.

Jim


-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-.-
r-help mailing list -- Read http://www.ci.tuwien.ac.at/~hornik/R/R-FAQ.html
Send "info", "help", or "[un]subscribe"
(in the "body", not the subject !)  To: r-help-request at stat.math.ethz.ch
_._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._._