diff --git a/articles/fonts.html b/articles/fonts.html index c7bc206..023b22c 100644 --- a/articles/fonts.html +++ b/articles/fonts.html @@ -169,7 +169,7 @@

System font aliases
-svglite("Rplots.svg", system_fonts = list(sans = "Arial Unicode MS"))
+svglite("Rplots.svg", system_fonts = list(sans = "Arial Unicode MS"))
 plot.new()
 text(0.5, 0.5, "正規分布")
 dev.off()
@@ -210,7 +210,7 @@

User font aliases= list(plain = serif_file) ) -ss <- svglite("plot.svg", user_fonts = fonts) +ss <- svglite("plot.svg", user_fonts = fonts) plot.new() text(0.5, 0.5, "Sans Plain text") text(0.2, 0.2, "Sans Italic text", font = 3) @@ -241,7 +241,7 @@

User font aliasesfonts$symbol$symbol <- fontquiver::font_symbol("Symbola") str(fonts, 2) -svglite("reproducible.svg", user_fonts = fonts) +svglite("reproducible.svg", user_fonts = fonts) plot(1:10) dev.off() diff --git a/index.html b/index.html index 28cb358..c7dfa10 100644 --- a/index.html +++ b/index.html @@ -108,7 +108,7 @@

Motivation

Speed

-

svglite() is considerably faster than svg(). If you are rendering SVGs dynamically to serve over the web this can be quite important:

+

svglite() is considerably faster than svg(). If you are rendering SVGs dynamically to serve over the web this can be quite important:

 library(svglite)
 
@@ -118,7 +118,7 @@ 

Speed tmp2 <- tempfile() svglite_test <- function() { - svglite(tmp1) + svglite(tmp1) plot(x, y) dev.off() } @@ -138,7 +138,7 @@

Speed

File size

-

Another point with high relevance when serving SVGs over the web is the size. svglite() produces much smaller files

+

Another point with high relevance when serving SVGs over the web is the size. svglite() produces much smaller files

 # svglite
 fs::file_size(tmp1)
@@ -150,7 +150,7 @@ 

File size (or ".svg.gz") extension.

 tmp3 <- tempfile(fileext = ".svgz")
-svglite(tmp3)
+svglite(tmp3)
 plot(x, y)
 invisible(dev.off())
 
@@ -161,7 +161,7 @@ 

File size

Editability

-

One of the main reasons for the size difference between the size of the output of svglite() and svg() is the fact that svglite() encodes text as styled <text> elements, whereas svg() converts the glyphs to polygons and renders these. The latter approach means that the output of svg() does not require the font to be present on the system that displays the SVG but makes it more or less impossible to edit the text after the fact. svglite focuses on providing maximal editability of the output, so that you can open up the result in a vector drawing program such as Inkscape or Illustrator and polish the output if you so choose.

+

One of the main reasons for the size difference between the size of the output of svglite() and svg() is the fact that svglite() encodes text as styled <text> elements, whereas svg() converts the glyphs to polygons and renders these. The latter approach means that the output of svg() does not require the font to be present on the system that displays the SVG but makes it more or less impossible to edit the text after the fact. svglite focuses on providing maximal editability of the output, so that you can open up the result in a vector drawing program such as Inkscape or Illustrator and polish the output if you so choose.

Font support diff --git a/news/index.html b/news/index.html index f993415..7f9ce18 100644 --- a/news/index.html +++ b/news/index.html @@ -60,6 +60,8 @@

svglite (development version)

  • Windows: use libpng included with Rtools on R 4.2 and up.
  • +
  • Add support for dev.capabilities() +

svglite 2.1.1

CRAN release: 2023-01-10

@@ -84,7 +86,7 @@

svglite 2.0.0

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)

  • Starting a new page creates a new file if the filename supports it (#98, @vandenman).

  • -
  • The inline devices now defaults to the same dimensions as svglite() (#89)

  • +
  • The inline devices now defaults to the same dimensions as svglite() (#89)

  • 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)

  • @@ -93,7 +95,7 @@

    svglite 2.0.0

    The use of textLength CSS property can now be turned off (#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)

  • -
  • svg files that are being written are now only valid at all times if always_valid is set to TRUE in the svglite() call.

  • +
  • svg files that are being written are now only valid at all times if always_valid is set to TRUE in the svglite() call.

  • svglite now guards against attempts at writing to the device before a new page has been requested (#126)

  • diff --git a/pkgdown.yml b/pkgdown.yml index d32d1a4..96db33b 100644 --- a/pkgdown.yml +++ b/pkgdown.yml @@ -4,7 +4,7 @@ pkgdown_sha: ~ articles: fonts: fonts.html scaling: scaling.html -last_built: 2023-10-11T07:13Z +last_built: 2023-10-11T07:18Z urls: reference: https://svglite.r-lib.org/reference article: https://svglite.r-lib.org/articles diff --git a/reference/editSVG.html b/reference/editSVG.html index 8db72d0..c6e9e81 100644 --- a/reference/editSVG.html +++ b/reference/editSVG.html @@ -74,7 +74,7 @@

    Argumentssvglite.

    +

    Other arguments passed on to svglite.

    height, width
    diff --git a/reference/font_face.html b/reference/font_face.html index 0495166..e97fd4b 100644 --- a/reference/font_face.html +++ b/reference/font_face.html @@ -68,7 +68,7 @@

    Webfonts in SVG and HTML can either be specified manually using the @font-face at-rule, or imported from e.g. Google Fonts using the @import at-rule. font_face() helps you create a valid @font-face block for the -web_fonts argument in svglite() and svgstring() functions.

    +web_fonts argument in svglite() and svgstring() functions.

    diff --git a/reference/htmlSVG.html b/reference/htmlSVG.html index c4d7932..4ec2c03 100644 --- a/reference/htmlSVG.html +++ b/reference/htmlSVG.html @@ -77,7 +77,7 @@

    Argumentssvglite.

    +

    Other arguments passed on to svglite.

    diff --git a/reference/stringSVG.html b/reference/stringSVG.html index 4cf88e5..8d98ce7 100644 --- a/reference/stringSVG.html +++ b/reference/stringSVG.html @@ -77,7 +77,7 @@

    Argumentssvglite.

    +

    Other arguments passed on to svglite.

    diff --git a/reference/svglite-package.html b/reference/svglite-package.html new file mode 100644 index 0000000..9452f85 --- /dev/null +++ b/reference/svglite-package.html @@ -0,0 +1,106 @@ + +svglite: An 'SVG' Graphics Device — svglite-package • svglite + Skip to content + + +
    +
    +
    + +
    +

    +

    A graphics device for R that produces 'Scalable Vector Graphics'. 'svglite' is a fork of the older 'RSvgDevice' package.

    +
    + + + +
    +

    Author

    +

    Maintainer: Thomas Lin Pedersen thomas.pedersen@posit.co (ORCID)

    +

    Authors:

    Other contributors:

    • Tony Plate (Early line dashing code) [contributor]

    • +
    • David Gohel (Line dashing code and early raster code) [contributor]

    • +
    • Yixuan Qiu (Improved styles; polypath implementation) [contributor]

    • +
    • Håkon Malmedal (Opacity code) [contributor]

    • +
    • Posit, PBC [copyright holder, funder]

    • +
    + +
    + + +
    + + diff --git a/reference/svglite.html b/reference/svglite.html index d0d5cc2..4f1e1df 100644 --- a/reference/svglite.html +++ b/reference/svglite.html @@ -67,7 +67,7 @@

    Usage

    -
    svglite(
    +    
    svglite(
       filename = "Rplot%03d.svg",
       width = 10,
       height = 8,
    @@ -203,8 +203,8 @@ 

    Author<

    Examples

    # Save to file
    -svglite(tempfile("Rplots.svg"))
    -plot(1:11, (-5:5)^2, type = 'b', main = "Simple Example")
    +svglite(tempfile("Rplots.svg"))
    +plot(1:11, (-5:5)^2, type = "b", main = "Simple Example")
     dev.off()
     #> agg_png 
     #>       2 
    diff --git a/reference/svgstring.html b/reference/svgstring.html
    index e8f8c68..909149d 100644
    --- a/reference/svgstring.html
    +++ b/reference/svgstring.html
    @@ -61,7 +61,7 @@ 
         
    -

    This is a variation on svglite that makes it easy to access +

    This is a variation on svglite that makes it easy to access the current value as a string.

    @@ -163,16 +163,18 @@

    Value

    Details

    -

    See svglite() documentation for information about +

    See svglite() documentation for information about specifying fonts.

    Examples

    -
    s <- svgstring(); s()
    +    
    s <- svgstring()
    +s()
     #> 
     
    -plot.new(); s();
    +plot.new()
    +s()
     #> <?xml version='1.0' encoding='UTF-8' ?>
     #> <svg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' class='svglite' width='720.00pt' height='576.00pt' viewBox='0 0 720.00 576.00'>
     #> <defs>
    @@ -198,7 +200,8 @@ 

    Examples#> <g clip-path='url(#cpMC4wMHw3MjAuMDB8MC4wMHw1NzYuMDA=)'> #> </g> #> </svg> -text(0.5, 0.5, "Hi!"); s() +text(0.5, 0.5, "Hi!") +s() #> <?xml version='1.0' encoding='UTF-8' ?> #> <svg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' class='svglite' width='720.00pt' height='576.00pt' viewBox='0 0 720.00 576.00'> #> <defs> @@ -269,37 +272,31 @@

    Examples#> </clipPath> #> </defs> #> <g clip-path='url(#cpNTkuMDR8Njg5Ljc2fDU5LjA0fDUwMi41Ng==)'> -#> <circle cx='666.40' cy='219.56' r='2.70' style='stroke-width: 0.75;' /> -#> <circle cx='82.40' cy='412.97' r='2.70' style='stroke-width: 0.75;' /> -#> <circle cx='589.79' cy='486.13' r='2.70' style='stroke-width: 0.75;' /> -#> <circle cx='285.75' cy='75.47' r='2.70' style='stroke-width: 0.75;' /> -#> <circle cx='450.27' cy='339.97' r='2.70' style='stroke-width: 0.75;' /> +#> <circle cx='666.40' cy='187.59' r='2.70' style='stroke-width: 0.75;' /> +#> <circle cx='405.08' cy='202.88' r='2.70' style='stroke-width: 0.75;' /> +#> <circle cx='488.17' cy='158.01' r='2.70' style='stroke-width: 0.75;' /> +#> <circle cx='325.63' cy='75.47' r='2.70' style='stroke-width: 0.75;' /> +#> <circle cx='82.40' cy='486.13' r='2.70' style='stroke-width: 0.75;' /> #> </g> #> <g clip-path='url(#cpMC4wMHw3MjAuMDB8MC4wMHw1NzYuMDA=)'> -#> <line x1='169.19' y1='502.56' x2='610.86' y2='502.56' style='stroke-width: 0.75;' /> -#> <line x1='169.19' y1='502.56' x2='169.19' y2='509.76' style='stroke-width: 0.75;' /> -#> <line x1='279.61' y1='502.56' x2='279.61' y2='509.76' style='stroke-width: 0.75;' /> -#> <line x1='390.02' y1='502.56' x2='390.02' y2='509.76' style='stroke-width: 0.75;' /> -#> <line x1='500.44' y1='502.56' x2='500.44' y2='509.76' style='stroke-width: 0.75;' /> -#> <line x1='610.86' y1='502.56' x2='610.86' y2='509.76' style='stroke-width: 0.75;' /> -#> <text x='169.19' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-2.0</text> -#> <text x='279.61' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-1.5</text> -#> <text x='390.02' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-1.0</text> -#> <text x='500.44' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-0.5</text> -#> <text x='610.86' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.0</text> -#> <line x1='59.04' y1='474.36' x2='59.04' y2='107.50' style='stroke-width: 0.75;' /> -#> <line x1='59.04' y1='474.36' x2='51.84' y2='474.36' style='stroke-width: 0.75;' /> -#> <line x1='59.04' y1='400.99' x2='51.84' y2='400.99' style='stroke-width: 0.75;' /> -#> <line x1='59.04' y1='327.61' x2='51.84' y2='327.61' style='stroke-width: 0.75;' /> -#> <line x1='59.04' y1='254.24' x2='51.84' y2='254.24' style='stroke-width: 0.75;' /> -#> <line x1='59.04' y1='180.87' x2='51.84' y2='180.87' style='stroke-width: 0.75;' /> -#> <line x1='59.04' y1='107.50' x2='51.84' y2='107.50' style='stroke-width: 0.75;' /> -#> <text transform='translate(41.76,474.36) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-1.0</text> -#> <text transform='translate(41.76,400.99) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-0.5</text> -#> <text transform='translate(41.76,327.61) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.0</text> -#> <text transform='translate(41.76,254.24) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.5</text> -#> <text transform='translate(41.76,180.87) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>1.0</text> -#> <text transform='translate(41.76,107.50) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>1.5</text> +#> <line x1='178.40' y1='502.56' x2='559.72' y2='502.56' style='stroke-width: 0.75;' /> +#> <line x1='178.40' y1='502.56' x2='178.40' y2='509.76' style='stroke-width: 0.75;' /> +#> <line x1='369.06' y1='502.56' x2='369.06' y2='509.76' style='stroke-width: 0.75;' /> +#> <line x1='559.72' y1='502.56' x2='559.72' y2='509.76' style='stroke-width: 0.75;' /> +#> <text x='178.40' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-1.0</text> +#> <text x='369.06' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='23.43px' lengthAdjust='spacingAndGlyphs'>-0.5</text> +#> <text x='559.72' y='528.48' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.0</text> +#> <line x1='59.04' y1='422.33' x2='59.04' y2='84.68' style='stroke-width: 0.75;' /> +#> <line x1='59.04' y1='422.33' x2='51.84' y2='422.33' style='stroke-width: 0.75;' /> +#> <line x1='59.04' y1='337.91' x2='51.84' y2='337.91' style='stroke-width: 0.75;' /> +#> <line x1='59.04' y1='253.50' x2='51.84' y2='253.50' style='stroke-width: 0.75;' /> +#> <line x1='59.04' y1='169.09' x2='51.84' y2='169.09' style='stroke-width: 0.75;' /> +#> <line x1='59.04' y1='84.68' x2='51.84' y2='84.68' style='stroke-width: 0.75;' /> +#> <text transform='translate(41.76,422.33) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.0</text> +#> <text transform='translate(41.76,337.91) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.2</text> +#> <text transform='translate(41.76,253.50) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.4</text> +#> <text transform='translate(41.76,169.09) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.6</text> +#> <text transform='translate(41.76,84.68) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='19.09px' lengthAdjust='spacingAndGlyphs'>0.8</text> #> <polygon points='59.04,502.56 689.76,502.56 689.76,59.04 59.04,59.04 ' style='stroke-width: 0.75;' /> #> <text x='374.40' y='557.28' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='53.09px' lengthAdjust='spacingAndGlyphs'>rnorm(5)</text> #> <text transform='translate(12.96,280.80) rotate(-90)' text-anchor='middle' style='font-size: 12.00px; font-family: "Liberation Sans";' textLength='53.09px' lengthAdjust='spacingAndGlyphs'>rnorm(5)</text> diff --git a/reference/xmlSVG.html b/reference/xmlSVG.html index 95e4ad7..ba5eed7 100644 --- a/reference/xmlSVG.html +++ b/reference/xmlSVG.html @@ -74,7 +74,7 @@

    Argumentssvglite.

    +

    Other arguments passed on to svglite.

    standalone
    diff --git a/search.json b/search.json index 9e0f54f..dbb00a5 100644 --- a/search.json +++ b/search.json @@ -1 +1 @@ -[{"path":[]},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"our-pledge","dir":"","previous_headings":"","what":"Our Pledge","title":"Contributor Covenant Code of Conduct","text":"members, contributors, leaders pledge make participation community harassment-free experience everyone, regardless age, body size, visible invisible disability, ethnicity, sex characteristics, gender identity expression, level experience, education, socio-economic status, nationality, personal appearance, race, caste, color, religion, sexual identity orientation. pledge act interact ways contribute open, welcoming, diverse, inclusive, healthy community.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"our-standards","dir":"","previous_headings":"","what":"Our Standards","title":"Contributor Covenant Code of Conduct","text":"Examples behavior contributes positive environment community include: Demonstrating empathy kindness toward people respectful differing opinions, viewpoints, experiences Giving gracefully accepting constructive feedback Accepting responsibility apologizing affected mistakes, learning experience Focusing best just us individuals, overall community Examples unacceptable behavior include: use sexualized language imagery, sexual attention advances kind Trolling, insulting derogatory comments, personal political attacks Public private harassment Publishing others’ private information, physical email address, without explicit permission conduct reasonably considered inappropriate professional setting","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"enforcement-responsibilities","dir":"","previous_headings":"","what":"Enforcement Responsibilities","title":"Contributor Covenant Code of Conduct","text":"Community leaders responsible clarifying enforcing standards acceptable behavior take appropriate fair corrective action response behavior deem inappropriate, threatening, offensive, harmful. Community leaders right responsibility remove, edit, reject comments, commits, code, wiki edits, issues, contributions aligned Code Conduct, communicate reasons moderation decisions appropriate.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"scope","dir":"","previous_headings":"","what":"Scope","title":"Contributor Covenant Code of Conduct","text":"Code Conduct applies within community spaces, also applies individual officially representing community public spaces. Examples representing community include using official e-mail address, posting via official social media account, acting appointed representative online offline event.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"enforcement","dir":"","previous_headings":"","what":"Enforcement","title":"Contributor Covenant Code of Conduct","text":"Instances abusive, harassing, otherwise unacceptable behavior may reported community leaders responsible enforcement codeofconduct@posit.co. complaints reviewed investigated promptly fairly. community leaders obligated respect privacy security reporter incident.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"enforcement-guidelines","dir":"","previous_headings":"","what":"Enforcement Guidelines","title":"Contributor Covenant Code of Conduct","text":"Community leaders follow Community Impact Guidelines determining consequences action deem violation Code Conduct:","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"id_1-correction","dir":"","previous_headings":"Enforcement Guidelines","what":"1. Correction","title":"Contributor Covenant Code of Conduct","text":"Community Impact: Use inappropriate language behavior deemed unprofessional unwelcome community. Consequence: private, written warning community leaders, providing clarity around nature violation explanation behavior inappropriate. public apology may requested.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"id_2-warning","dir":"","previous_headings":"Enforcement Guidelines","what":"2. Warning","title":"Contributor Covenant Code of Conduct","text":"Community Impact: violation single incident series actions. Consequence: warning consequences continued behavior. interaction people involved, including unsolicited interaction enforcing Code Conduct, specified period time. includes avoiding interactions community spaces well external channels like social media. Violating terms may lead temporary permanent ban.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"id_3-temporary-ban","dir":"","previous_headings":"Enforcement Guidelines","what":"3. Temporary Ban","title":"Contributor Covenant Code of Conduct","text":"Community Impact: serious violation community standards, including sustained inappropriate behavior. Consequence: temporary ban sort interaction public communication community specified period time. public private interaction people involved, including unsolicited interaction enforcing Code Conduct, allowed period. Violating terms may lead permanent ban.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"id_4-permanent-ban","dir":"","previous_headings":"Enforcement Guidelines","what":"4. Permanent Ban","title":"Contributor Covenant Code of Conduct","text":"Community Impact: Demonstrating pattern violation community standards, including sustained inappropriate behavior, harassment individual, aggression toward disparagement classes individuals. Consequence: permanent ban sort public interaction within community.","code":""},{"path":"https://svglite.r-lib.org/CODE_OF_CONDUCT.html","id":"attribution","dir":"","previous_headings":"","what":"Attribution","title":"Contributor Covenant Code of Conduct","text":"Code Conduct adapted Contributor Covenant, version 2.1, available https://www.contributor-covenant.org/version/2/1/code_of_conduct.html. Community Impact Guidelines inspired [Mozilla’s code conduct enforcement ladder][https://github.com/mozilla/inclusion]. answers common questions code conduct, see FAQ https://www.contributor-covenant.org/faq. Translations available https://www.contributor-covenant.org/translations.","code":""},{"path":"https://svglite.r-lib.org/articles/fonts.html","id":"system-font-aliases","dir":"Articles","previous_headings":"","what":"System font aliases","title":"Specifying fonts","text":"system_fonts takes named list font families argument. names typically correspond standard R faces can also alias non-standard families (though less useful): need support non-latin characters, choose fonts good Unicode coverage. “Arial Unicode MS” sans serif font good coverage available macOS Windows systems (latter, MS Office installed). Note font support kerning bold italic faces. Noto fontset provided Google well Han Sans family Adobe excellent coverage may available time rendering. can concern distribute SVG files Internet.","code":"fonts <- list( sans = \"Helvetica\", mono = \"Consolas\", `Times New Roman` = \"DejaVu Serif\" ) ss <- svgstring(system_fonts = fonts) plot(1:10) text(0.8, 0.8, \"Some text\", family = \"mono\") text(0.2, 0.2, \"Other text\", family = \"Times New Roman\") dev.off() ss() svglite(\"Rplots.svg\", system_fonts = list(sans = \"Arial Unicode MS\")) plot.new() text(0.5, 0.5, \"正規分布\") dev.off()"},{"path":"https://svglite.r-lib.org/articles/fonts.html","id":"user-font-aliases","dir":"Articles","previous_headings":"","what":"User font aliases","title":"Specifying fonts","text":"addition system fonts, can also provide fonts necessarily installed system (.e., fonts live user space). main reason generate reproducible SVG files different platforms can different versions font thus produce different text metrics. user_fonts arguments takes either paths font files, fonts fontquiver package, list specifies alias. Whereas system_fonts gets named list families argument, user_fonts takes named tree lists families (sans, serif, mono symbol) faces (plain, italic, bold, bolditalic, symbol): can also control font gets written font-family fields SVGs supplying list containing alias file elements: fontquiver fonts particularly useful creating reproducible SVG files. vdiffr package uses svglite fontquiver fonts create visual unit tests reliably across platforms. Liberation fontset appropriate usage features 12 combinations standard R families faces. addition fontquiver provides Symbola symbol font. function fontquiver::font_families() produces list appropriate structure can directly supplied svglite:","code":"# Using ttf files from fontquiver here, but it could be any ttf some_file <- fontquiver::font(\"Liberation\", \"Sans\", \"Regular\")$ttf other_file <- fontquiver::font(\"Liberation\", \"Sans\", \"Italic\")$ttf serif_file <- fontquiver::font(\"Liberation\", \"serif\", \"Italic\")$ttf # The outer named list contains families while the inner named list # contains faces: fonts <- list( sans = list( plain = some_file, italic = other_file ), serif = list(plain = serif_file) ) ss <- svglite(\"plot.svg\", user_fonts = fonts) plot.new() text(0.5, 0.5, \"Sans Plain text\") text(0.2, 0.2, \"Sans Italic text\", font = 3) text(0.8, 0.8, \"Serif text\", family = \"serif\") dev.off() file_with_alias <- list(alias = \"Foobar Font\", file = other_file) fonts <- list(sans = list(plain = file_with_alias)) ss <- svgstring(user_fonts = fonts) plot(1:10) text(0.5, 0.5, \"Sans text\") dev.off() ss() fonts <- fontquiver::font_families(\"Liberation\") fonts$symbol$symbol <- fontquiver::font_symbol(\"Symbola\") str(fonts, 2) svglite(\"reproducible.svg\", user_fonts = fonts) plot(1:10) dev.off()"},{"path":"https://svglite.r-lib.org/articles/fonts.html","id":"debugging-font-matching","dir":"Articles","previous_headings":"","what":"Debugging font matching","title":"Specifying fonts","text":"systemfonts package used match font family names fonts installed system. systemfonts always return valid font, requested font badly misspelled missing, default returned. test expected font matched can use match_font() font_info() functions systemfonts:","code":"systemfonts::match_font(\"Helvetica\") #> $path #> [1] \"/usr/share/fonts/opentype/urw-base35/NimbusSans-Regular.otf\" #> #> $index #> [1] 0 #> #> $features #> NULL systemfonts::font_info(\"Helvetica\", bold = TRUE) #> path index #> 1 /usr/share/fonts/opentype/urw-base35/NimbusSans-Bold.otf 0 #> family style italic bold monospace weight width kerning color #> 1 Nimbus Sans Bold FALSE TRUE FALSE bold normal FALSE FALSE #> scalable vertical n_glyphs n_sizes n_charmaps #> 1 TRUE FALSE 855 0 4 #> bbox max_ascend max_descend #> 1 -2.25000, 12.82812, -3.68750, 12.84375 8.75 -3.25 #> max_advance_width max_advance_height lineheight underline_pos #> 1 13.48438 14.40625 14.40625 -1.859375 #> underline_size #> 1 0.828125"},{"path":"https://svglite.r-lib.org/articles/scaling.html","id":"scaling-svg-outputs","dir":"Articles","previous_headings":"","what":"Scaling SVG outputs","title":"Scaling Issues","text":"SVG files produced svglite include width height properties. deliberate choice intended make easier fit fluidly SVG figure enclosing container. scaling straightforward requires understanding viewBox SVG attribute included SVGs produced svglite. property defines aspect ratio plot (well user coordinate system, see next section).","code":""},{"path":"https://svglite.r-lib.org/articles/scaling.html","id":"fluid-scaling","dir":"Articles","previous_headings":"Scaling SVG outputs","what":"Fluid scaling","title":"Scaling Issues","text":"viewBox determined width height arguments svglite’s device functions (10’’ x 8’’ default). Although dimensions supplied inches, viewBox’s user coordinate system completely unit agnostic. main effect thus determine aspect ratio. Since dimensions provided, dimensions enclosing container used instead SVG rescaled fit container (although Internet Explorer currently requires CSS tricks get behaviour, see https://tympanus.net/codrops/2014/08/19/making-svgs-responsive--css/). Aspect ratio preserved default figure scaled . details aspect ratio preserved can adjusted multiple ways via preserveAspectRatio attribute. See https://www.sarasoueidan.com/blog/svg-coordinate-systems/ information property. useful resource: https://css-tricks.com/scale-svg/","code":""},{"path":"https://svglite.r-lib.org/articles/scaling.html","id":"natural-scaling","dir":"Articles","previous_headings":"Scaling SVG outputs","what":"Natural scaling","title":"Scaling Issues","text":"Another strategy needed order scale figure make text within SVG consistent text surrounding web page. useful, instance, create consistent appearance HTML presentation. Since user coordinate system defined viewBox unitless, need map figure natural dimensions. ensure correspondence scale figure web page. mentioned , natural scale svglite’s figures points determined width height arguments supply device functions (10’’ x 8’’ default). Although dimensions specified inches, coordinate system scaled points. Counting 72 points per inch, default SVG surface thus 720 x 576 pt. Note CSS standard defines 12pt equal 16px, default size text browsers. Since 12pt default text size svglite well, SVG scaled natural dimensions appear seamless web text 16px. text web page another size, compute scale factor adjust dimensions SVG accordingly. sum , displaying plot according natural dimensions requires providing user agent information lengths defined within SVG actually mean. several ways achieve . First can edit SVG enclose another pair tags defines height width. root element determines final dimensions figure. second way enclose figure
    tag appropriate dimensions let SVG figure rescale container (cf. section fluid scaling): Finally, can directly specify dimensions tag embedding figure. Note dimension attributes tags accept arbitrary units, supply dimensions pixels. Just multiply width height measured points factor 16/12:","code":"
    <\/div> "},{"path":[]},{"path":"https://svglite.r-lib.org/articles/scaling.html","id":"device-scaling","dir":"Articles","previous_headings":"Internal notes","what":"Device scaling","title":"Scaling Issues","text":"graphics devices, svglite scaled big points (1/72 inch) rather pica points (1/72.27 inch). Note LaTeX grid graphics system ggplot2 based, points refer pica points. Big points denoted LaTeX bp CSS pt. use latter notation. See https://tex.stackexchange.com//200968/19755 historical background units. conversion device units physical dimensions determined DevDesc parameter ipr. IPR stands inches per raster (native device coordinates sometimes called rasters R terminology) set 1/72 svglite. device’s physical dimensions set following DevDesc parameters (width height plot dimensions set user inches): default svglite plot surface thus 720 x 576 pt.","code":""},{"path":"https://svglite.r-lib.org/articles/scaling.html","id":"scaling-of-graphical-elements","dir":"Articles","previous_headings":"Internal notes","what":"Scaling of graphical elements","title":"Scaling Issues","text":"conventional fundamental line width (lwd = 1) correspond line width 1/96 inch svglite obeys convention. Also, like R graphics devices, svglite interprets point sizes directly big points (e.g. ps graphical parameter fontsize argument device functions). default font size 12pt. Text metrics computed systemfonts, uses freetype extract metrics glyph calculate string dimensions . Text metrics calculated 1000dpi based cex * ps font size. Base graphics system also makes use obscure cra parameter relatives (cin, cxy, csi). cra serves crude measure default character height width default fontsize provided device called (12pt svgilte). main effect parameter (specifically, height component) change relationship margin parameters mar/mai oma/omi. margins mar oma specified line units character height used measure line spacing convert margins measured lines physical margins. devices, cra[0] set 0.9 * pointsize cra[1] 1.2 * pointsize. parameters completely unused Grid graphics system.","code":""},{"path":"https://svglite.r-lib.org/articles/scaling.html","id":"svg-output","dir":"Articles","previous_headings":"Internal notes","what":"SVG output","title":"Scaling Issues","text":"SVG output sets viewBox (user coordinate system) values scaled big points. viewBox: width height set dd->right dd->bottom respectively (values determined user-supplied figure width height). Line width: 1 lwd equal 1/96 inch. svglite gets values scaled device coordinates (big points), line width multiplied 72/96. Text: gdtools returns metrics scaled big points transformation needed. need add px units work around rendering bug Firefox. Note viewBox set , pixel equals one unit user coordinate system thus actually represents big point.","code":""},{"path":"https://svglite.r-lib.org/authors.html","id":null,"dir":"","previous_headings":"","what":"Authors","title":"Authors and Citation","text":"Hadley Wickham. Author. Lionel Henry. Author. Thomas Lin Pedersen. Maintainer, author. T Jake Luciani. Author. Matthieu Decorde. Author. Vaudor Lise. Author. Tony Plate. Contributor. Early line dashing code David Gohel. Contributor. Line dashing code early raster code Yixuan Qiu. Contributor. Improved styles; polypath implementation Håkon Malmedal. Contributor. Opacity code . Copyright holder, funder.","code":""},{"path":"https://svglite.r-lib.org/authors.html","id":"citation","dir":"","previous_headings":"","what":"Citation","title":"Authors and Citation","text":"Wickham H, Henry L, Pedersen T, Luciani T, Decorde M, Lise V (2023). svglite: 'SVG' Graphics Device. https://svglite.r-lib.org, https://github.com/r-lib/svglite.","code":"@Manual{, title = {svglite: An 'SVG' Graphics Device}, author = {Hadley Wickham and Lionel Henry and Thomas Lin Pedersen and T Jake Luciani and Matthieu Decorde and Vaudor Lise}, year = {2023}, note = {https://svglite.r-lib.org, https://github.com/r-lib/svglite}, }"},{"path":"https://svglite.r-lib.org/index.html","id":"svglite-","dir":"","previous_headings":"","what":"An SVG Graphics Device","title":"An SVG Graphics Device","text":"svglite graphics device produces clean svg output, suitable use web, hand editing. Compared built-svg(), svglite produces smaller files, leaves text , making easier edit result creation. also supports multiple nice features embedding web fonts.","code":""},{"path":"https://svglite.r-lib.org/index.html","id":"installation","dir":"","previous_headings":"","what":"Installation","title":"An SVG Graphics Device","text":"svglite available CRAN using install.packages(\"svglite\"). can install development version github :","code":"# install.packages(\"pak\") pak::pak(\"r-lib/svglite\")"},{"path":"https://svglite.r-lib.org/index.html","id":"motivation","dir":"","previous_headings":"","what":"Motivation","title":"An SVG Graphics Device","text":"grDevices package bundled R already comes SVG device (using eponymous svg() call). development svglite motivated following considerations:","code":""},{"path":"https://svglite.r-lib.org/index.html","id":"speed","dir":"","previous_headings":"Motivation","what":"Speed","title":"An SVG Graphics Device","text":"svglite() considerably faster svg(). rendering SVGs dynamically serve web can quite important:","code":"library(svglite) x <- runif(1e3) y <- runif(1e3) tmp1 <- tempfile() tmp2 <- tempfile() svglite_test <- function() { svglite(tmp1) plot(x, y) dev.off() } svg_test <- function() { svg(tmp2, onefile = TRUE) plot(x, y) dev.off() } bench::mark(svglite_test(), svg_test(), min_iterations = 250, check = FALSE) #> # A tibble: 2 × 6 #> expression min median `itr/sec` mem_alloc `gc/sec` #> #> 1 svglite_test() 2.08ms 2.23ms 438. 691KB 7.13 #> 2 svg_test() 6.07ms 6.26ms 159. 179KB 0.638"},{"path":"https://svglite.r-lib.org/index.html","id":"file-size","dir":"","previous_headings":"Motivation","what":"File size","title":"An SVG Graphics Device","text":"Another point high relevance serving SVGs web size. svglite() produces much smaller files cases, compressing make .svgz (gzipped svg) worthwhile. svglite supports compressed output directly triggered provided path \".svgz\" (\".svg.gz\") extension.","code":"# svglite fs::file_size(tmp1) #> 75K # svg fs::file_size(tmp2) #> 321K tmp3 <- tempfile(fileext = \".svgz\") svglite(tmp3) plot(x, y) invisible(dev.off()) # svglite - svgz fs::file_size(tmp3) #> 9.42K"},{"path":"https://svglite.r-lib.org/index.html","id":"editability","dir":"","previous_headings":"Motivation","what":"Editability","title":"An SVG Graphics Device","text":"One main reasons size difference size output svglite() svg() fact svglite() encodes text styled elements, whereas svg() converts glyphs polygons renders . latter approach means output svg() require font present system displays SVG makes less impossible edit text fact. svglite focuses providing maximal editability output, can open result vector drawing program Inkscape Illustrator polish output choose.","code":""},{"path":"https://svglite.r-lib.org/index.html","id":"font-support","dir":"","previous_headings":"Motivation","what":"Font support","title":"An SVG Graphics Device","text":"svglite uses systemfonts font discovery means installed fonts system available use. systemfonts foundation means fonts registered register_font() register_variant() also available. contains non-standard weights OpenType features (e.g. ligatures tabular numerics) correctly encoded style block. systemfonts also allows embed webfont @imports file ensure file looks expected even systems without used font installed.","code":""},{"path":"https://svglite.r-lib.org/index.html","id":"code-of-conduct","dir":"","previous_headings":"","what":"Code of Conduct","title":"An SVG Graphics Device","text":"Please note svglite project released Contributor Code Conduct. contributing project, agree abide terms.","code":""},{"path":"https://svglite.r-lib.org/reference/create_svgz.html","id":null,"dir":"Reference","previous_headings":"","what":"Convert an svg file to svgz, overwriting the old file — create_svgz","title":"Convert an svg file to svgz, overwriting the old file — create_svgz","text":"Convert svg file svgz, overwriting old file","code":""},{"path":"https://svglite.r-lib.org/reference/create_svgz.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Convert an svg file to svgz, overwriting the old file — create_svgz","text":"","code":"create_svgz(file)"},{"path":"https://svglite.r-lib.org/reference/create_svgz.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Convert an svg file to svgz, overwriting the old file — create_svgz","text":"file path file convert","code":""},{"path":"https://svglite.r-lib.org/reference/editSVG.html","id":null,"dir":"Reference","previous_headings":"","what":"Run plotting code and open svg in OS/system default svg viewer or editor. — editSVG","title":"Run plotting code and open svg in OS/system default svg viewer or editor. — editSVG","text":"useful primarily testing post-processing SVG.","code":""},{"path":"https://svglite.r-lib.org/reference/editSVG.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Run plotting code and open svg in OS/system default svg viewer or editor. — editSVG","text":"","code":"editSVG(code, ..., width = NA, height = NA)"},{"path":"https://svglite.r-lib.org/reference/editSVG.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Run plotting code and open svg in OS/system default svg viewer or editor. — editSVG","text":"code Plotting code execute. ... arguments passed svglite. height, width Height width inches.","code":""},{"path":"https://svglite.r-lib.org/reference/editSVG.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Run plotting code and open svg in OS/system default svg viewer or editor. — editSVG","text":"","code":"if (interactive()) { editSVG(plot(1:10)) editSVG(contour(volcano)) }"},{"path":"https://svglite.r-lib.org/reference/font_face.html","id":null,"dir":"Reference","previous_headings":"","what":"Create a font-face specification — font_face","title":"Create a font-face specification — font_face","text":"Webfonts SVG HTML can either specified manually using @font-face -rule, imported e.g. Google Fonts using @import -rule. font_face() helps create valid @font-face block web_fonts argument svglite() svgstring() functions.","code":""},{"path":"https://svglite.r-lib.org/reference/font_face.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Create a font-face specification — font_face","text":"","code":"font_face( family, woff2 = NULL, woff = NULL, ttf = NULL, otf = NULL, eot = NULL, svg = NULL, local = NULL, weight = NULL, style = NULL, range = NULL, variant = NULL, stretch = NULL, feature_setting = NULL, variation_setting = NULL )"},{"path":"https://svglite.r-lib.org/reference/font_face.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Create a font-face specification — font_face","text":"family font family name font respond . woff2, woff, ttf, otf, eot, svg URLs font different formats. least one must given. Best browser support provided woff format. local One font names local installations font may . local font found either given names used download happen. weight optional value font-weight descriptor style optional value font-style descriptor range optional value unicode-range descriptor give range unicode values font support variant optional value font-variant descriptor stretch optional value font-stretch descriptor feature_setting optional value font-feature-settings descriptor recommended avoid using possible variation_setting optional value font-variation-settings descriptor.","code":""},{"path":"https://svglite.r-lib.org/reference/font_face.html","id":"value","dir":"Reference","previous_headings":"","what":"Value","title":"Create a font-face specification — font_face","text":"character string @font-face block.","code":""},{"path":"https://svglite.r-lib.org/reference/font_face.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Create a font-face specification — font_face","text":"","code":"font_face( family = \"MyHelvetica\", ttf = \"MgOpenModernaBold.ttf\", local = c(\"Helvetica Neue Bold\", \"HelveticaNeue-Bold\"), weight = \"bold\" ) #> @font-face { #> font-family: \"MyHelvetica\"; #> src: local(\"Helvetica Neue Bold\"), #> local(\"HelveticaNeue-Bold\"), #> url(\"MgOpenModernaBold.ttf\") format(\"truetype\"); #> font-weight: bold; #> }"},{"path":"https://svglite.r-lib.org/reference/htmlSVG.html","id":null,"dir":"Reference","previous_headings":"","what":"Run plotting code and view svg in RStudio Viewer or web browser. — htmlSVG","title":"Run plotting code and view svg in RStudio Viewer or web browser. — htmlSVG","text":"useful primarily testing. Requires htmltools package.","code":""},{"path":"https://svglite.r-lib.org/reference/htmlSVG.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Run plotting code and view svg in RStudio Viewer or web browser. — htmlSVG","text":"","code":"htmlSVG(code, ...)"},{"path":"https://svglite.r-lib.org/reference/htmlSVG.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Run plotting code and view svg in RStudio Viewer or web browser. — htmlSVG","text":"code Plotting code execute. ... arguments passed svglite.","code":""},{"path":"https://svglite.r-lib.org/reference/htmlSVG.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Run plotting code and view svg in RStudio Viewer or web browser. — htmlSVG","text":"","code":"if (interactive() && require(\"htmltools\")) { htmlSVG(plot(1:10)) htmlSVG(hist(rnorm(100))) }"},{"path":"https://svglite.r-lib.org/reference/reexports.html","id":null,"dir":"Reference","previous_headings":"","what":"Objects exported from other packages — reexports","title":"Objects exported from other packages — reexports","text":"objects imported packages. Follow links see documentation. systemfonts font_feature, register_font, register_variant","code":""},{"path":"https://svglite.r-lib.org/reference/stringSVG.html","id":null,"dir":"Reference","previous_headings":"","what":"Run plotting code and return svg as string — stringSVG","title":"Run plotting code and return svg as string — stringSVG","text":"useful primarily testing can used alternative svgstring().","code":""},{"path":"https://svglite.r-lib.org/reference/stringSVG.html","id":"ref-usage","dir":"Reference","previous_headings":"","what":"Usage","title":"Run plotting code and return svg as string — stringSVG","text":"","code":"stringSVG(code, ...)"},{"path":"https://svglite.r-lib.org/reference/stringSVG.html","id":"arguments","dir":"Reference","previous_headings":"","what":"Arguments","title":"Run plotting code and return svg as string — stringSVG","text":"code Plotting code execute. ... arguments passed svglite.","code":""},{"path":"https://svglite.r-lib.org/reference/stringSVG.html","id":"ref-examples","dir":"Reference","previous_headings":"","what":"Examples","title":"Run plotting code and return svg as string — stringSVG","text":"","code":"stringSVG(plot(1:10)) #> Saving 6.67\" x 6.67\" image #> #> #> #>