An R Wrapper to the Overly Complicated 'Bitmoji' API

An R wrapper to the overly complicated 'Bitmoji' API allowing users to access and plot various comic strips using their personalized 'Bitstrips' avatar (< https://www.bitmoji.com/>).


Travis-CI BuildStatus AppVeyor BuildStatus

Ya, this is happening…

Installation

You can (try to) install the development version of RBitmoji from GitHub using

if (!requireNamespace("devtools")) {
  install.packages("devtools")
}
devtools::install_github("bgreenwell/RBitmoji")

Obtaining your Bitmoji ID

In order to use RBitmoji you will need your unique Bitmoji ID, which can be difficult to find. Fortunately, the get_id() function can simplify the process! TO use this function, you must supply the email address associated with your Bitmoji account. You will then be prompted to enter your Bitmoji account password using a secure blah, blah, blah. For example:

library(RBitmoji)
my_id <- get_id("[email protected]")

If successful, your id will be stored in the variable my_id. Once that is done, you can use the plot_comic() function to do real data science.

Basic usage

If you are familiar with Bitmoji, then you know that there are hundreds of comics available for your avatar, each of which is associated with a comic id and a tag. As of right now, you can only look up and plot comics by tag, but in the future, we’ll add an id argument as well. Also, note that many comics are associated with multiple tags and vice versa, so use set.seed() for reproducibility. Below are some simple examples (the value of my_id was found using the get_id() function).

# Use set.seed() to generate the same comic everytime for a particular tag
set.seed(101)  # for reproducibility
my_id <- "1551b314-5e8a-4477-aca2-088c05963111-v1"
plot_comic(my_id, tag = "fail")
 
# Another example
plot_comic(my_id, tag = "time magazine")
 
# Some tags are associated with multiple comics
par(mfrow = c(2, 2))
for (i in 1:4) plot_comic(my_id, tag = "cool")
 
# Overlay comics on various plots
comic <- get_comic(my_id, tag = "volcano")
library(ggplot2)
ggplot(iris, aes(x = Petal.Length, y = Petal.Width)) +
  geom_point(aes(color = Species)) +
  annotation_raster(comic, xmin = 1, xmax = 3, ymin = 1.5, ymax = 2.5)
 
# You have two ids, you can also plot comics with friends
set.seed(102)  # for reproducibility
plot_comic(c(my_id, my_id), tag = "vomit")
plot_comic(c(my_id, my_id), tag = "drink")

Inspirations

News

RBitmoji 0.0.1.9000

RBitmoji 0.0.1

  • Initial release.

  • Added a NEWS.md file to track changes to the package.

Reference manual

It appears you don't have a PDF plugin for this browser. You can click here to download the reference manual.

install.packages("RBitmoji")

0.0.2 by Brandon Greenwell, 5 months ago


https://github.com/bgreenwell/RBitmoji


Report a bug at https://github.com/bgreenwell/RBitmoji/issues


Browse source code at https://github.com/cran/RBitmoji


Authors: Brandon Greenwell [aut, cre]


Documentation:   PDF Manual  


GPL (>= 2) license


Imports getPass, graphics, grDevices, httr, jsonlite, png, RCurl

Suggests knitr, rmarkdown


See at CRAN