Skip to content

Latest commit

 

History

History
96 lines (72 loc) · 1.96 KB

README.md

File metadata and controls

96 lines (72 loc) · 1.96 KB

pdfcolorsplit

{pdfcolorsplit} is an utility to split a PDF file into a file containing color sheets, and a file containing B&W sheets.

This is useful when one must print a document, but the printer does not automatically choose the ink based on the content.

Features

  • Color detection using {magick}
  • Can deal with single- and double-sided PDFs

Installation

The package is not in CRAN yet.
You can simply install it from this repository:

remotes::install_github("lgaborini/pdfcolorsplit")

Example

Let’s prepare the R Markdown Cookbook for printing!

## library(pdfcolorsplit)

f_pdf_local <- "assets/rmarkdown-cookbook.pdf"

df_pages <- tidy_pdf_pages(
   pdf = f_pdf_local,
   double_sided = TRUE
)

How many pages must be printed in color?

df_pages %>% 
   dplyr::count(is_color_page)
#> # A tibble: 2 x 2
#>   is_color_page     n
#>   <lgl>         <int>
#> 1 FALSE            76
#> 2 TRUE             13

How many SHEETS must be printed in color? (this is the actual printing cost)

df_pages %>% 
   dplyr::count(is_color_sheet)
#> # A tibble: 2 x 2
#>   is_color_sheet     n
#>   <lgl>          <int>
#> 1 FALSE             73
#> 2 TRUE              16

Show one random color page:

df_pages %>% 
   dplyr::filter(is_color_page) %>% 
   dplyr::slice_head(n = 1) %>% 
   dplyr::pull(img)
#> [[1]]
#> # A tibble: 1 x 7
#>   format width height colorspace matte filesize density
#>   <chr>  <int>  <int> <chr>      <lgl>    <int> <chr>  
#> 1 PNG      612    792 sRGB       TRUE         0 72x72

Split in two parts:

# The directory that will contain the files
output_dir <- tempdir()

df_pages %>% 
   split_pdf_chunks(
      pdf = f_pdf_local,
      output_dir = output_dir
   )