
plotTracks
is the main interface when plotting single track
objects, or lists of tracks linked together across the same genomic
coordinates. Essentially, the resulting plots are very similar to the
graphical output of the UCSC Genome Browser, execpt for all of the
interactivity.plotTracks(trackList, from=NULL, to=NULL, ..., sizes=NULL,
panel.only=FALSE, extend.right=0, extend.left=0, title.width=NULL,
add=FALSE, main, cex.main=2, fontface.main=2, col.main="black",
margin=6, chromosome=NULL, innerMargin=3)
GdObject
. The tracks will all be drawn to the
same genomic coordinates, either as defined by the from
and
to
arguments if supplied, or by the maximum range across all
individual items in the list.to
cannot be
larger than from
. If NULL
, the plotting ranges are
derived from the individual tracks. See extend.left
and
extend.right
below for the definition of the final plotting
ranges.settings
for details on display
parameters.trackList
, or NULL
to
auto-detect the most appropriate vertical size proportions.panel.only==TRUE
.from-extend.left
to
to+extend.right
.imageMap
slot, along with the additional
ImageMap
object titles
containing information about the
title panels. The layout of the individual tracks is highly customizable though so
called "display parameters". See settings
for details.
While plotting a track, the software automatically computes HTML image
map coordinates based on the current graphics device. These
coordinates as well as the associated annotation information can later
be used to embed images of the plots in semi-interactive HTML
pages. See ImageMap
for details.
GdObject
ImageMap
RangeTrack
StackedTrack
## Create some tracks to plot
st <- c(2000000, 2070000, 2100000, 2160000)
ed <- c(2050000, 2130000, 2150000, 2170000)
str <- c("-", "+", "-", "-")
gr <- c("Group1","Group2","Group1", "Group3")
annTrack <- AnnotationTrack(start=st, end=ed, strand=str, chromosome=7,
genome="hg19", feature="test", group=gr,
id=paste("annTrack item", 1:4),
name="annotation track foo",
stacking="squish")
ax <- GenomeAxisTrack()
dt <- DataTrack(start=seq(min(st), max(ed), len=10), width=18000,
data=matrix(runif(40), nrow=4), genome="hg19", chromosome=7,
type="histogram", name="data track bar")
## Now plot the tracks
res <- plotTracks(list(ax, annTrack, dt))
## Plot only a subrange
res <- plotTracks(list(ax, annTrack, dt), from=2080000, to=2156000)
## Extend plotting ranges
res <- plotTracks(list(ax, annTrack, dt), extend.left=200000, extend.right=200000)
## Add a header
res <- plotTracks(list(ax, annTrack, dt), main="A GenomGraphs plot",
col.main="darkgray")
## Change vertical size and title width
res <- plotTracks(list(ax, annTrack, dt), sizes=c(1,1,5))
names(annTrack) <- "foo"
res <- plotTracks(list(ax, annTrack), title.width=0.6)
## Adding and lattice like plots
library(grid)
grid.newpage()
pushViewport(viewport(height=0.5, y=1, just="top"))
grid.rect()
plotTracks(annTrack, add=TRUE)
popViewport(1)
pushViewport(viewport(height=0.5, y=0, just="bottom"))
grid.rect()
plotTracks(dt, add=TRUE)
popViewport(1)
## Not run:
# library(lattice)
# myPanel <- function(x, ...) plotTracks(annTrack, panel.only=TRUE,
# from=min(x), to=max(x), shape="box")
# a <- seq(1900000, 2250000, len=40)
# xyplot(b~a|c, data.frame(a=a, b=1, c=cut(a, 4)), panel=myPanel,
# scales=list(x="free"))
# ## End(Not run)
Run the code above in your browser using DataLab