Create Chicklet (Rounded Segmented Column) Charts https://cinc.rud.is/web/packages/ggchicklet/
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
boB Rudis 822c3de6a5
switch to tinytest
5 years ago
R fixes #1 5 years ago
README_files/figure-gfm pretty much feature complete 5 years ago
data pretty much feature complete 5 years ago
data-raw pretty much feature complete 5 years ago
inst/tinytest switch to tinytest 5 years ago
man smarter logic for corner-radius of legend keys 5 years ago
tests switch to tinytest 5 years ago
vignettes doc change 'px' to 'pt' 5 years ago
.Rbuildignore pretty much feature complete 5 years ago
.codecov.yml R package repo initialization complete 5 years ago
.gitignore pretty much feature complete 5 years ago
.travis.yml R package repo initialization complete 5 years ago
CONDUCT.md R package repo initialization complete 5 years ago
DESCRIPTION switch to tinytest 5 years ago
LICENSE initial commit 5 years ago
NAMESPACE pretty much feature complete 5 years ago
NEWS.md R package repo initialization complete 5 years ago
README.Rmd pretty much feature complete 5 years ago
README.md pretty much feature complete 5 years ago
ggchicklet.Rproj R package repo initialization complete 5 years ago

README.md

Travis-CI BuildStatus CoverageStatus CRAN\_Status\_Badge

ggchicklet

Create Chicklet (Rounded Segmented Column) Charts

Description

Sometimes it is useful to stylize column charts a bit more than just bland rectangles. Methods are provided to create rounded rectangle segmented column charts (i.e. “chicklets”).

What’s Inside The Tin

The following functions are implemented:

Installation

install.packages("ggchicklet", repos = "https://cinc.rud.is")
# or 
devtools::install_git("https://git.rud.is/hrbrmstr/ggchicklet.git")
# or 
devtools::install_git("https://git.sr.ht/~hrbrmstr/ggchicklet")
# or
devtools::install_gitlab("hrbrmstr/ggchicklet")
# or
devtools::install_bitbucket("hrbrmstr/ggchicklet")
# or (if you must)
devtools::install_github("hrbrmstr/ggchicklet")

Usage

library(ggchicklet)

# current version
packageVersion("ggchicklet")
## [1] '0.1.0'

From the NYTimes

library(hrbrthemes)
library(tidyverse)

data("debates2019")

debates2019 %>%
  mutate(speaker = fct_reorder(speaker, elapsed, sum, .desc=FALSE)) %>%
  mutate(topic = fct_other(
    topic,
    c("Immigration", "Economy", "Climate Change", "Gun Control", "Healthcare", "Foreign Policy"))
  ) %>%
  ggplot(aes(speaker, elapsed, group = timestamp, fill = topic)) +
  geom_chicklet(width = 0.75) +
  scale_y_continuous(
    expand = c(0, 0.0625),
    position = "right",
    breaks = seq(0, 14, 2),
    labels = c(0, sprintf("%d min.", seq(2, 14, 2)))
  ) +
  scale_fill_manual(
    name = NULL,
    values = c(
      "Immigration" = "#ae4544",
      "Economy" = "#d8cb98",
      "Climate Change" = "#a4ad6f",
      "Gun Control" = "#cc7c3a",
      "Healthcare" = "#436f82",
      "Foreign Policy" = "#7c5981",
      "Other" = "#cccccc"
    ),
    breaks = setdiff(unique(debates2019$topic), "Other")
  ) +
  guides(
    fill = guide_legend(nrow = 1)
  ) +
  coord_flip() +
  labs(
    x = NULL, y = NULL, fill = NULL,
    title = "How Long Each Candidate Spoke",
    subtitle = "Nights 1 & 2 of the June 2019 Democratic Debates",
    caption = "Each bar segment represents the length of a candidate’s response to a question.\n\nOriginals <https://www.nytimes.com/interactive/2019/admin/100000006581096.embedded.html?>\n<https://www.nytimes.com/interactive/2019/admin/100000006584572.embedded.html?>\nby @nytimes Weiyi Cai, Jason Kao, Jasmine C. Lee, Alicia Parlapiano and Jugal K. Patel\n\n#rstats reproduction by @hrbrmstr"
  ) +
  theme_ipsum_rc(grid="X") +
  theme(axis.text.x = element_text(color = "gray60", size = 10)) +
  theme(legend.position = "top")

ggchicklet Metrics

Lang # Files (%) LoC (%) Blank lines (%) # Lines (%)
R 9 0.82 123 0.51 27 0.37 105 0.54
Rmd 2 0.18 116 0.49 46 0.63 90 0.46

Code of Conduct

Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.