Title: | Easily Work with 'Font Awesome' Icons |
---|---|
Description: | Easily and flexibly insert 'Font Awesome' icons into 'R Markdown' documents and 'Shiny' apps. These icons can be inserted into HTML content through inline 'SVG' tags or 'i' tags. There is also a utility function for exporting 'Font Awesome' icons as 'PNG' images for those situations where raster graphics are needed. |
Authors: | Richard Iannone [aut, cre] , Christophe Dervieux [ctb] , Winston Chang [ctb], Dave Gandy [ctb, cph] (Font-Awesome font), Posit Software, PBC [cph, fnd] |
Maintainer: | Richard Iannone <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.5.2.9000 |
Built: | 2024-08-30 20:58:50 UTC |
Source: | https://github.com/rstudio/fontawesome |
Add one or more Font Awesome icons as SVGs contained within <svg>...</svg>
.
We can optionally set certain style attributes. The fa()
function can be
used directly within inline evaluations of R code in R Markdown documents.
fa( name, fill = NULL, fill_opacity = NULL, stroke = NULL, stroke_width = NULL, stroke_opacity = NULL, height = NULL, width = NULL, margin_left = NULL, margin_right = NULL, vertical_align = NULL, position = NULL, title = NULL, prefer_type = c("regular", "solid"), a11y = c("deco", "sem", "none") )
fa( name, fill = NULL, fill_opacity = NULL, stroke = NULL, stroke_width = NULL, stroke_opacity = NULL, height = NULL, width = NULL, margin_left = NULL, margin_right = NULL, vertical_align = NULL, position = NULL, title = NULL, prefer_type = c("regular", "solid"), a11y = c("deco", "sem", "none") )
name |
The name of the Font Awesome icon. This could be as a short name
(e.g., |
fill , fill_opacity
|
The fill color of the icon can be set with |
stroke , stroke_width , stroke_opacity
|
The stroke options allow for
setting the color, width, and opacity of the SVG outline stroke. By
default, the stroke width is very small at |
height , width
|
The height and width style attributes of the rendered
SVG. If nothing is provided for |
margin_left , margin_right
|
The length value for the margin that's either
left or right of the icon. By default, |
vertical_align |
The vertical alignment of the icon. By default, a
length of |
position |
The value for the |
title |
An option for populating the SVG |
prefer_type |
Chooses the type of icon returned if: (1) providing a
short name, and (2) that icon has both solid and regular types.
For example, using |
a11y |
Cases that distinguish the role of the icon and inform which
accessibility attributes to be used. Icons can either be |
A fontawesome
object.
if (interactive()) { # Create a Font Awesome SVG icon fa(name = "r-project") }
if (interactive()) { # Create a Font Awesome SVG icon fa(name = "r-project") }
html_dependency
The fa_html_dependency()
function adds a html_dependency
object into a
Shiny or R Markdown context. This allows for the direct use of <i>
tags
that refer to Font Awesome icons without having to use the fa_i()
to create
these tags and also add the html_dependency
to the document.
fa_html_dependency()
fa_html_dependency()
The html_dependency
object is created internally with the following
invocation:
htmltools::htmlDependency( name = "font-awesome", version = fa_version, src = "fontawesome", package = "fontawesome", stylesheet = c("css/all.min.css", "css/v4-shims.min.css") )
The fa_version
object is an internal object that provides the released
version number for the Font Awesome icons. This can be inspected by using
fa_metadata()$version
.
An html_dependency
object.
if (interactive()) { # Create a Font Awesome `html_dependency` fa_html_dependency() }
if (interactive()) { # Create a Font Awesome `html_dependency` fa_html_dependency() }
<i>
tagThe fa_i()
function creates a Font Awesome <i>
tag and not an SVG as with
fa()
. The primary use case for fa_i()
is for legacy Shiny applications
that use the shiny::icon()
function. This function is called within a
shiny::icon()
call and all HTML dependencies to support icon generation are
hosted in the fontawesome package.
fa_i( name, class = NULL, ..., prefer_type = c("regular", "solid"), html_dependency = fa_html_dependency() )
fa_i( name, class = NULL, ..., prefer_type = c("regular", "solid"), html_dependency = fa_html_dependency() )
name |
The name of the Font Awesome icon. This could be as a short name
(e.g., |
class |
Additional classes to customize the style of the icon. |
... |
Arguments passed to the |
prefer_type |
Chooses the type of icon returned if: (1) providing a
short name, and (2) that icon has both solid and regular types.
For example, using |
html_dependency |
Provides an opportunity to use a custom
|
An icon element.
if (interactive()) { # Create a Font Awesome icon object fa_i(name = "r-project") }
if (interactive()) { # Create a Font Awesome icon object fa_i(name = "r-project") }
This function provide some metadata about the included Font Awesome assets in the fontawesome package. The list that is returned has the following components:
version
: The released version number for the Font Awesome icons
icon_count
: The total count of unique Font Awesome icons
icon_names
: A vector of short names (e.g., "npm"
, "drum"
, etc.) for
all included icons
icon_names_full
: A vector containing the full names (e.g., "fab fa-npm"
, "fas fa-drum"
, etc.) for all included icons
icon_names_fa(r|s|b)
: Vectors of short names within the regular ("r"
),
solid ("s"
), and brand ("b"
) groups
icon_names_full_fa(r|s|b)
: Vectors with the full names of icons within
the regular ("r"
), solid ("s"
), and brand ("b"
) groups
fa_metadata()
fa_metadata()
A list with metadata for the included Font Awesome assets.
if (interactive()) { # Get information on the Font Awesome # assets included in this package fa_metadata() }
if (interactive()) { # Get information on the Font Awesome # assets included in this package fa_metadata() }
Get a Font Awesome icon as a PNG file. We can optionally set the fill
attribute before writing the PNG. Additionally, there is control over the
output width and height (usually, icons are 512 by 512 pixels). Please note
that this function requires that the rsvg is installed on the system.
Attempting to use fa_png()
without rsvg available will result in an
error message.
fa_png( name, file = NULL, fill = NULL, fill_opacity = NULL, stroke = NULL, stroke_width = NULL, stroke_opacity = NULL, height = NULL, width = NULL, prefer_type = c("regular", "solid") )
fa_png( name, file = NULL, fill = NULL, fill_opacity = NULL, stroke = NULL, stroke_width = NULL, stroke_opacity = NULL, height = NULL, width = NULL, prefer_type = c("regular", "solid") )
name |
The name of the Font Awesome icon. |
file |
the path to the output file. If |
fill , fill_opacity
|
The fill color of the icon can be set with |
stroke , stroke_width , stroke_opacity
|
The stroke options allow for
setting the color, width, and opacity of the outline stroke. By default,
the stroke width is very small at |
height , width
|
The output height and width of the rendered PNG. If nothing is provided then the output dimensions will match that of the input SVG viewBox. |
prefer_type |
Chooses the type of icon returned if: (1) providing a
short name, and (2) that icon has both solid and regular types.
For example, using |
A PNG file written to disk.
if (interactive()) { # Create a Font Awesome SVG icon as a # PNG file on disk fa_png(name = "r-project") }
if (interactive()) { # Create a Font Awesome SVG icon as a # PNG file on disk fa_png(name = "r-project") }