Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rich-iannone/omsvg
SVGs in R
https://github.com/rich-iannone/omsvg
easy-to-use r svg
Last synced: 3 months ago
JSON representation
SVGs in R
- Host: GitHub
- URL: https://github.com/rich-iannone/omsvg
- Owner: rich-iannone
- License: other
- Created: 2019-10-08T03:05:32.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2021-07-07T01:47:33.000Z (over 3 years ago)
- Last Synced: 2024-10-12T21:12:48.903Z (3 months ago)
- Topics: easy-to-use, r, svg
- Language: R
- Homepage: https://rich-iannone.github.io/omsvg/
- Size: 4.39 MB
- Stars: 51
- Watchers: 3
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.Rmd
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - rich-iannone/omsvg - SVGs in R (R)
README
---
output: github_document
---```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)library(omsvg)
```# omsvg
[![Lifecycle:
experimental](https://img.shields.io/badge/lifecycle-experimental-orange.svg)](https://www.tidyverse.org/lifecycle/#experimental)
[![R build
status](https://github.com/rich-iannone/omsvg/workflows/R-CMD-check/badge.svg)](https://github.com/rich-iannone/omsvg/actions?workflow=R-CMD-check)## Overview
Scalable vector graphics, SVGs, are *fantastic*. The **omsvg** package lets you make SVGs using the **R** programming language, and, it tries to make the whole process a little less difficult. We can create SVG elements, transform them programmatically, apply filters, and even animate them.
### Creating a Simple SVG
The process of using **omsvg** begins with the `SVG()` function. That allows you to define the overall size of the graphic and set some global options. Let's start simple and make an SVG with three elements: (1) a rectangle, (2) an ellipse, and (3) some text. To do this, we'll use the `svg_rect()`, `svg_ellipse()`, and `svg_text()` functions.
```{r create_simple_svg}
svg <-
SVG(width = 250, height = 100) %>%
svg_rect(x = 25, y = 25, width = 50, height = 50, fill = "yellow") %>%
svg_ellipse(x = 125, y = 50, width = 50, height = 50, stroke = "magenta") %>%
svg_text(x = 175, y = 50, text = "this is text", attrs = svg_attrs_pres(font_family = "Helvetica"))
``````{r simple_svg_display, echo=FALSE}
svg %>% as.character() %>% cat()
```Aside from rectangles, ellipses, and text, we can also elect to use circles (`svg_circle()`), lines (`svg_line()`), *polylines* (`svg_polyline()`), polygons (`svg_polygon()`), and as-complex-as-you-can-make-'em paths (`svg_path()`).
### Animating an SVG
One thing that's really great about SVGs is that they can be animated, and, almost everything in an SVG is animatable. The **omsvg** package lets us animate each element with minimal frustration. Here is an example of a rectangle being quite animated.
```{r animating_rectangle}
svg_rectangle_anim <-
SVG(width = 700, height = 150) %>%
svg_rect(
x = 100, y = 75,
width = 100, height = 100,
stroke = "cyan",
fill = "lightblue",
anims = anims(
0.5 ~ list(
anim_position(initial = TRUE),
anim_rotation(initial = TRUE)
),
2.0 ~ list(
anim_position(x = 500, y = 75, easing_fn = ease_in_out()),
anim_rotation(90, easing_fn = ease_in_out())
)
)
)
``````{r animated_svg_display, echo=FALSE}
svg_rectangle_anim %>% as.character() %>% cat()
```Animations are made through reference to keyframe times. Each of these times (in seconds) is like a transition point. Above, the rectangle is held at its initial position and rotation state until `0.5` seconds has elapsed. At `2.0` seconds, the second keyframe, the rectangle's position is to be moved from `{x = 100, y = 100}` to `{x = 500, y = 100}`, and, its rotation state should change to `90` degrees. We can assign a `timing` function that governs the tweening of the animation. For the position and rotation changes, these are both using the `ease_in_out()` timing function (where movement eases into a maximum speed and then decelerates to a stop).
## Installation
The **omsvg** package is available in CRAN and can be installed with:
```{r eval=FALSE}
install.packages("omsvg")
```You can install the development version from [GitHub](https://github.com/) with:
```{r eval=FALSE}
# install.packages("devtools")
devtools::install_github("rich-iannone/omsvg")
```