svglite now uses systemfonts for text metric calculations and font family lookup.
svglite now directly encodes raster data into png instead of rendering it through cairo. If the provided raster is smaller than the final requested size it will be resized.
SVG’s can now get a top-level id so that style definitions doesn’t spill into the surrounding HTML (#91)
Dimensions are now encoded into the top-level
<svg> tag (#90)
Clip defs are now only written if they don’t already exist (#110)
Clipping is now defined with outer groups instead of on each element (#109)
svglite now uses cpp11 instead of Rcpp (#100)
svgz output is now supported natively (#6)
Text adjustments are now encoded in css where possible (#107)
The use of textLength CSS property can now be turned of (#118)
web font imports can now be given when creating an svg (#108)
Add scaling argument to devices to control line-width and text scaling (#115)
Improvements to reproducibility of generated SVGs: Negative zeros are now treated as positive, and the clip ID are now generated from truncated elements.
svglite now uses the
polygon SVG element. This ensures that polygons are properly closed (#82).
Text metrics are now correctly computed for Unicode characters in plotmath expressions (#81).
The device functions gain
Two new vignettes:
vignette("scaling"). The vignette on fonts explains in detail how to use the new fonts arguments and why. The vignette on scaling goes over scaling issues, e.g. when embedding svglite outputs in a web page.
stringSVG() device function for quick testing.
Clip paths now get a unique identifier to avoid collisions when multiple plots are included in a document (#67).
Raster graphics are now correctly cropped (#64) and handle transparency properly.
The dimensions of text fields are now hardcoded in the SVGs to prevent alignment issues.
Intermediate outputs are always valid SVG (#53).
Use raster test compatible with older versions of R.
Fix incorrect device size (#50).
svglite is fully featured svg graphics device that works on all platforms, forked from RSvgDevice. It supports all graphics device features:
Transparent colours are now generated with
rgba() rather than using
fill-opacity styles (#16). NA fills and colours are translated to “none”.
Rasters are supported by embedding base64-encoded pngs in a data url (#2).
We also made a few other tweaks to the rendered SVG:
viewBox attribute of
<svg> is set (not
height): I’m reasonably certain this makes it easier to use in more places (#12).
Default styling properties are specified in a global
<style> element: this reduces overall file size, and should make it easier to re-style the output for your own needs.
You can now only produce a single page per device - previously this worked but produced incorrect output (#5).
Output no longer contains dummy
<desc> element (#4)
And added some helper functions: