library(tidyverse) library(hueniverrrsity) library(gridExtra) library(ggpubr) knitr::opts_chunk$set( collapse = TRUE, comment = "#>", fig.path = "man/figures/README-", out.width = "100%" )
A visual identity allows an organization to be instantly recognizable. Comprised of their logo, typeface, and colours, it is applied when creating external or internal communications. At universities, staff create visualizations that adhere to the colour palette specified by their institution's visual identity guidelines. For example, on the Students and Alumni page of UBC Master of Data Science website, the visualizations all adhere to the colour palette specified by UBC's visual identity guideline.
This R package allows users to apply university-specific themes to ggplot2 objects. This package currently supports the official colour palettes of four institutions belonging to the U15 Group of Canadian Research Universities: the University of Alberta, the University of British Columbia, McGill University, and the University of Toronto. In the future, we hope to extend this package to support the visual identities of all universities in the association.
To see the vignette for this package, click here
The hueniverrrsity package fits into the R ecosystem with other R packages that allow users to change the theme of ggplot2 objects. These types of packages allow general aesthetic theme changes or specific theme changes for a purpose. One of the most common packages of this type is ggthemes, which allows users to select and apply different general themes to ggplot2 objects. Our package will be different from ggthemes since the goal of the change in plot theme is to adhere to university-specific colour palettes, rather than to generally change the colour and appearance of plots.
You can install the development version of hueniverrrsity from GitHub with:
# install.packages("devtools") devtools::install_github("UBC-MDS/hueniverrrsity")
Start by importing the following packages:
library(hueniverrrsity) library(ggplot2)
theme_alberta()
Input:
colour_use
: fill
or colour
colour_use = colour
for geom_point()
and geom_line()
colour_use = fill
for geom_boxplot()
, geom_bar()
, geom_violin()
and geom_histogram()
colour_palette
: alpha
, beta
, gamma
or delta
Available palettes:
alpha
``` {r out.width = "33%", echo = FALSE}
knitr::include_graphics("imgs/alpha.png")
`beta` <br/> ``` {r out.width = "33%", echo = FALSE} knitr::include_graphics("imgs/beta.png")
gamma
``` {r out.width = "33%", echo = FALSE}
knitr::include_graphics("imgs/gamma.png")
`delta` <br/> ``` {r out.width = "33%", echo = FALSE} knitr::include_graphics("imgs/delta.png")
Output:
Examples:
``` {r theme_alberta(), out.width = "80%"}
a1 <- ggplot(data=mtcars, aes(x = hp, y = mpg, colour = as.factor(cyl))) + geom_point(size = 3, alpha = 0.8) + theme_alberta('colour', 'beta')
a2 <- ggplot(data = mtcars, aes(x = hp, fill = as.factor(cyl))) + geom_density(alpha = 0.8) + theme_alberta('fill', 'delta')
ggarrange(a1, a2, ncol=2, common.legend = TRUE)
### `theme_mcgill()` Input: - `colour_use`: `fill` or `colour` - `colour_use = colour` for `geom_point()` and `geom_line()` - `colour_use = fill` for `geom_boxplot()`, `geom_bar()`, `geom_violin()` and `geom_histogram()` Available palette: ``` {r out.width = "33%", echo = FALSE} knitr::include_graphics("imgs/mcgill.png")
Output:
Examples:
``` {r theme_mcgill(), out.width = "80%"}
m1 <- ggplot(data = mtcars, aes(x = hp, y = mpg, colour = as.factor(cyl))) + geom_point(size = 3, alpha = 0.8) + theme_mcgill('colour')
m2 <- ggplot(data = mtcars, aes(x = hp, fill = as.factor(cyl))) + geom_density(alpha=0.8) + theme_mcgill('fill')
ggarrange(m1, m2, ncol=2, common.legend = TRUE)
### `theme_toronto()` Input: - `colour_use`: `fill` or `colour` - `colour_use = colour` for `geom_point()` and `geom_line()` - `colour_use = fill` for `geom_boxplot()`, `geom_bar()`, `geom_violin()` and `geom_histogram()` - `colour_palette`: `vibrant`, `cool` or `awards` Available palettes: `vibrant` <br/> ``` {r out.width = "25%", echo = FALSE} knitr::include_graphics("imgs/vibrant.png")
cool
``` {r out.width = "25%", echo = FALSE}
knitr::include_graphics("imgs/cool.png")
`awards` <br/> ``` {r out.width = "25%", echo = FALSE} knitr::include_graphics("imgs/awards.png")
Output:
Examples:
``` {r theme_toronto(), out.width = "80%"}
t1 <- ggplot(data = mtcars, aes(x = hp, y = mpg, colour = as.factor(cyl))) + geom_point(size = 2.5) + theme_toronto('colour', 'vibrant')
t2 <- ggplot(data = mtcars, aes(x = hp, fill = as.factor(cyl))) + geom_density(alpha = 0.8) + theme_toronto('fill', 'awards')
ggarrange(t1, t2, ncol=2, common.legend = TRUE)
### `theme_ubc()` Input: - `colour_use`: `fill` or `colour` - `colour_use = colour` for `geom_point()` and `geom_line()` - `colour_use = fill` for `geom_boxplot()`, `geom_bar()`, `geom_violin()` and `geom_histogram()` Available palette: ``` {r out.width = "40%", echo = FALSE} knitr::include_graphics("imgs/ubc.png")
Output:
Examples:
``` {r theme_ubc(), out.width = "80%"}
u1 <- ggplot(data = mtcars, aes(x = hp, y = mpg, colour = as.factor(cyl))) + geom_point(size = 2.5) + theme_ubc('colour')
u2 <- ggplot(data = mtcars, aes(x = hp, fill = as.factor(cyl))) + geom_density(alpha=0.8) + theme_ubc('fill')
ggarrange(u1, u2, ncol=2, common.legend = TRUE) ```
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.