Save tmap to a file. This can be either a static plot (e.g. png) or an interactive map (html).
Usage
tmap_save(
tm = NULL,
filename = NA,
device = NULL,
width = NA,
height = NA,
units = NA,
dpi = NA,
outer.margins = NA,
asp = NULL,
scale = NA,
insets_tm = NULL,
insets_vp = NULL,
add.titles = TRUE,
in.iframe = FALSE,
selfcontained = !in.iframe,
verbose = NULL,
...
)Arguments
- tm
tmap object
- filename
filename including extension, and optionally the path. The extensions pdf, eps, svg, wmf (Windows only), png, jpg, bmp, tiff, and html are supported. If the extension is missing, the file will be saved as a static plot in
"plot"mode and as an interactive map (html) in another mode. The default format for static plots is png, but this can be changed using the option"output.format"intmap_options(). IfNA(the default), the file is saved as "tmap01" in the default format, and the number incremented if the file already exists.- device
graphic device to use. Either a device function (e.g.,
pngorcairo_pdf) or a text indicating selected graphic device: "pdf", "eps", "svg", "wmf" (Windows only), "png", "jpg", "bmp", "tiff". IfNULL, the graphic device is guessed based on thefilenameargument.- height, width
The dimensions of the plot (not applicable for html files). Units are set with the argument
units. If one of them is not specified, this is calculated using the formula asp = width / height, where asp is the estimated aspect ratio of the map. If both are missing, they are set such thatwidth * heightis equal to the option"output.size"intmap_options(). This is by default 49, meaning that is the map is a square (so aspect ratio of 1) both width and height are set to 7.- units
units for width and height (
"in","cm", or"mm"). By default, pixels ("px") are used if either width or height is set to a value greater than 50. Else, the units are inches ("in").- dpi
dots per inch. Only applicable for raster graphics. By default it is set to 300, but this can be changed using the option
"output.dpi"intmap_options().- outer.margins
overrides the outer.margins argument of
tm_options()(unless set toNA)- asp
if specified, it overrides the asp argument of
tm_options(). Tip: set to0if map frame should be placed on the edges of the image.- scale
overrides the scale argument of
tm_options()(unless set toNA)- insets_tm
tmap object of an inset map, or a list of tmap objects of multiple inset maps. The number of tmap objects should be equal to the number of viewports specified with
insets_vp.- insets_vp
viewportof an inset map, or a list ofviewports of multiple inset maps. The number of viewports should be equal to the number of tmap objects specified withinsets_tm.- add.titles
add titles to leaflet object.
- in.iframe
should an interactive map be saved as an iframe? If so, two HTML files will be saved; one small parent HTML file with the iframe container, and one large child HTML file with the actual widget. See
widgetframe::saveWidgetframe()for details. By defaultFALSE, which means that one large HTML file is saved (see saveWidget()).- selfcontained
when an interactive map is saved, should the resources (e.g. JavaScript libraries) be contained in the HTML file? If
FALSE, they are placed in an adjacent directory (see alsohtmlwidgets::saveWidget()). Note that the HTML file will often still be large whenselfcontained = FALSE, since the map data (polygons and popups), which are also contained in the HTML file, usually take more space then the map resources.- verbose
Deprecated. It is now controlled by the tmap option
show.messages(seetmap_options())- ...
additional arguments passed on to the underlying output function (see Details). For interactive (html) maps these are passed to
htmlwidgets::saveWidget()orwidgetframe::saveWidgetframe(). For static maps they are passed to the graphic device; the most useful are:colormodel(pdf, eps)Color model of the output. The default is
"srgb"; usecolormodel = "cmyk"for print workflows that require CMYK. SeegrDevices::pdf().compression(tiff)Compression method, e.g.
"lzw","zip", or"jpeg". The default"none"can produce very large files; the lossless"lzw"or"zip"is usually a good choice for publication.quality(jpg)JPEG quality, from
0to100(default75).bg(all)Background color. Use
bg = "transparent"for a transparent background (png, tiff, and svg support transparency; jpg and bmp do not).pointsize(all)Default point size of text, which scales the text drawn by the device.
family(pdf, eps, svg),fonts(pdf, eps)Font family, and fonts to embed in the file.
antialias(png, jpg, bmp, tiff)Type of anti-aliasing, e.g.
"default","none","gray", or"subpixel". This only applies to cairo-type devices.pngalways uses cairo (type = "cairo-png"), butjpg,bmp, andtiffuse the platform default device type, so on a build without cairo supportantialiasis ignored for those formats.
Details
Extra arguments (...) are passed on to the function that writes the
output. For interactive (html) maps this is htmlwidgets::saveWidget(), or
widgetframe::saveWidgetframe() when in.iframe = TRUE. For static maps it
is the graphic device: the function supplied to device, or, when
device = NULL, the default device for the file extension:
grDevices::pdf() ("pdf"), grDevices::postscript() ("eps"),
grDevices::svg() ("svg"), grDevices::png() ("png"),
grDevices::jpeg() ("jpg"/"jpeg"), grDevices::bmp() ("bmp"), and
grDevices::tiff() ("tiff"). The most useful device arguments are listed
under ....
Note that filename, width, and height are always set by tmap_save,
as are res and units for the raster formats (png, jpg, bmp, tiff); these
cannot be overridden through .... Use the dpi, width, height, and
units arguments of tmap_save instead.
Examples
if (FALSE) { # \dontrun{
data(NLD_muni, NLD_prov)
m <- tm_shape(NLD_muni) +
tm_fill(col="population", convert2density=TRUE,
style="kmeans",
title=expression("Population (per " * km^2 * ")")) +
tm_borders("black", alpha=.5) +
tm_shape(NLD_prov) +
tm_borders("grey25", lwd=2) +
tm_style("classic") +
tm_format("NLD", inner.margins = c(.02, .15, .06, .15)) +
tm_scalebar(position = c("left", "bottom")) +
tm_compass(position=c("right", "bottom"))
tmap_save(m, "choropleth.png", height = 7) # height interpreted in inches
tmap_save(m, "choropleth_icon.png", height = 100, scale = .1) # height interpreted in pixels
data(World)
m2 <- tm_shape(World) +
tm_fill("well_being", id="name", title="Well-being") +
tm_format("World")
# save image
tmap_save(m2, "World_map.png", width=1920, height=1080, asp=0)
# cut left inner margin to make sure Antarctica is snapped to frame
tmap_save(m2 + tm_layout(inner.margins = c(0, -.1, 0.05, 0.01)),
"World_map2.png", width=1920, height=1080, asp=0)
# save interactive plot
tmap_save(m2, "World_map.html")
} # }
