Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.
This is the add-on to our recently published R Markdown template for business reports. Since we’re working with ggplot2 on a daily basis and use it in nearly every our projects, we designed a ggplot2 theme in our corporate design. That is, it uses our , coporate colors and our logo in the background of the plot. We ourselves find this a very handy thing, because the style is “switched on and off” with a single function call, without having to touch the ggplot syntax itself. With the package ggCorpIdent we’d like to share this functionality with you, so that you can easily adopt your individual corporate style in ggplot2 graphics. This documents leads through the main styling opportunities.
Installation
You can get the package ggCorpIdent from GitHub. If you have not installed devtools yet, please do that first.
<code># install.packages("devtools") devtools::install_github("INWTlab/ggCorpIdent")</code>
Switch on
Having this done, we first call a standard ggplot2 plot from the iris dataset.
<code>library(ggplot2) ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, col = Species)) + geom_point() + labs(title = "A Nice ggplot2 Graphic")</code>
To now use the default ggCorpIdent theme we load the package and call the function ggCorpIdent() before the actual plot(s). If you use this to style all graphics in an R Markdown report for example, you can call ggCorpIdent() in a hidden code chunk (e.g. the setup) and with this all ggplot2 graphics will be using the individual style. Hence, the corporate style is set globally and the output is produced by standard ggplot2 syntax.
<code># default `ggCorpIdent` settings # Initialisation of `ggCorpIdent` library(ggCorpIdent) ggCorpIdent() ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, col = Species)) + geom_point() + labs(title = "Another Nice ggplot2 Graphic", subtitle = "With Customized Style")</code>
And this is basically all you need to do. Within ggCorpIdent() you can define your own style via a set of arguments (for details see ?ggCorpIdent). Let’s see some example configurations.
Colors
Via the colors argument you can overwrite the default colors with your own corporate colors.
<code># usage of different and colors myCorpColors <- c("dodgerblue4", "violetred1", "mintcream") ggCorpIdent(colors = myCorpColors) ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, col = Species)) + geom_point() + labs(title = "Another Nice ggplot2 Graphic With Changed Colors")</code>
You can specify as many colors as you like. However, if more colors are needed than you specify, the given colors are interpolated.
<code># if more than the specified colors are required, the color values are interpolated: iris$Species <- paste("Species", sample(1:6, size = nrow(iris), replace = TRUE)) ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, col = Species)) + geom_point() + labs(title = "Another Nice ggplot2 Graphic With Interpolated Colors")</code>
Fonts (Windows)
The or the family, respectively, for the text elements in the plot can be changed via the argument base_family, you might already know this from the theme functions of ggplot2 (e.g. theme_bw()). On a windows computer a has to meet two conditions in order to be used in your plot. First of all, it has to be a system . You can simply drag and drop s in the system s folder in order to make them one. When it is a system you need to import the into the package via _import() imported from the package extra. Let me demonstrate this. In the ttf folder of this package you find the 4 ttf files for the lora . Drag and drop these 4 files into the directory C:\Windows\Fonts. To now make your system s available for use with this package you can import them via the following command. This could take a minute or two, though.
<code># _import()</code>
You can use the pattern argument to be more specific about which s to be imported. When this is done you can check via
<code>s()</code> <output>## [1] "Lato Black" "Lato" ## [3] "Lora" "Arial Black" ## [5] "Arial" "Arial Narrow" ## [7] "Bahnschrift" "Book Antiqua" ## [9] "Bookman Old Style" "Bookshelf Symbol 7" ## [11] "Bradley Hand ITC" "Calibri" ## [13] "Calibri Light" "Cambria" ## [15] "Candara" "Candara Light" ## [17] "Century" "Century Gothic" ...</output>
which s are available for you to use. Pick the one you want to use – in this case it is Lora – and call it in the function ggCorpIdent in the base_family argument. Then print the previous plot again. And as you can see, the has changed to Lora!
<code>ggCorpIdent(base_family = "Lora", colors = myCorpColors) ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, col = Species)) + geom_point() + labs(title = "Another Nice ggplot2 Graphic With Customized Font")</code>
Fonts (Linux)
On a linux machine you can use system s just the same way as described for a windows machine. As soon as you want to use a that is not a system , you need to install it on your system, too. Here is a link on how to install a in ubuntu, for example: https://wiki.ubuntu.com/Fonts. Then you import the into the package via _import() and you’ll be ready to use it.
Logo
You can add a logo within the plot. You can set the position, scale the logo and control for its transparency. In case you don’t want to include the logo (anymore), set the argument logo to NULL.
<code># usage of coprporate logo logoFromPackage <- system.file("logo/logo_INWT.png", package = "ggCorpIdent", mustWork = TRUE) ggCorpIdent(colors = myCorpColors, base_family = "Lora", logo = logoFromPackage, logoPosition = "bottomright", logoSize = 0.4, logoTransparency = 0.5) ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, col = Species)) + geom_point() + labs(title = "What a Nice, Customized and Branded ggplot2 Graphic", subtitle = "With Custom Colors, Font and Logo")</code>
There is currently just one exception, the logo can not be used in combination with coord_polar(). In this very special case use the original ggplot2::ggplot function and not the ggCorpIdent::ggplot wrapper function:
<code>ggplot2::ggplot(iris, aes(x = Species, fill = Species)) + geom_bar() + coord_polar() + theme(axis.text.x = element_blank())</code>
Switch off
As mentioned in the introduction it is quite easy to switch the styling off again and reset the default ggplot2 appearance of your graphics.
<code># detach package `ggCorpIdent` and reset theme to standard to obtain # default ggplot2 output with identical(!) syntax: detach("package:ggCorpIdent") theme_set(theme_gray()) ggplot(iris, aes(x = Sepal.Length, y = Sepal.Width, col = Species)) + geom_point() + labs(title = "The Standard Nice ggplot2 Graphic", subtitle = "Detaching `ggCorpIdent` is Sufficient to get Standard Output Back")</code>
Collaboration
You’re welcome to help improve this package, just open an issue on GitHub or send a pull request.
R-bloggers.com offers daily e-mail updates about R news and tutorials about learning R and many other topics. Click here if you're looking to post or find an R/data-science job.
Want to share your content on R-bloggers? click here if you have a blog, or here if you don't.