Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/feddelegrand7/fabricerin
Create Easily Canvas in Shiny and RMarkdown Documents
https://github.com/feddelegrand7/fabricerin
canvas javascript r rmarkdown rmarkdown-document rstats shiny
Last synced: 4 months ago
JSON representation
Create Easily Canvas in Shiny and RMarkdown Documents
- Host: GitHub
- URL: https://github.com/feddelegrand7/fabricerin
- Owner: feddelegrand7
- License: other
- Created: 2020-07-26T20:13:45.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2021-02-01T18:00:42.000Z (about 4 years ago)
- Last Synced: 2024-10-03T06:51:42.584Z (5 months ago)
- Topics: canvas, javascript, r, rmarkdown, rmarkdown-document, rstats, shiny
- Language: R
- Homepage: https://ihaddadenfodil.com/post/fabricerin-a-tutorial/
- Size: 7.12 MB
- Stars: 54
- Watchers: 5
- Forks: 5
- Open Issues: 3
-
Metadata Files:
- Readme: README.Rmd
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-shiny-extensions - fabricerin - Create HTML5 canvas in Shiny and R Markdown documents based on Fabric.js. (UI Components / Image / Audio / Video)
- jimsghstars - feddelegrand7/fabricerin - Create Easily Canvas in Shiny and RMarkdown Documents (R)
README
---
output: github_document
---```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```# fabricerin
[data:image/s3,"s3://crabby-images/7ccdb/7ccdbeb16f274b840eb50c9612a16a5336798c6f" alt="Travis build status"](https://travis-ci.com/feddelegrand7/fabricerin)
[data:image/s3,"s3://crabby-images/b0fc0/b0fc0f5cd0d4a6fea2120a7f6f4b8a0a94c140cb" alt="CRAN_time_from_release"](https://cran.r-project.org/package=fabricerin)
[data:image/s3,"s3://crabby-images/b53af/b53aff942af96e218e3bd80dbb583cc7a96d1a55" alt="CRAN_latest_release_date"](https://cran.r-project.org/package=fabricerin)
[data:image/s3,"s3://crabby-images/73df4/73df44f0b5a4eb3550b9196ed9f1734bf9866e03" alt="metacran downloads"](https://cran.r-project.org/package=fabricerin)
[data:image/s3,"s3://crabby-images/9a558/9a5580ffe5c58a63d45139d5a9b3fc11572d91d6" alt="metacran downloads"](https://cran.r-project.org/package=fabricerin)
[data:image/s3,"s3://crabby-images/a4a19/a4a19d4b9126e5274cf97823c96a30b784ae9b02" alt="License: AGPL v3"](https://www.gnu.org/licenses/agpl-3.0)
[data:image/s3,"s3://crabby-images/a3b64/a3b64bab91d9c96207e43470f1d70f6916a8b6bd" alt="R badge"](https://github.com/feddelegrand7/fabricerin)The `fabricerin` (spelled __fabrikerine__) package allows you to create easily canvas elements within your Shiny app and RMarkdown documents. Thanks to [Garrick Aden-Buie](https://twitter.com/grrrck?lang=en), you can also use it within your [xaringan](https://github.com/yihui/xaringan) slides. You can use the canvas to render shapes, images and text. You can also create a canvas for drawing/taking notes purposes. Under the hoods, `fabricerin` relies on the [fabricjs](http://fabricjs.com/) JavaScript library.
## Installation
You can install `fabricerin` from [CRAN](https://CRAN.R-project.org/package=fabricerin) with:
```{r, eval=FALSE}
install.packages("fabricerin")
```
You can install the development version from [GitHub](https://github.com/) with:
```{r, eval=FALSE}
# install.packages("remotes")remotes::install_github("feddelegrand7/fabricerin")
```
## Examples:
First of all, I'd like to state that all the example provided apply the same way to Shiny and Rmd documents. `fabricerin` is not an R wrapper for the fabricjs library. The package doesn't cover all the capabilities of the library. The `fabricerin` package relies only on some specified features that according to me will help Shiny/Rmd users. Of course, if you need some improvement, feel free to create a Pull Request.
### `fabric_drawing()` Create a canvas for taking notes
***`fabric_drawing()` is pretty useful when you want to teach something and write some notes at the same time, below I provide an example using the `xaringan` package. Inside a `xaringan` slide you can just (for example) run R code in the left and take notes in the right:
> Important: When you change a color, make sure that the __erase__ box is not checked.
data:image/s3,"s3://crabby-images/cc3d2/cc3d268e573ef572bfe31b9c16330c8dca07a7e1" alt=""
`fabric_drawing()` can be used the same way in Shiny:
```{r, eval=FALSE}
library(shiny)
library(fabricerin)ui <- fluidPage(
fabric_drawing(cid = "canvas123"))
server <- function(input, output){}
shinyApp(ui, server)
```
data:image/s3,"s3://crabby-images/4db95/4db95939d84d58fb1e93d32481eb84582bdda282" alt=""
## `fabric_shape()` Render shape objects in canvas
***Currently, `fabricerin` supports three types of shapes: Rectangle, Triangle, Circle and Polygon. The user can interact with the shape and modify its position, size and rotation. If you want to disable this interactivity, you can set `selectable =FALSE`
```{r, eval=FALSE}
library(shiny)
library(fabricerin)ui <- fluidPage(
fabric_shape(cid = "canvaId", # canvas id
cfill = "orange", # canvas color
cwidth = 800, # the width of the canvas
cheight = 600, # the height of the canvas
shapeId = "shapeId", # shape id
shape = "Rect",
fill = "red", # shape color
width = 400,
height = 400,
left = 100, # the position of the shape from the left relative to the canvas
top = 100, # the position of the shape from the top relative to the canvas
strokecolor = "darkblue",
strokewidth = 5,
selectable = TRUE)
)server <- function(input, output){}
shinyApp(ui, server)
```
data:image/s3,"s3://crabby-images/6db71/6db71d1a476a94706995cb1d5b3191eb09fdec8d" alt=""
You can add as many shape as you want to an existing canvas using the `fabric_shape_add()` function. __Don't forget to reference the preexisting canvas with its ID:__
```{r, eval=FALSE}
library(shiny)
library(fabricerin)ui <- fluidPage(
fabric_shape(cid = "canvaId",
shapeId = "cr1",
shape = "Circle",
radius = 30,
left = 100),
fabric_shape_add(cid = "canvaId",
shapeId = "cr2",
shape = "Circle",
radius = 30,
left = 200),
fabric_shape_add(cid = "canvaId",
shapeId = "cr3",
shape = "Circle",
radius = 30,
left = 300),
fabric_shape_add(cid = "canvaId",
shapeId = "cr4",
shape = "Circle",
radius = 30,
left = 400)
)server <- function(input, output){}
shinyApp(ui, server)
```data:image/s3,"s3://crabby-images/f447c/f447cdfe9c611012da75f3306560f77f8a3858f3" alt=""
## `fabric_image()` Render images in canvas
***You can insert an image within a canvas a play with it using the `fabric_image()` function. Note that this function accepts only URL external images.
```{r, eval=FALSE}
ui <- fluidPage(
fabric_image(cid = "cimage",
cfill = "lightblue",
imgId = "Rimg",
imgsrc = "https://upload.wikimedia.org/wikipedia/commons/thumb/1/1b/R_logo.svg/724px-R_logo.svg.png"))
server <- function(input, output) {}
shinyApp(ui = ui, server = server)
```
data:image/s3,"s3://crabby-images/9f143/9f143e4cc39e7b2420d3d59f241df24545dc732d" alt=""
Similar to shapes, you can add images to preexisting canvas using the `fabric_image_add()` function:
```{r,eval=FALSE}
library(shiny)
library(fabricerin)ui <- fluidPage(
fabric_image(cid = "cimage",
imgId = "Rimg",
imgsrc = "https://upload.wikimedia.org/wikipedia/commons/thumb/1/1b/R_logo.svg/724px-R_logo.svg.png",
imgheight = 200,
imgwidth = 200),
fabric_image_add(cid = "cimage",
imgId = "rstudioimg",
imgsrc = "https://raw.githubusercontent.com/rstudio/hex-stickers/master/PNG/dplyr.png",
imgwidth = 200,
imgheight = 200,
left = 400)
)server <- function(input, output) {}
shinyApp(ui = ui, server = server)
```
data:image/s3,"s3://crabby-images/52a29/52a29ed8776c5bfb434a1525efd21dea35fed483" alt=""
## `fabric_text()` Render text elements in canvas
***The `fabric_text()` function has many arguments, feel free to check them out:
```{r, eval=FALSE}
ui <- fluidPage(
fabric_text(cid = "cId",
textId = "text",
text = " 'But A Hero Is A Guy Who Gives Out The Meat To Everyone Else. \\n I Want To Eat The Damn Meat!' \\n Monkey D. Luffy",
cfill = "#DD5347",
left = 120,
shadowCol = "blue",
fontSize = 20,
fontWeight = "bold",
lineHeight = 3
)
)
server <- function(input, output) {}shinyApp(ui = ui, server = server)
```
data:image/s3,"s3://crabby-images/2b08f/2b08f892f52280fdecd74baf0c9dc733f50aa25c" alt=""
Here also, we can use the `fabric_text_add()` function to incorporate a text object within a canvas element:
```{r, eval=FALSE}
library(shiny)
library(fabricerin)ui <- fluidPage(
fabric_shape(cid = "canvas123",
cfill = "lightblue",
cwidth = 1000,
shapeId = "tri1",
shape = "Triangle",
fill = "darkblue"),fabric_text_add(cid = "canvas123",
textId = "txt1",
text = "This is a darkblue Triangle !",
left = 350
))
server <- function(input, output) {}
shinyApp(ui = ui, server = server)
```
data:image/s3,"s3://crabby-images/4c81f/4c81f4d900334e4e6ad85d1be0911d56a163f335" alt=""
## `fabric_curtail()` Add a background or an overlay image to a canvas
You can set an image as a background or as a foreground (overlay) for a canvas as follows:
> Note that due to security reasons, you won't be able to replicate the following example on some images' sources.
```{r, eval=FALSE}
ui <- fluidPage(
fabric_shape(cid = "canvas123",
shapeId = "tri1",
shape = "Triangle",
fill = "lightblue"),fabric_curtail(cid = "canvas123",
imgsrc = "https://st.depositphotos.com/1642482/1904/i/950/depositphotos_19049237-stock-photo-leaf.jpg",
type = "background")
)
server <- function(input, output) {}
shinyApp(ui = ui, server = server)
```
data:image/s3,"s3://crabby-images/bd29b/bd29bbf6baebddb2fd65ba5a69c1efa1e42e1aa1" alt=""
## Code of Conduct
Please note that the fabricerin project is released with a [Contributor Code of Conduct](https://contributor-covenant.org/version/2/0/CODE_OF_CONDUCT.html). By contributing to this project, you agree to abide by its terms.