22 lines
93 KiB
JSON
22 lines
93 KiB
JSON
{
|
||
"hash": "1f512aedde0c78d18d7113364c7ce0db",
|
||
"result": {
|
||
"engine": "knitr",
|
||
"markdown": "---\ntitle: \"数据可视化\"\nsubtitle: 《区域水环境污染数据分析实践》<br>Data analysis practice of regional water environment pollution\nauthor: 苏命、王为东<br>中国科学院大学资源与环境学院<br>中国科学院生态环境研究中心\ndate: today\nlang: zh\nformat:\n revealjs:\n theme: dark\n slide-number: true\n chalkboard:\n buttons: true\n preview-links: auto\n lang: zh\n toc: true\n toc-depth: 1\n toc-title: 大纲\n logo: ./_extensions/inst/img/ucaslogo.png\n css: ./_extensions/inst/css/revealjs.css\n pointer:\n key: \"p\"\n color: \"#32cd32\"\n pointerSize: 18\nrevealjs-plugins:\n - pointer\nfilters:\n - d2\nknitr:\n opts_chunk:\n dev: \"svg\"\n retina: 3\nexecute:\n freeze: auto\n cache: true\n echo: true\n fig-width: 5\n fig-height: 6\n---\n\n\n\n\n\n\n## {background-image=\"../../img/concepts/tidyverse-packages-ggplot.png\" background-position=\"center\" background-size=\"100%\"}\n\n\n\n## The ggplot2 Package\n\n<br>\n\n... is an **R package to visualize data** created by Hadley Wickham in 2005\n\n\n::: {.cell}\n\n```{.r .cell-code}\n# install.packages(\"ggplot2\")\nlibrary(ggplot2)\n```\n:::\n\n\n<br>\n\n::: fragment\n... is part of the [`{tidyverse}`](https://www.tidyverse.org/)\n\n\n::: {.cell}\n\n```{.r .cell-code}\n# install.packages(\"tidyverse\")\nlibrary(tidyverse)\n```\n:::\n\n:::\n\n# The Grammar of {ggplot2}\n\n\n\n## The Grammar of {ggplot2}\n\n<br>\n<table style='width:100%;font-size:14pt;'>\n <tr>\n <th>Component</th>\n <th>Function</th>\n <th>Explanation</th>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Data</b></td>\n <td><code>ggplot(data)</code> </td>\n <td>*The raw data that you want to visualise.*</td>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Aesthetics </b></td>\n <td><code>aes()</code></td>\n <td>*Aesthetic mappings between variables and visual properties.*</td>\n <tr>\n <td><b style='color:#67676;'>Geometries</b></td>\n <td><code>geom_*()</code></td>\n <td>*The geometric shapes representing the data.*</td>\n </tr>\n</table>\n\n\n\n## The Grammar of {ggplot2}\n\n\n<br>\n<table style='width:100%;font-size:14pt;'>\n <tr>\n <th>Component</th>\n <th>Function</th>\n <th>Explanation</th>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Data</b></td>\n <td><code>ggplot(data)</code> </td>\n <td>*The raw data that you want to visualise.*</td>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Aesthetics </b></td>\n <td><code>aes()</code></td>\n <td>*Aesthetic mappings between variables and visual properties.*</td>\n <tr>\n <td><b style='color:#67676;'>Geometries</b></td>\n <td><code>geom_*()</code></td>\n <td>*The geometric shapes representing the data.*</td>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Statistics</b></td>\n <td><code>stat_*()</code></td>\n <td>*The statistical transformations applied to the data.*</td>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Scales</b></td>\n <td><code>scale_*()</code></td>\n <td>*Maps between the data and the aesthetic dimensions.*</td>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Coordinate System</b></td>\n <td><code>coord_*()</code></td>\n <td>*Maps data into the plane of the data rectangle.*</td>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Facets</b></td>\n <td><code>facet_*()</code></td>\n <td>*The arrangement of the data into a grid of plots.*</td>\n </tr>\n <tr>\n <td><b style='color:#67676;'>Visual Themes</b></td>\n <td><code>theme() / theme_*()</code></td>\n <td>*The overall visual defaults of a plot.*</td>\n </tr>\n</table>\n\n\n\n## The Data\n\n<b style='font-size:2.3rem;'>Bike sharing counts in London, UK, powered by [TfL Open Data](https://tfl.gov.uk/modes/cycling/santander-cycles)</b>\n\n::: incremental\n- covers the years 2015 and 2016\n- incl. weather data acquired from [freemeteo.com](https://freemeteo.com)\n- prepared by Hristo Mavrodiev for [Kaggle](https://www.kaggle.com/hmavrodiev/london-bike-sharing-dataset)\n:::\n\n<br>\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code}\nbikes <- readr::read_csv(\"../../data/ggplot2/london-bikes-custom.csv\",\n ## or: \"https://raw.githubusercontent.com/z3tt/graphic-design-ggplot2/main/data/london-bikes-custom.csv\"\n col_types = \"Dcfffilllddddc\"\n)\n\nbikes$season <- forcats::fct_inorder(bikes$season)\n```\n:::\n\n:::\n\n------------------------------------------------------------------------\n\n\n::: {.cell}\n::: {.cell-output-display}\n`````{=html}\n<table class=\"table lightable-minimal lightable-hover\" style=\"font-size: 20px; margin-left: auto; margin-right: auto; font-family: Spline Sans Mono; \">\n <thead>\n <tr>\n <th style=\"text-align:left;\"> Variable </th>\n <th style=\"text-align:left;\"> Description </th>\n <th style=\"text-align:left;\"> Class </th>\n </tr>\n </thead>\n<tbody>\n <tr>\n <td style=\"text-align:left;\"> date </td>\n <td style=\"text-align:left;\"> Date encoded as `YYYY-MM-DD` </td>\n <td style=\"text-align:left;\"> date </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> day_night </td>\n <td style=\"text-align:left;\"> `day` (6:00am–5:59pm) or `night` (6:00pm–5:59am) </td>\n <td style=\"text-align:left;\"> character </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> year </td>\n <td style=\"text-align:left;\"> `2015` or `2016` </td>\n <td style=\"text-align:left;\"> factor </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> month </td>\n <td style=\"text-align:left;\"> `1` (January) to `12` (December) </td>\n <td style=\"text-align:left;\"> factor </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> season </td>\n <td style=\"text-align:left;\"> `winter`, `spring`, `summer`, or `autumn` </td>\n <td style=\"text-align:left;\"> factor </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> count </td>\n <td style=\"text-align:left;\"> Sum of reported bikes rented </td>\n <td style=\"text-align:left;\"> integer </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> is_workday </td>\n <td style=\"text-align:left;\"> `TRUE` being Monday to Friday and no bank holiday </td>\n <td style=\"text-align:left;\"> logical </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> is_weekend </td>\n <td style=\"text-align:left;\"> `TRUE` being Saturday or Sunday </td>\n <td style=\"text-align:left;\"> logical </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> is_holiday </td>\n <td style=\"text-align:left;\"> `TRUE` being a bank holiday in the UK </td>\n <td style=\"text-align:left;\"> logical </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> temp </td>\n <td style=\"text-align:left;\"> Average air temperature (°C) </td>\n <td style=\"text-align:left;\"> double </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> temp_feel </td>\n <td style=\"text-align:left;\"> Average feels like temperature (°C) </td>\n <td style=\"text-align:left;\"> double </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> humidity </td>\n <td style=\"text-align:left;\"> Average air humidity (%) </td>\n <td style=\"text-align:left;\"> double </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> wind_speed </td>\n <td style=\"text-align:left;\"> Average wind speed (km/h) </td>\n <td style=\"text-align:left;\"> double </td>\n </tr>\n <tr>\n <td style=\"text-align:left;\"> weather_type </td>\n <td style=\"text-align:left;\"> Most common weather type </td>\n <td style=\"text-align:left;\"> character </td>\n </tr>\n</tbody>\n</table>\n\n`````\n:::\n:::\n\n\n## `ggplot2::ggplot()`\n\n\n::: {.cell}\n\n:::\n\n\ndata:image/s3,"s3://crabby-images/25277/25277bbdc4417bbc49f0759e38b206e152920f4c" alt=""{fig-alt=\"The help page of the ggplot() function.\" fig-width=\"175%\"}\n\n## Data\n\n\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code}\nggplot(data = bikes)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/15649/156498fe90d82b83b915c5c841e90021b76c6b03" alt=""{width=480}\n:::\n:::\n\n\n## Aesthetic Mapping(视觉映射):`aes(.)`\n\n<br>\n\n<b class='simple-highlight-grn' style='font-size:2.6rem;'>= link variables to graphical properties</b><br><br>\n\n::: incremental\n- positions (`x`, `y`)\n- colors (`color`, `fill`)\n- shapes (`shape`, `linetype`)\n- size (`size`)\n- transparency (`alpha`)\n- groupings (`group`)\n:::\n\n## Aesthetic Mapping(视觉映射):`aes(.)`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2|1,2\"}\nggplot(data = bikes) +\n aes(x = temp_feel, y = count)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/009b5/009b5207ba06e55613e0d00709a051f7d4682901" alt=""{width=480}\n:::\n:::\n\n\n## <span style='color:#4758AB;'>aes</span>thetics\n\n`aes()` outside as component\n\n\n::: {.cell}\n\n```{.r .cell-code}\nggplot(data = bikes) +\n aes(x = temp_feel, y = count)\n```\n:::\n\n\n<br>\n\n::: fragment\n`aes()` inside, explicit matching\n\n\n::: {.cell}\n\n```{.r .cell-code}\nggplot(data = bikes, mapping = aes(x = temp_feel, y = count))\n```\n:::\n\n\n<br>\n:::\n\n::: fragment\n`aes()` inside, implicit matching\n\n\n::: {.cell}\n\n```{.r .cell-code}\nggplot(bikes, aes(temp_feel, count))\n```\n:::\n\n\n<br>\n:::\n\n::: fragment\n`aes()` inside, mixed matching\n\n\n::: {.cell}\n\n```{.r .cell-code}\nggplot(bikes, aes(x = temp_feel, y = count))\n```\n:::\n\n:::\n\n# Geometrical Layers \n\n## Geometries(几何图层):geom_*\n\n<br>\n\n<b class='simple-highlight-grn' style='font-size:2.6rem;'>= interpret aesthetics as graphical representations</b><br><br>\n\n::: incremental\n- points\n- lines\n- polygons\n- text labels\n- ...\n:::\n\n## Geometries(几何图层):geom_*\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1,2,3,4|5\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/60d5d/60d5d10cb4c09b693e36d2863a86f1f03161c2fa" alt=""{width=480}\n:::\n:::\n\n\n## Visual Properties of Layers(图层属性)\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5,6,7,8,9,10,11|6,7,8,9,10\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point(\n color = \"#28a87d\",\n alpha = .5,\n shape = \"X\",\n stroke = 1,\n size = 4\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/8bcf7/8bcf7d79378be7497bad8b838c24bfc27ad30b57" alt=""{width=480}\n:::\n:::\n\n\n## Setting vs Mapping of Visual Properties\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point(\n color = \"#28a87d\",\n alpha = .5\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fdaf3/fdaf356c95bcd99e7fe2e460f35ce8c737f57948" alt=""{width=480}\n:::\n:::\n\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point(\n aes(color = season),\n alpha = .5\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/e4c8a/e4c8a2cdfa04e545e7b0f7366631a4aa12b6653d" alt=""{width=480}\n:::\n:::\n\n:::\n:::\n\n## Mapping Expressions\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point(\n aes(color = temp_feel > 20),\n alpha = .5\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/39880/39880ab8c57507b8ef6a54a9ae3e35e3af3b8600" alt=""{width=480}\n:::\n:::\n\n\n## Filter Data\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = temp, y = temp_feel)\n ) +\n geom_point(\n aes(color = weather_type == \"clear\",\n size = count),\n shape = 18,\n alpha = .5\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/a07b3/a07b3372325a4c396785be24bb8d12b3b4767b7f" alt=""{width=480}\n:::\n:::\n\n\n## Filter Data\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(\n bikes %>% filter(!is.na(weather_type)),\n aes(x = temp, y = temp_feel)\n ) +\n geom_point(\n aes(color = weather_type == \"clear\",\n size = count),\n shape = 18,\n alpha = .5\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/59e93/59e93eb3f0244670b6fbf50580a9625154086b76" alt=""{width=480}\n:::\n:::\n\n\n\n\n## Local vs. Global(应用至当前图层或所有图层)\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"3,6\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point(\n aes(color = season),\n alpha = .5\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9752c/9752cda5321a96c39d79d81f581d1aceb936fd36" alt=""{width=480}\n:::\n:::\n\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"3,4\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count,\n color = season)\n ) +\n geom_point(\n alpha = .5\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/7a03c/7a03c11355e2ac137f710e37ea0427ddfe7e7b77" alt=""{width=480}\n:::\n:::\n\n:::\n:::\n\n## Adding More Layers\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9,10,11\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count,\n color = season)\n ) +\n geom_point(\n alpha = .5\n ) +\n geom_smooth(\n method = \"lm\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/eb176/eb1761d7ec6c5c836127e121bf44bb527a95166f" alt=""{width=480}\n:::\n:::\n\n\n## Global Color Encoding\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3,4,9,10,11\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count,\n color = season)\n ) +\n geom_point(\n alpha = .5\n ) +\n geom_smooth(\n method = \"lm\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fe1af/fe1af0232608f5128f5d8289b768fe64af3f0f12" alt=""{width=480}\n:::\n:::\n\n\n## Local Color Encoding\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6,9,10,11\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point(\n aes(color = season),\n alpha = .5\n ) +\n geom_smooth(\n method = \"lm\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9fc2d/9fc2db09097d20445b4ed41b26e69619d0dbc143" alt=""{width=480}\n:::\n:::\n\n\n## The \\`group\\` Aesthetic\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point(\n aes(color = season),\n alpha = .5\n ) +\n geom_smooth(\n aes(group = day_night),\n method = \"lm\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fdcea/fdceadfd074ce19da35e489c92cd33ff4d0c8686" alt=""{width=480}\n:::\n:::\n\n\n## Set Both as Global Aesthetics\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4,5\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count,\n color = season,\n group = day_night)\n ) +\n geom_point(\n alpha = .5\n ) +\n geom_smooth(\n method = \"lm\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/27bf4/27bf465617ef75fd78a59236e72a33468f6998c5" alt=""{width=480}\n:::\n:::\n\n\n## Overwrite Global Aesthetics\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4,12\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count,\n color = season,\n group = day_night)\n ) +\n geom_point(\n alpha = .5\n ) +\n geom_smooth(\n method = \"lm\",\n color = \"black\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/acb5d/acb5d8faff7cb6d6655d78fee1d77acce6e8617e" alt=""{width=480}\n:::\n:::\n\n\n\n\n# Statistical Layers\n\n\n## \\`stat_\\*()\\` and \\`geom_\\*()\\`\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(bikes, aes(x = temp_feel, y = count)) +\n stat_smooth(geom = \"smooth\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/0ab97/0ab97c9f109b25eb4de949b8406756318e7b51ab" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(bikes, aes(x = temp_feel, y = count)) +\n geom_smooth(stat = \"smooth\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/aa20e/aa20e5fa47b6d43abc5014358a9618b202faaa98" alt=""{width=480}\n:::\n:::\n\n:::\n\n\n## \\`stat_\\*()\\` and \\`geom_\\*()\\`\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(bikes, aes(x = season)) +\n stat_count(geom = \"bar\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4a8b9/4a8b94e73e94bc6a6f6073bdd572b9a7fc18a5ba" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(bikes, aes(x = season)) +\n geom_bar(stat = \"count\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4cbda/4cbda7545423e647b5bc58f7b2600e526d4bc711" alt=""{width=480}\n:::\n:::\n\n:::\n\n\n## \\`stat_\\*()\\` and \\`geom_\\*()\\`\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(bikes, aes(x = date, y = temp_feel)) +\n stat_identity(geom = \"point\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/40adc/40adc0ebaa8b2e93fe10866f63209ab8ceb7bb4c" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"2\"}\nggplot(bikes, aes(x = date, y = temp_feel)) +\n geom_point(stat = \"identity\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/78563/7856356f42da12ddae484ad5d240949174a06273" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Statistical Summaries\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5|3\"}\nggplot(\n bikes, \n aes(x = season, y = temp_feel)\n ) +\n stat_summary() \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/2ddee/2ddeed68bcce784818d2551bd430dc9da1067980" alt=""{width=480}\n:::\n:::\n\n\n\n## Statistical Summaries\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6,7\"}\nggplot(\n bikes, \n aes(x = season, y = temp_feel)\n ) +\n stat_summary(\n fun.data = mean_se, ## the default\n geom = \"pointrange\" ## the default\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/c76a9/c76a942a939e281ad32b0e8422f13decbb4ba980" alt=""{width=480}\n:::\n:::\n\n\n\n## Statistical Summaries\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5|5,6,11|6,7,8,9,10,11|7,8\"}\nggplot(\n bikes, \n aes(x = season, y = temp_feel)\n ) +\n geom_boxplot() +\n stat_summary(\n fun = mean,\n geom = \"point\",\n color = \"#28a87d\",\n size = 3\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/afd8c/afd8ce00b2b5ec8004c6a8ff53b9782fbdac63d8" alt=""{width=480}\n:::\n:::\n\n\n\n## Statistical Summaries\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5,6,7,8,9|7,8\"}\nggplot(\n bikes, \n aes(x = season, y = temp_feel)\n ) +\n stat_summary(\n fun = mean, \n fun.max = function(y) mean(y) + sd(y), \n fun.min = function(y) mean(y) - sd(y) \n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/08ae2/08ae2f98c10e0a498eb59ac79f0b7e6998580473" alt=""{width=480}\n:::\n:::\n\n\n\n\n# Extending a ggplot\n\n## Store a ggplot as Object\n\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"1,16\"}\ng <-\n ggplot(\n bikes,\n aes(x = temp_feel, y = count,\n color = season,\n group = day_night)\n ) +\n geom_point(\n alpha = .5\n ) +\n geom_smooth(\n method = \"lm\",\n color = \"black\"\n )\n\nclass(g)\n```\n\n::: {.cell-output .cell-output-stdout}\n\n```\n[1] \"gg\" \"ggplot\"\n```\n\n\n:::\n:::\n\n\n## Inspect a ggplot Object\n\n\n::: {.cell}\n\n```{.r .cell-code}\ng$data\n```\n\n::: {.cell-output .cell-output-stdout}\n\n```\n# A tibble: 1,454 × 14\n date day_night year month season count is_workday is_weekend\n <date> <chr> <fct> <fct> <fct> <int> <lgl> <lgl> \n 1 2015-01-04 day 2015 1 winter 6830 FALSE TRUE \n 2 2015-01-04 night 2015 1 winter 2404 FALSE TRUE \n 3 2015-01-05 day 2015 1 winter 14763 TRUE FALSE \n 4 2015-01-05 night 2015 1 winter 5609 TRUE FALSE \n 5 2015-01-06 day 2015 1 winter 14501 TRUE FALSE \n 6 2015-01-06 night 2015 1 winter 6112 TRUE FALSE \n 7 2015-01-07 day 2015 1 winter 16358 TRUE FALSE \n 8 2015-01-07 night 2015 1 winter 4706 TRUE FALSE \n 9 2015-01-08 day 2015 1 winter 9971 TRUE FALSE \n10 2015-01-08 night 2015 1 winter 5630 TRUE FALSE \n# ℹ 1,444 more rows\n# ℹ 6 more variables: is_holiday <lgl>, temp <dbl>, temp_feel <dbl>,\n# humidity <dbl>, wind_speed <dbl>, weather_type <chr>\n```\n\n\n:::\n:::\n\n\n## Inspect a ggplot Object\n\n\n::: {.cell}\n\n```{.r .cell-code}\ng$mapping\n```\n\n::: {.cell-output .cell-output-stdout}\n\n```\nAesthetic mapping: \n* `x` -> `temp_feel`\n* `y` -> `count`\n* `colour` -> `season`\n* `group` -> `day_night`\n```\n\n\n:::\n:::\n\n\n## Extend a ggplot Object: Add Layers\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code}\ng +\n geom_rug(\n alpha = .2\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/c5efa/c5efa63b76f2e0a983bd1c6c397b9487b470464f" alt=""{width=480}\n:::\n:::\n\n\n## Remove a Layer from the Legend\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4\"}\ng +\n geom_rug(\n alpha = .2,\n show.legend = FALSE\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/463e1/463e1f2c734d8449d5b7f95e72a179b2f1bb958f" alt=""{width=480}\n:::\n:::\n\n\n## Extend a ggplot Object: Add Labels\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2,3,4\"}\ng +\n xlab(\"Feels-like temperature (°F)\") +\n ylab(\"Reported bike shares\") +\n ggtitle(\"TfL bike sharing trends\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3304a/3304a2cc40562cddc74fc9fb8f1515ff04e260de" alt=""{width=480}\n:::\n:::\n\n\n## Extend a ggplot Object: Add Labels\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2,3,4,5,6\"}\ng +\n labs(\n x = \"Feels-like temperature (°F)\",\n y = \"Reported bike shares\",\n title = \"TfL bike sharing trends\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4b016/4b01626ee8de7dbd231d9e2df6ff6abdde284404" alt=""{width=480}\n:::\n:::\n\n\n## Extend a ggplot Object: Add Labels\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6\"}\ng <- g +\n labs(\n x = \"Feels-like temperature (°F)\",\n y = \"Reported bike shares\",\n title = \"TfL bike sharing trends\",\n color = \"Season:\"\n )\n\ng\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3bcdb/3bcdbbc64fb5ad77878844d6fd149cc9f5182e19" alt=""{width=480}\n:::\n:::\n\n\n## Extend a ggplot Object: Add Labels\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6,7,9\"}\ng +\n labs(\n x = \"Feels-like temperature (°F)\",\n y = \"Reported bike shares\",\n title = \"TfL bike sharing trends\",\n subtitle = \"Reported bike rents versus feels-like temperature in London\",\n caption = \"Data: TfL\",\n color = \"Season:\",\n tag = \"Fig. 1\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fa06f/fa06f9d97b785d5bb8f48568654471bdb8082f3c" alt=""{width=480}\n:::\n:::\n\n\n## Extend a ggplot Object: Add Labels\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"3\"}\ng +\n labs(\n x = \"\",\n caption = \"Data: TfL\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/943fc/943fccbb3aba207cb9b244c2ac9931aedea9a14b" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"3\"}\ng +\n labs(\n x = NULL,\n caption = \"Data: TfL\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/d95a6/d95a6caa2b046c71149d80c8396f03c81c086065" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Extend a ggplot Object: Themes\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code}\ng + theme_light()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/e7421/e7421d6c70cb7b15c9f440599aa653e3ac0601d9" alt=""{width=480}\n:::\n:::\n\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code}\ng + theme_minimal()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/2abdb/2abdbe4bac3af66971b66056de50298c3764b9f4" alt=""{width=480}\n:::\n:::\n\n:::\n:::\n\n## Change the Theme Base Settings\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2,3|1,2,3,4\"}\ng + theme_light(\n base_size = 14\n)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/45ae4/45ae48371a6f43348a6c282560f44b6958ea0a78" alt=""{width=480}\n:::\n:::\n\n\n## Set a Theme Globally\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code}\ntheme_set(theme_light())\n\ng\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/af7e7/af7e7be64a4a6bff23d3a1bb889dd24718087283" alt=""{width=480}\n:::\n:::\n\n\n## Change the Theme Base Settings\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2,3|1,2,3,4\"}\ntheme_set(theme_light(\n base_size = 14\n))\n\ng\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3a6af/3a6afc27566ee4f7715c0f31818a50840f946f73" alt=""{width=480}\n:::\n:::\n\n\n\n## Overwrite Specific Theme Settings\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2|3\"}\ng +\n theme(\n panel.grid.minor = element_blank()\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/0cce9/0cce93b108fd51851f8d7c041c2feb06783d0bc7" alt=""{width=480}\n:::\n:::\n\n\n## Overwrite Specific Theme Settings\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4\"}\ng +\n theme(\n panel.grid.minor = element_blank(),\n plot.title = element_text(face = \"bold\")\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4e876/4e876db376c0640ccad0aeaf5c93710060eb03da" alt=""{width=480}\n:::\n:::\n\n\n## Overwrite Specific Theme Settings\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5\"}\ng +\n theme(\n panel.grid.minor = element_blank(),\n plot.title = element_text(face = \"bold\"),\n legend.position = \"top\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/1d98a/1d98af4c331faf532201566981e90b2f20acdc96" alt=""{width=480}\n:::\n:::\n\n\n## Overwrite Specific Theme Settings\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5\"}\ng +\n theme(\n panel.grid.minor = element_blank(),\n plot.title = element_text(face = \"bold\"),\n legend.position = \"none\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/0884d/0884d3d2789e3eed497cd64608770efca79cc01a" alt=""{width=480}\n:::\n:::\n\n\n## Overwrite Specific Theme Settings\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6|2,3,4,6,7\"}\ng +\n theme(\n panel.grid.minor = element_blank(),\n plot.title = element_text(face = \"bold\"),\n legend.position = \"top\",\n plot.title.position = \"plot\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/b3b5b/b3b5b90f7bf0ba0f578655ff63d3f2302e584385" alt=""{width=480}\n:::\n:::\n\n\n## Overwrite Theme Settings Globally\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1|2,3,4,5|1,2,3,4,5,6\"}\ntheme_update(\n panel.grid.minor = element_blank(),\n plot.title = element_text(face = \"bold\"),\n legend.position = \"top\",\n plot.title.position = \"plot\"\n)\n\ng\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/598c8/598c843513ee268b898d68cbad180da388aea2da" alt=""{width=480}\n:::\n:::\n\n\n## Save the Graphic\n\n\n::: {.cell}\n\n```{.r .cell-code}\nggsave(g, filename = \"my_plot.png\")\n```\n:::\n\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code}\nggsave(\"my_plot.png\")\n```\n:::\n\n:::\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code}\nggsave(\"my_plot.png\", width = 8, height = 5, dpi = 600)\n```\n:::\n\n:::\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code}\nggsave(\"my_plot.pdf\", width = 20, height = 12, unit = \"cm\", device = cairo_pdf)\n```\n:::\n\n:::\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code}\ngrDevices::cairo_pdf(\"my_plot.pdf\", width = 10, height = 7)\ng\ndev.off()\n```\n:::\n\n:::\n\n------------------------------------------------------------------------\n\n<br>\n\ndata:image/s3,"s3://crabby-images/6c428/6c428e90b43eb543c87daf5f7022455e6bb1220a" alt="Modified from canva.com"{fig-alt=\"A comparison of vector and raster graphics.\" fig-width=\"150%\"}\n\n# Facets(面)\n\n## Facets(面)\n\n<br>\n\n<b class='simple-highlight-grn' style='font-size:2.6rem;'>= split variables to multiple panels</b><br><br>\n\n::: fragment\nFacets are also known as:\n\n- small multiples\n- trellis graphs\n- lattice plots\n- conditioning\n:::\n\n------------------------------------------------------------------------\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/6f685/6f6854773df4bb811ab957d84a58eac9ddf5c213" alt=""{width=480}\n:::\n:::\n\n\n::: fragment\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/6aaf7/6aaf7f42c7e42c960759e2ba4cce16be0e64bb99" alt=""{width=480}\n:::\n:::\n\n:::\n:::\n\n## Setup\n\n\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1,2,3,4,5,6,7,8,9,10|12\"}\ng <-\n ggplot(\n bikes,\n aes(x = temp_feel, y = count,\n color = season)\n ) +\n geom_point(\n alpha = .3,\n guide = \"none\"\n )\n\ng\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/02cb2/02cb21c916bded14114bea6a78ac033ea25a0ac7" alt=""{width=480}\n:::\n:::\n\n\n## Wrapped Facets\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1,2,3,4|2,4|3\"}\ng +\n facet_wrap(\n vars(day_night)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/39c6e/39c6ed892082bc5644881e11b124e13be779afc0" alt=""{width=480}\n:::\n:::\n\n\n## Wrapped Facets\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3\"}\ng +\n facet_wrap(\n ~ day_night\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/97b5b/97b5b2cb72a469d6cda060b0aff402a064791e3b" alt=""{width=480}\n:::\n:::\n\n\n## Facet Multiple Variables\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3\"}\ng +\n facet_wrap(\n ~ is_workday + day_night\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/dfd92/dfd92e6cbafe86238c15b2be4151a072ca9299c7" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Cols + Rows\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4\"}\ng +\n facet_wrap(\n ~ day_night,\n ncol = 1\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/8aab3/8aab3751ca2aff1fcf8ac0e7cbded194c39f17cb" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Free Scaling\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5\"}\ng +\n facet_wrap(\n ~ day_night,\n ncol = 1,\n scales = \"free\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/b048e/b048e2d2615501f6d88ab705cc46850989cc3a7f" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Free Scaling\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5\"}\ng +\n facet_wrap(\n ~ day_night,\n ncol = 1,\n scales = \"free_y\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/efd78/efd7889bb2e52b4499e1f302d927ad5c762d172c" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Switch Labels\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5\"}\ng +\n facet_wrap(\n ~ day_night,\n ncol = 1,\n switch = \"x\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/89983/899832f66984bbadb447ac9201bab9af5f9c6893" alt=""{width=480}\n:::\n:::\n\n\n## Gridded Facets\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2,5|3,4\"}\ng +\n facet_grid(\n rows = vars(day_night),\n cols = vars(is_workday)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/563cb/563cb2c5c46c26f2627a40d6b07de5d5e62f1b28" alt=""{width=480}\n:::\n:::\n\n\n## Gridded Facets\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3\"}\ng +\n facet_grid(\n day_night ~ is_workday\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/71a52/71a526d641db6cb3c6f89450380d93899b325335" alt=""{width=480}\n:::\n:::\n\n\n## Facet Multiple Variables\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3\"}\ng +\n facet_grid(\n day_night ~ is_workday + season\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/e1a12/e1a126bdc58e584c9eb508c20d2e58cb8620dd77" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Free Scaling\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4\"}\ng +\n facet_grid(\n day_night ~ is_workday,\n scales = \"free\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/71224/7122478416715c975b182707175f1913cb0b48a8" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Switch Labels\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"5\"}\ng +\n facet_grid(\n day_night ~ is_workday,\n scales = \"free\",\n switch = \"y\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/b798e/b798ede3882ceee4da69895e88de88fc043b0eb0" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Proportional Spacing\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4,5|5\"}\ng +\n facet_grid(\n day_night ~ is_workday,\n scales = \"free\",\n space = \"free\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/48abe/48abe1d7b6f048408303360dcabc96f081e2125e" alt=""{width=480}\n:::\n:::\n\n\n## Facet Options: Proportional Spacing\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4,5\"}\ng +\n facet_grid(\n day_night ~ is_workday,\n scales = \"free_y\",\n space = \"free_y\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/5f955/5f955a10a971a825870a4f737b91fe553036005b" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1,2,3,4,5,6,7,8,9,10,11,12|8,9,10\"}\nggplot(\n diamonds,\n aes(x = carat, y = price)\n ) +\n geom_point(\n alpha = .3\n ) +\n geom_smooth(\n method = \"lm\",\n se = FALSE,\n color = \"dodgerblue\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/0e2ad/0e2ad62174ff3f7c8c4b7bfaf74d178211395ce6" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"13,14,15,16,17\"}\nggplot(\n diamonds,\n aes(x = carat, y = price)\n ) +\n geom_point(\n alpha = .3\n ) +\n geom_smooth(\n method = \"lm\",\n se = FALSE,\n color = \"dodgerblue\"\n ) +\n facet_grid(\n cut ~ clarity,\n space = \"free_x\",\n scales = \"free_x\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/f40e4/f40e4435e197274f46b37398b2c05cffe2656494" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet (Dark Theme Bonus)\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"19,20,21,22\"}\nggplot(\n diamonds,\n aes(x = carat, y = price)\n ) +\n geom_point(\n alpha = .3,\n color = \"white\"\n ) +\n geom_smooth(\n method = \"lm\",\n se = FALSE,\n color = \"dodgerblue\"\n ) +\n facet_grid(\n cut ~ clarity,\n space = \"free_x\",\n scales = \"free_x\"\n ) +\n theme_dark(\n base_size = 14\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4b23b/4b23ba8d4652b9776699c9b27b188e8b04198ddb" alt=""{width=480}\n:::\n:::\n\n\n# Scales(尺度)\n\n\n\n\n\n## Scales\n\n<br>\n\n<b class='simple-highlight-grn' style='font-size:2.6rem;'>= translate between variable ranges and property ranges</b><br><br>\n\n::: incremental\n- feels-like temperature ⇄ x\n- reported bike shares ⇄ y\n- season ⇄ color\n- year ⇄ shape\n- ...\n:::\n\n## Scales\n\nThe `scale_*()` components control the properties of all the<br><b class='simple-highlight-ylw'>aesthetic dimensions mapped to the data.</b>\n\n<br>Consequently, there are `scale_*()` functions for all aesthetics such as:\n\n- **positions** via `scale_x_*()` and `scale_y_*()`\n\n- **colors** via `scale_color_*()` and `scale_fill_*()`\n\n- **sizes** via `scale_size_*()` and `scale_radius_*()`\n\n- **shapes** via `scale_shape_*()` and `scale_linetype_*()`\n\n- **transparency** via `scale_alpha_*()`\n\n## Scales\n\nThe `scale_*()` components control the properties of all the<br><b class='simple-highlight-ylw'>aesthetic dimensions mapped to the data.</b>\n\n<br>The extensions (`*`) can be filled by e.g.:\n\n- `continuous()`, `discrete()`, `reverse()`, `log10()`, `sqrt()`, `date()` for positions\n\n- `continuous()`, `discrete()`, `manual()`, `gradient()`, `gradient2()`, `brewer()` for colors\n\n- `continuous()`, `discrete()`, `manual()`, `ordinal()`, `area()`, `date()` for sizes\n\n- `continuous()`, `discrete()`, `manual()`, `ordinal()` for shapes\n\n- `continuous()`, `discrete()`, `manual()`, `ordinal()`, `date()` for transparency\n\n------------------------------------------------------------------------\n\ndata:image/s3,"s3://crabby-images/7919b/7919b01930fe840b7241ff10cfa0cbc1fdb81066" alt="Illustration by [Allison Horst"](../../img/concepts/continuous_discrete.png){fig-size=\"120%\" fig-align=\"center\" fig-alt=\"Allison Horsts illustration ofthe correct use of continuous versus discrete; however, in {ggplot2} these are interpeted in a different way: as quantitative and qualitative.\"}\n\n## Continuous vs. Discrete in {ggplot2}\n\n::: {layout-ncol=\"2\"}\n## Continuous:<br>quantitative or numerical data\n\n- height\n- weight\n- age\n- counts\n\n## Discrete:<br>qualitative or categorical data\n\n- species\n- sex\n- study sites\n- age group\n:::\n\n## Continuous vs. Discrete in {ggplot2}\n\n::: {layout-ncol=\"2\"}\n## Continuous:<br>quantitative or numerical data\n\n- height (continuous)\n- weight (continuous)\n- age (continuous or discrete)\n- counts (discrete)\n\n## Discrete:<br>qualitative or categorical data\n\n- species (nominal)\n- sex (nominal)\n- study site (nominal or ordinal)\n- age group (ordinal)\n:::\n\n## Aesthetics + Scales\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3,4\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/cf686/cf686bc15d25101b2fb3b2e9f5068488f06c1c8f" alt=""{width=480}\n:::\n:::\n\n\n## Aesthetics + Scales\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3,4,7,8,9|7,8,9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_date() +\n scale_y_continuous() +\n scale_color_discrete()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/f2013/f201304fff6ed1a1605b0a4801737435cf170c9e" alt=""{width=480}\n:::\n:::\n\n\n## Scales\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"7\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_continuous() +\n scale_y_continuous() +\n scale_color_discrete()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/24180/24180f1edbfce2e18cd30d0fa2d559eac873a8c7" alt=""{width=480}\n:::\n:::\n\n\n## Scales\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_continuous() +\n scale_y_log10() +\n scale_color_discrete()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/971e9/971e9fc787051270107c5c6b00f65fba4e835e3e" alt=""{width=480}\n:::\n:::\n\n\n## Scales\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_continuous() +\n scale_y_log10() +\n scale_color_viridis_d()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/f56ef/f56efc712edd73688b90c4c77922ce3a2063fb30" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8,9,10|9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) + \n geom_point() +\n scale_y_continuous(\n trans = \"log10\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fa8f2/fa8f2e6b0510a45cb0ce895400da196ea2dd232f" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"7,8,9|8\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\"\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/06486/06486d600ea5dfe409c079f577358867f78d5c47" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = seq(0, 60000, by = 15000)\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/ffb26/ffb26d3d248e89410f66672624e21c9ce1eaabd3" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = 0:4*15000\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/dc22b/dc22bf7cab2dd4fd5cbb0135ee770dfa65113e69" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = c(0, 2:12*2500, 40000, 50000)\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/b1b2a/b1b2aeab544337c7e81bbd5362d69cb0c00e7848" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8,10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares in thousands\",\n breaks = 0:4*15000,\n labels = 0:4*15\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/cfe4c/cfe4c1ebc52f9c78aee57c2cd7ba310f32679839" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares in thousands\",\n breaks = 0:4*15000,\n labels = paste(0:4*15000, \"bikes\")\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/a6c74/a6c74f8a9bc7002f1fae1ac4a8e2484424060e52" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = 0:4*15000,\n limits = c(NA, 60000)\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/d8b9e/d8b9eb14ce1d3fddd38da9cae42dd2c893db3c80" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = 0:4*15000,\n expand = c(0, 0)\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fbf15/fbf155097c7a33901d0cf43a519a8e65fbfc8dd8" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = -1:5*15000,\n expand = c(.5, .5) ## c(add, mult)\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/15c0c/15c0c5b5eef6ef9c3d3859bde394957b41869e2a" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = -1:5*15000,\n expand = expansion(add = 2000)\n ) \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4a927/4a927a6421448f2cbda6327cc93f0bab4beb02ee" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_continuous\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_y_continuous(\n name = \"Reported bike shares\",\n breaks = 0:4*15000,\n guide = \"none\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/f9529/f9529dc4482ff1dde5e3e84ff4c5c842cfc27803" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_date\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"7,10|7,8,9,10|9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_date(\n name = NULL,\n date_breaks = \"4 months\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/0fb24/0fb24d9e83ab9f3aa3bd1286f9e8d2f650cf867b" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_date\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_date(\n name = NULL,\n date_breaks = \"20 weeks\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9e95b/9e95bcfb28ee4856905c1114958d4eddfe060b02" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_date\\` with \\`strftime()\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9,10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_date(\n name = NULL,\n date_breaks = \"6 months\",\n date_labels = \"%Y/%m/%d\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/7b03d/7b03d2b8e2b7b9e6511f9aa55355084920028b63" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_date\\` with \\`strftime()\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_x_date(\n name = NULL,\n date_breaks = \"6 months\",\n date_labels = \"%b '%y\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9cf05/9cf052c8b4c2e56e78acd1a63eb32e13ff81a582" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_discrete\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3,6,9|6,7,8,9|7,8\"}\nggplot(\n bikes,\n aes(x = season, y = count)\n ) +\n geom_boxplot() +\n scale_x_discrete(\n name = \"Period\",\n labels = c(\"Dec-Feb\", \"Mar-May\", \"Jun-Aug\", \"Sep-Nov\")\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/404ad/404ad733418b47f1c72114082fd4a4a6c33c00c5" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_x\\|y_discrete\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8\"}\nggplot(\n bikes,\n aes(x = season, y = count)\n ) +\n geom_boxplot() +\n scale_x_discrete(\n name = \"Season\",\n expand = c(.5, 0) ## add, mult\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/b898f/b898fbc95e6f041d80149b214c6bafb717c4d45e" alt=""{width=480}\n:::\n:::\n\n\n## Discrete or Continuous?\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3,5,6,7\"}\nggplot(\n bikes,\n aes(x = as.numeric(season), y = count)\n ) +\n geom_boxplot(\n aes(group = season)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9fb3a/9fb3a4f9e2808b6355cb821694cbd3a5c02034d0" alt=""{width=480}\n:::\n:::\n\n\n## Discrete or Continuous?\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"9,10,11,12,13|11|12\"}\nggplot(\n bikes,\n aes(x = as.numeric(season),\n y = count)\n ) +\n geom_boxplot(\n aes(group = season)\n ) +\n scale_x_continuous(\n name = \"Season\",\n breaks = 1:4,\n labels = levels(bikes$season)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/61066/61066f8f039e0f32b64b919f61f45074130636cf" alt=""{width=480}\n:::\n:::\n\n\n## Discrete or Continuous?\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3,4\"}\nggplot(\n bikes,\n aes(x = as.numeric(season) + \n as.numeric(season) / 8,\n y = count)\n ) +\n geom_boxplot(\n aes(group = season)\n ) +\n scale_x_continuous(\n name = \"Season\",\n breaks = 1:4,\n labels = levels(bikes$season)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fd24b/fd24b312a10f0ebab6caced05ced33cdc25f6f19" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_color\\|fill_discrete\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"7,10|7,8,9,10|8,9\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_color_discrete(\n name = \"Season:\",\n type = c(\"#69b0d4\", \"#00CB79\", \"#F7B01B\", \"#a78f5f\")\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/e9692/e96926f1929b4bcdaf280640eb8679d521fb8a24" alt=""{width=480}\n:::\n:::\n\n\n## Inspect Assigned Colors\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1|12|14\"}\ng <- ggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_color_discrete(\n name = \"Season:\",\n type = c(\"#3ca7d9\", \"#1ec99b\", \"#F7B01B\", \"#bb7e8f\")\n )\n\ngb <- ggplot_build(g)\n\ngb$data[[1]][c(1:5, 200:205, 400:405), 1:5]\n```\n\n::: {.cell-output .cell-output-stdout}\n\n```\n colour x y PANEL group\n1 #3ca7d9 16439 6830 1 1\n2 #3ca7d9 16439 2404 1 1\n3 #3ca7d9 16440 14763 1 1\n4 #3ca7d9 16440 5609 1 1\n5 #3ca7d9 16441 14501 1 1\n200 #1ec99b 16538 8830 1 2\n201 #1ec99b 16539 24019 1 2\n202 #1ec99b 16539 10500 1 2\n203 #1ec99b 16540 25640 1 2\n204 #1ec99b 16540 11830 1 2\n205 #1ec99b 16541 22216 1 2\n400 #F7B01B 16638 12079 1 3\n401 #F7B01B 16639 26646 1 3\n402 #F7B01B 16639 12446 1 3\n403 #F7B01B 16640 11312 1 3\n404 #F7B01B 16640 4722 1 3\n405 #F7B01B 16641 22748 1 3\n```\n\n\n:::\n:::\n\n\n## \\`scale_color\\|fill_discrete\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1,2,3,4,5,6|1,16\"}\nmy_colors <- c(\n `winter` = \"#3c89d9\",\n `spring` = \"#1ec99b\",\n `summer` = \"#F7B01B\",\n `autumn` = \"#a26e7c\"\n)\n\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_color_discrete(\n name = \"Season:\",\n type = my_colors\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/48491/48491105bdbd015bd432d432e86ac28f9400b9e8" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_color\\|fill_discrete\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2,5|1,16\"}\nmy_colors_alphabetical <- c(\n `autumn` = \"#a26e7c\",\n `spring` = \"#1ec99b\",\n `summer` = \"#F7B01B\",\n `winter` = \"#3c89d9\"\n)\n\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_color_discrete(\n name = \"Season:\",\n type = my_colors_alphabetical\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/559bc/559bc2e9164e23f55d2eed3b377316d14f810c5f" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_color\\|fill_discrete\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1|11,12,13\"}\nlibrary(RColorBrewer)\n\nggplot(\n bikes,\n aes(x = date, y = count,\n color = season)\n ) +\n geom_point() +\n scale_color_discrete(\n name = \"Season:\",\n type = brewer.pal(\n n = 4, name = \"Dark2\"\n )\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/da4f1/da4f1f9bbdcc50a1c5b7a9853d011644dc39ac64" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_color\\|fill_manual\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"4,9,10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = weather_type)\n ) +\n geom_point() +\n scale_color_manual(\n name = \"Season:\",\n values = brewer.pal(n = 6, name = \"Pastel1\"),\n na.value = \"black\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3f72b/3f72b5989326434335aded1e61d63ab68a417710" alt=""{width=480}\n:::\n:::\n\n\n## \\`scale_color\\|fill_carto_d\\`\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"7,8,9,10\"}\nggplot(\n bikes,\n aes(x = date, y = count,\n color = weather_type)\n ) +\n geom_point() +\n rcartocolor::scale_color_carto_d(\n name = \"Season:\",\n palette = \"Pastel\",\n na.value = \"black\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4ee9c/4ee9c4d8529c08afbf1f55f2c4fd0eb76f1ec4d6" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"1|10|20\"}\nfacet <-\n ggplot(\n diamonds,\n aes(x = carat, y = price)\n ) +\n geom_point(\n alpha = .3\n ) +\n geom_smooth(\n aes(color = cut),\n method = \"lm\",\n se = FALSE\n ) +\n facet_grid(\n cut ~ clarity,\n space = \"free_x\",\n scales = \"free_x\"\n )\n\nfacet\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3456d/3456d6c7d67e3b786a982b2353a6e2da433e2868" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code}\nfacet +\n scale_x_continuous(\n breaks = 0:5\n ) +\n scale_y_continuous(\n limits = c(0, 30000),\n breaks = 0:3*10000,\n labels = c(\"$0\", \"$10,000\", \"$20,000\", \"$30,000\")\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/dc587/dc5871e6bda148b0525819dcee8bde28662ea64b" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8,9,10,11,12,13,14\"}\nfacet +\n scale_x_continuous(\n breaks = 0:5\n ) +\n scale_y_continuous(\n limits = c(0, 30000),\n breaks = 0:3*10000,\n labels = paste0(\n \"$\", format(\n 0:3*10000, \n big.mark = \",\", \n trim = TRUE\n )\n )\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/a5241/a5241d40fc831bfaf35129d80bdedf6d9f30bf5a" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8,9,10,11,12,13\"}\nfacet +\n scale_x_continuous(\n breaks = 0:5\n ) +\n scale_y_continuous(\n limits = c(0, 30000),\n breaks = 0:3*10000,\n labels = function(y) paste0(\n \"$\", format(\n y, big.mark = \",\",\n trim = TRUE\n )\n )\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/6ce38/6ce3878a44a5691f9610a31c7867bd425a7aae27" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8\"}\nfacet +\n scale_x_continuous(\n breaks = 0:5\n ) +\n scale_y_continuous(\n limits = c(0, 30000),\n breaks = 0:3*10000,\n labels = scales::dollar_format()\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/7fc0e/7fc0ea357e7b4e545b9537f7d34ba8103a2d9b12" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"10,11,12,13\"}\nfacet +\n scale_x_continuous(\n breaks = 0:5\n ) +\n scale_y_continuous(\n limits = c(0, 30000),\n breaks = 0:3*10000,\n labels = scales::dollar_format()\n ) +\n scale_color_brewer(\n palette = \"Set2\",\n guide = \"none\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/5c352/5c352936914372ed057b17fb7c5442c36b80bc91" alt=""{width=480}\n:::\n:::\n\n\n## Diamonds Facet\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"13,14,15\"}\nfacet +\n scale_x_continuous(\n breaks = 0:5\n ) +\n scale_y_continuous(\n limits = c(0, 30000),\n breaks = 0:3*10000,\n labels = scales::dollar_format()\n ) +\n scale_color_brewer(\n palette = \"Set2\"\n ) +\n theme(\n legend.position = \"none\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fd7b7/fd7b7b2bdfa24ef40f5fb00802460b1f6ee1ccff" alt=""{width=480}\n:::\n:::\n\n\n# Coordinate Systems(投影)\n\n## Coordinate Systems\n\n<br>\n\n<b class='simple-highlight-grn' style='font-size:2.6rem;'>= interpret the position aesthetics</b><br><br>\n\n::: incremental\n- **linear coordinate systems:** preserve the geometrical shapes\n - `coord_cartesian()`\n - `coord_fixed()`\n - `coord_flip()`\n- **non-linear coordinate systems:** likely change the geometrical shapes\n - `coord_polar()`\n - `coord_map()` and `coord_sf()`\n - `coord_trans()`\n:::\n\n## Cartesian Coordinate System\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = season, y = count)\n ) +\n geom_boxplot() +\n coord_cartesian()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/6896f/6896fb30b713d544ca31305ae742db859f2787d9" alt=""{width=480}\n:::\n:::\n\n\n## Cartesian Coordinate System\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6,7,8\"}\nggplot(\n bikes,\n aes(x = season, y = count)\n ) +\n geom_boxplot() +\n coord_cartesian(\n ylim = c(NA, 15000)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fdda2/fdda23a5324003b5cf734dfcee6970c12b260468" alt=""{width=480}\n:::\n:::\n\n\n## Changing Limits\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6,7,8\"}\nggplot(\n bikes,\n aes(x = season, y = count)\n ) +\n geom_boxplot() +\n coord_cartesian(\n ylim = c(NA, 15000)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/8d2c3/8d2c3eec5c8ccfbfa9e72141cacab2a9872f9dd1" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6,7,8\"}\nggplot(\n bikes,\n aes(x = season, y = count)\n ) +\n geom_boxplot() +\n scale_y_continuous(\n limits = c(NA, 15000)\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/a91a8/a91a8df6015219f99ecc15d35cf1117956ac04f9" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Clipping\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"8\"}\nggplot(\n bikes,\n aes(x = season, y = count)\n ) +\n geom_boxplot() +\n coord_cartesian(\n ylim = c(NA, 15000),\n clip = \"off\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/7568d/7568d641b68947ccc67624e9bce0f06dae435b16" alt=""{width=480}\n:::\n:::\n\n\n## Clipping\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"2,3|6,7,8,9,10|12\"}\nggplot(\n filter(bikes, is_holiday == TRUE),\n aes(x = temp_feel, y = count)\n ) +\n geom_point() +\n geom_text(\n aes(label = season),\n nudge_x = .3,\n hjust = 0\n ) +\n coord_cartesian(\n clip = \"off\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/b832d/b832d7303faf7df60c8ad87d14ab14973a26076b" alt=""{width=480}\n:::\n:::\n\n\n## ... or better use {ggrepel}\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n filter(bikes, is_holiday == TRUE),\n aes(x = temp_feel, y = count)\n ) +\n geom_point() +\n ggrepel::geom_text_repel(\n aes(label = season),\n nudge_x = .3,\n hjust = 0\n ) +\n coord_cartesian(\n clip = \"off\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/39d32/39d32b04a02629b4e3969a8d705f52bff8385779" alt=""{width=480}\n:::\n:::\n\n\n## Remove All Padding\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"7|8\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = count)\n ) +\n geom_point() +\n coord_cartesian(\n expand = FALSE,\n clip = \"off\"\n )\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/86460/8646057f5cdbe842853cafc02c61ce76e5fe19d3" alt=""{width=480}\n:::\n:::\n\n\n## Fixed Coordinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = temp)\n ) +\n geom_point() +\n coord_fixed()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3428e/3428ebf9efe6677871751b4bb5ac981409f00428" alt=""{width=480}\n:::\n:::\n\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp_feel, y = temp)\n ) +\n geom_point() +\n coord_fixed(ratio = 4)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/48dbc/48dbca1b646f3d00eb28974e2460f72825cc8f00" alt=""{width=480}\n:::\n:::\n\n:::\n:::\n\n## Flipped Coordinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = weather_type)\n ) +\n geom_bar() +\n coord_cartesian()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/1b5ce/1b5ced66fffe914cb0b9b67ec1478de9b9c5299e" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = weather_type)\n ) +\n geom_bar() +\n coord_flip()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/e5ab4/e5ab44b110e91628acd49950abe12ffe33167058" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Flipped Coordinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"3,6\"}\nggplot(\n bikes,\n aes(y = weather_type)\n ) +\n geom_bar() +\n coord_cartesian()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9befa/9befa2bb3a2719e82089bcc22c1e1b912c04ccf3" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"3,6\"}\nggplot(\n bikes,\n aes(x = weather_type)\n ) +\n geom_bar() +\n coord_flip()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/49e53/49e530b19c816d6a8dac26f32e2b0e271061489e" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Reminder: Sort Your Bars!\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3|2\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(y = fct_infreq(weather_type))\n ) +\n geom_bar()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/f1a2f/f1a2f277bb64fb7810940c6a1f8c2f97b99a88c5" alt=""{width=480}\n:::\n:::\n\n\n## Reminder: Sort Your Bars!\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"3,4,5\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(y = fct_rev(\n fct_infreq(weather_type)\n ))\n ) +\n geom_bar()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/01f6a/01f6a4abfa4fdd8871f6eedf56221c965077d5be" alt=""{width=480}\n:::\n:::\n\n\n## Circular Corrdinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = weather_type,\n fill = weather_type)\n ) +\n geom_bar() +\n coord_polar()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/53463/53463892899e390952f7c60c6e565ad3cd8e8f40" alt=""{width=480}\n:::\n:::\n\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = weather_type,\n fill = weather_type)\n ) +\n geom_bar() +\n coord_cartesian()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/50f80/50f8062c742850efddd71f3c49a27a2fdc2dfad1" alt=""{width=480}\n:::\n:::\n\n:::\n:::\n\n## Circular Cordinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6,7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = fct_infreq(weather_type),\n fill = weather_type)\n ) +\n geom_bar(width = 1) +\n coord_polar()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/c6c72/c6c7247787b4e49c4ddff5db64714af063352fba" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6,7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = fct_infreq(weather_type),\n fill = weather_type)\n ) +\n geom_bar(width = 1) +\n coord_cartesian()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/342a1/342a1075b284f516c251a894f63d67bba0aca709" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Circular Corrdinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = fct_infreq(weather_type),\n fill = weather_type)\n ) +\n geom_bar() +\n coord_polar(theta = \"x\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/96e5b/96e5b0f747fc5ee843fece425a06ff0de54dae8b" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = fct_infreq(weather_type),\n fill = weather_type)\n ) +\n geom_bar() +\n coord_polar(theta = \"y\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4dde9/4dde9fea16c408b39a6e769ff6ec801d8f0af70f" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Circular Corrdinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"5\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = 1, fill = weather_type)\n ) +\n geom_bar(position = \"stack\") +\n coord_polar(theta = \"y\") \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/7f7f7/7f7f750992d6033b4ef5bf2fc1bfc9297acaf1e6" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"5\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = 1, fill = weather_type)\n ) +\n geom_bar(position = \"stack\") +\n coord_cartesian() \n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/63984/6398440bc38d66821f19645b7521f65325574c4a" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Circular Corrdinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"4,6,7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = 1,\n fill = fct_rev(fct_infreq(weather_type)))\n ) +\n geom_bar(position = \"stack\") +\n coord_polar(theta = \"y\") +\n scale_fill_discrete(name = NULL)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/16228/16228ec1bc76365001ff9cf4a7a4f868f9ab9b03" alt=""{width=480}\n:::\n:::\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"4,6,7\"}\nggplot(\n filter(bikes, !is.na(weather_type)),\n aes(x = 1,\n fill = fct_rev(fct_infreq(weather_type)))\n ) +\n geom_bar(position = \"stack\") +\n coord_cartesian() +\n scale_fill_discrete(name = NULL)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/2f476/2f47611481a0ae514e4aa9fd0be650759e8fd9e3" alt=""{width=480}\n:::\n:::\n\n:::\n\n## Transform a Coordinate System\n\n\n::: {.cell output-location='column'}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp, y = count)\n ) +\n geom_point() +\n coord_trans(y = \"log10\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/f315b/f315b1175767c43631db21c7e300cfaf5f8f68dd" alt=""{width=480}\n:::\n:::\n\n\n## Transform a Coordinate System\n\n::: {layout-ncol=\"2\"}\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp, y = count,\n group = day_night)\n ) +\n geom_point() +\n geom_smooth(method = \"lm\") +\n coord_trans(y = \"log10\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/23a91/23a91d68f44b7e3b6f9cc5e6368327f64118991e" alt=""{width=480}\n:::\n:::\n\n\n::: fragment\n\n::: {.cell}\n\n```{.r .cell-code code-line-numbers=\"6\"}\nggplot(\n bikes,\n aes(x = temp, y = count,\n group = day_night)\n ) +\n geom_point() +\n geom_smooth(method = \"lm\") +\n scale_y_log10()\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/29115/2911559890141e1bb1224ed84da99f4fb026475b" alt=""{width=480}\n:::\n:::\n\n:::\n:::\n\n\n# 图形组合\n\n------------------------------------------------------------------------\n\ndata:image/s3,"s3://crabby-images/7919b/7919b01930fe840b7241ff10cfa0cbc1fdb81066" alt="Illustration by [Allison Horst"](../../img/layout/ah_patchwork.jpg){fig-align=\"center\" fig-alt=\"Allison Horsts monster illustration of the patchwork extension package.\"}\n\n::: footer\n:::\n\n------------------------------------------------------------------------\n\n::: panel-tabset\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/ff4d4/ff4d40aa4e2fec174a8481ffa9c3922ce1a6b898" alt=""{width=960}\n:::\n:::\n\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\ntheme_std <- theme_set(theme_minimal(base_size = 18))\ntheme_update(\n # text = element_text(family = \"Pally\"),\n panel.grid = element_blank(),\n axis.text = element_text(color = \"grey50\", size = 12),\n axis.title = element_text(color = \"grey40\", face = \"bold\"),\n axis.title.x = element_text(margin = margin(t = 12)),\n axis.title.y = element_text(margin = margin(r = 12)),\n axis.line = element_line(color = \"grey80\", size = .4),\n legend.text = element_text(color = \"grey50\", size = 12),\n plot.tag = element_text(size = 40, margin = margin(b = 15)),\n plot.background = element_rect(fill = \"white\", color = \"white\")\n)\n\nbikes_sorted <-\n bikes %>%\n filter(!is.na(weather_type)) %>%\n group_by(weather_type) %>%\n mutate(sum = sum(count)) %>%\n ungroup() %>%\n mutate(\n weather_type = forcats::fct_reorder(\n str_to_title(str_wrap(weather_type, 5)), sum\n )\n )\n\np1 <- ggplot(\n bikes_sorted,\n aes(x = weather_type, y = count, color = weather_type)\n ) +\n geom_hline(yintercept = 0, color = \"grey80\", size = .4) +\n stat_summary(\n geom = \"point\", fun = \"sum\", size = 12\n ) +\n stat_summary(\n geom = \"linerange\", ymin = 0, fun.max = function(y) sum(y),\n size = 2, show.legend = FALSE\n ) +\n coord_flip(ylim = c(0, NA), clip = \"off\") +\n scale_y_continuous(\n expand = c(0, 0), limits = c(0, 8500000),\n labels = scales::comma_format(scale = .0001, suffix = \"K\")\n ) +\n scale_color_viridis_d(\n option = \"magma\", direction = -1, begin = .1, end = .9, name = NULL,\n guide = guide_legend(override.aes = list(size = 7))\n ) +\n labs(\n x = NULL, y = \"Sum of reported bike shares\", tag = \"P1\",\n ) +\n theme(\n axis.line.y = element_blank(),\n axis.text.y = element_text(family = \"Pally\", color = \"grey50\", face = \"bold\",\n margin = margin(r = 15), lineheight = .9)\n )\n\np1\n```\n:::\n\n:::\n\n------------------------------------------------------------------------\n\n::: panel-tabset\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/8f08b/8f08b0e74a9c8db5e8fe8a3080ff6bbf1526205b" alt=""{width=960}\n:::\n:::\n\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np2 <- bikes_sorted %>%\n filter(season == \"winter\", is_weekend == TRUE, day_night == \"night\") %>%\n group_by(weather_type, .drop = FALSE) %>%\n mutate(id = row_number()) %>%\n ggplot(\n aes(x = weather_type, y = id, color = weather_type)\n ) +\n geom_point(size = 4.5) +\n scale_color_viridis_d(\n option = \"magma\", direction = -1, begin = .1, end = .9, name = NULL,\n guide = guide_legend(override.aes = list(size = 7))\n ) +\n labs(\n x = NULL, y = \"Reported bike shares on\\nweekend winter nights\", tag = \"P2\",\n ) +\n coord_cartesian(ylim = c(.5, NA), clip = \"off\")\n\np2\n```\n:::\n\n:::\n\n------------------------------------------------------------------------\n\n::: panel-tabset\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/ff70d/ff70d0a6e18590310fd9fe208a9b8d811a9a1f6f" alt=""{width=960}\n:::\n:::\n\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\nmy_colors <- c(\"#cc0000\", \"#000080\")\n\np3 <- bikes %>%\n group_by(week = lubridate::week(date), day_night, year) %>%\n summarize(count = sum(count)) %>%\n group_by(week, day_night) %>%\n mutate(avg = mean(count)) %>%\n ggplot(aes(x = week, y = count, group = interaction(day_night, year))) +\n geom_line(color = \"grey65\", size = 1) +\n geom_line(aes(y = avg, color = day_night), stat = \"unique\", size = 1.7) +\n annotate(\n geom = \"text\", label = c(\"Day\", \"Night\"), color = my_colors,\n x = c(5, 18), y = c(125000, 29000), size = 8, fontface = \"bold\", family = \"Pally\"\n ) +\n scale_x_continuous(breaks = c(1, 1:10*5)) +\n scale_y_continuous(labels = scales::comma_format()) +\n scale_color_manual(values = my_colors, guide = \"none\") +\n labs(\n x = \"Week of the Year\", y = \"Reported bike shares\\n(cumulative # per week)\", tag = \"P3\",\n )\n\np3\n```\n:::\n\n:::\n\n## {patchwork}\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code code-line-numbers=\"3|2,3\"}\n# install.packages(\"patchwork\")\nrequire(patchwork)\n(p1 + p2) / p3\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/02014/02014da64f13f0505100e8e74b2e416331349687" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## \"Collect Guides\"\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code}\n(p1 + p2) / p3 + plot_layout(guides = \"collect\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/77117/7711705ea76ca9b1a2a20a2976c33f05be00cb0e" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## Apply Theming\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code}\n((p1 + p2) / p3 & theme(legend.justification = \"top\")) +\nplot_layout(guides = \"collect\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/221ce/221ce8c47088b81554797b1124eb6547fbe70c54" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## Apply Theming\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code}\n(p1 + p2) / p3 & theme(legend.position = \"none\",\n plot.background = element_rect(color = \"black\", size = 3))\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/a686b/a686bf620f355af5cd6b3ffab0df99ff13caa0b3" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## Adjust Widths and Heights\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code code-line-numbers=\"2\"}\n((p1 + p2) / p3 & theme(legend.position = \"none\")) +\n plot_layout(heights = c(.2, .1), widths = c(2, 1))\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/5465c/5465c7985fa08d3c8b7f7ba1e3b163d308bac5bc" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## Use A Custom Layout\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code code-line-numbers=\"1,2,3,4|5\"}\npicasso <- \"\nAAAAAA#BBBB\nCCCCCCCCC##\nCCCCCCCCC##\"\n(p1 + p2 + p3 & theme(legend.position = \"none\")) +\nplot_layout(design = picasso)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/0c973/0c9730a3c873fbd7071a891b14b7cb4a1458ad9e" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## Add Labels\n\n\n::: {.cell}\n\n```{.r .cell-code}\npl1 <- p1 + labs(tag = NULL, title = \"Plot One\") + theme(legend.position = \"none\")\npl2 <- p2 + labs(tag = NULL, title = \"Plot Two\") + theme(legend.position = \"none\")\npl3 <- p3 + labs(tag = NULL, title = \"Plot Three\") + theme(legend.position = \"none\")\n```\n:::\n\n\n## Add Labels\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code code-line-numbers=\"2\"}\n(pl1 + pl2) / pl3 +\n plot_annotation(tag_levels = \"1\",\n tag_prefix = \"P\",\n title = \"An overarching title for all 3 plots, placed on the very top while all other titles are sitting below the tags.\")\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fc5e4/fc5e4eab8ee2a305a88e1a15a80baef28f42f8bd" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## Add Text\n\n::: panel-tabset\n### Graphic\n\n\n::: {.cell layout-align=\"center\"}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/f98b7/f98b71a5e13e1683de0249281490f9b99424fc96" alt=""{fig-align='center' width=864}\n:::\n:::\n\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\ntext <- tibble::tibble(\n x = 0, y = 0, label = \"Lorem ipsum dolor sit amet, **consectetur adipiscing elit**, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation <b style='color:#000080;'>ullamco laboris nisi</b> ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat <b style='color:#cc0000;'>cupidatat non proident</b>, sunt in culpa qui officia deserunt mollit anim id est laborum.\"\n)\npt <- ggplot(text, aes(x = x, y = y)) +\n ggtext::geom_textbox(\n aes(label = label),\n box.color = NA, width = unit(23, \"lines\"),\n color = \"grey40\", size = 6.5, lineheight = 1.4\n ) +\n coord_cartesian(expand = FALSE, clip = \"off\") +\n theme_void()\npt\n```\n:::\n\n:::\n\n## Add Text\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code}\n(p1 + pt) / p3\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fcb6e/fcb6e7022a8b3f105bc5e621f76d2b14b1c03394" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n## Add Inset Plots\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code}\npl1 + inset_element(pl2,\n l = .6, b = .1, r = 1, t = .6)\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/e9b72/e9b72a61aa270c99f108d48f429cb9f1d2fd0b7a" alt=""{fig-align='center' width=1152}\n:::\n:::\n\n\n## Add Inset Plots\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code}\npl1 + inset_element(pl2,\n l = .6, b = 0, r = 1, t = .5, align_to = 'full')\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/be247/be24792ef552bdec0a6a09920d3db899dea2d479" alt=""{fig-align='center' width=1152}\n:::\n:::\n\n\n## Add Inset Plots\n\n\n::: {.cell layout-align=\"center\"}\n\n```{.r .cell-code}\n(pl1 + inset_element(pl2,\n l = .6, b = .1, r = 1, t = .6) + pt) / pl3\n```\n\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/80db7/80db789229594d7098139e35ef3042bdb8f094b8" alt=""{fig-align='center' width=1440}\n:::\n:::\n\n\n\n## 练习\n\n\n::: {.cell}\n\n```{.r .cell-code}\nlibrary(palmerpenguins)\nlibrary(ggthemes)\npenguins\n```\n\n::: {.cell-output .cell-output-stdout}\n\n```\n# A tibble: 344 × 8\n species island bill_length_mm bill_depth_mm flipper_length_mm body_mass_g\n <fct> <fct> <dbl> <dbl> <int> <int>\n 1 Adelie Torgersen 39.1 18.7 181 3750\n 2 Adelie Torgersen 39.5 17.4 186 3800\n 3 Adelie Torgersen 40.3 18 195 3250\n 4 Adelie Torgersen NA NA NA NA\n 5 Adelie Torgersen 36.7 19.3 193 3450\n 6 Adelie Torgersen 39.3 20.6 190 3650\n 7 Adelie Torgersen 38.9 17.8 181 3625\n 8 Adelie Torgersen 39.2 19.6 195 4675\n 9 Adelie Torgersen 34.1 18.1 193 3475\n10 Adelie Torgersen 42 20.2 190 4250\n# ℹ 334 more rows\n# ℹ 2 more variables: sex <fct>, year <int>\n```\n\n\n:::\n:::\n\n\n## 效果\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/771ad/771ad04be01fa3a9a94595f5d0fdd932141ffb22" alt=""{width=768}\n:::\n:::\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n## 练习\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(\n data = penguins,\n mapping = aes(x = flipper_length_mm, y = body_mass_g)\n) +\n geom_point(aes(color = species, shape = species)) +\n geom_smooth(method = \"lm\") +\n labs(\n title = \"Body mass and flipper length\",\n subtitle = \"Dimensions for Adelie, Chinstrap, and Gentoo Penguins\",\n x = \"Flipper length (mm)\", y = \"Body mass (g)\",\n color = \"Species\", shape = \"Species\"\n ) +\n scale_color_colorblind()\n```\n:::\n\n\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/fe12c/fe12c50c1979595839499f0111559c9c54681589" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 练习\n\n:::: {.panel-tabset}\n\n### Code\n\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(\n data = penguins,\n mapping = aes(x = flipper_length_mm, y = body_mass_g)) +\n geom_point(aes(color = bill_depth_mm)) +\n geom_smooth()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4f1aa/4f1aa7e121b86a8415cd504021b5d5250550fde1" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 练习\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(\n data = penguins,\n mapping = aes(x = flipper_length_mm, y = body_mass_g, color = island)\n) +\n geom_point() +\n geom_smooth(se = FALSE)\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9eee0/9eee0f90fa34f2084187120ef97bb9e2437e7d58" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 分层展示\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(\n data = penguins,\n mapping = aes(x = flipper_length_mm, y = body_mass_g)\n) +\n geom_point() +\n geom_smooth()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/c0c3f/c0c3f497eba3a675450c5c63d8a1ca1d5be5fc0e" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 柱状图\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins, aes(x = species)) +\n geom_bar()\n```\n:::\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/2e005/2e005e7dd9e6a4ad0da0228e0f6797575c28c78f" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 柱状图\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins, aes(x = fct_infreq(species))) +\n geom_bar()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/73f1c/73f1ced9372418f22423c8365afbcf471d7e77ff" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n\n## 直方图\n\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins, aes(x = body_mass_g)) +\n geom_histogram(binwidth = 200)\n```\n:::\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/86ce0/86ce03048f770e9e5f330110e2e8f4602a345886" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 直方图\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell layout-ncol=\"2\"}\n\n```{.r .cell-code}\np1 <- ggplot(penguins, aes(x = body_mass_g)) +\n geom_histogram(binwidth = 20)\np2 <- ggplot(penguins, aes(x = body_mass_g)) +\n geom_histogram(binwidth = 2000)\np <- p1 + p2\n```\n:::\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3eec8/3eec85ffc6daa7ec5774ac351ef8a75b0bf9758a" alt=""{width=960}\n:::\n:::\n\n\n::::\n\n## 密度图\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins, aes(x = body_mass_g)) +\n geom_density()\n```\n:::\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9d324/9d324b07a687ac95e25f1e0b9015bf2455e26ada" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n\n## 箱图\n\n\n:::: {.panel-tabset}\n\n### Code\n\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = species, y = body_mass_g)) +\n geom_boxplot()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/6947a/6947a521c7264519913c369c12a50817492c4499" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 分组\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = body_mass_g, color = species)) +\n geom_density(linewidth = 0.75)\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/37f63/37f6364230ad1149e19e0d46ed0d8c17c9949114" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 分组\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = body_mass_g, color = species, fill = species)) +\n geom_density(alpha = 0.5)\n```\n:::\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/3810c/3810c5beff5f20ce3152d486d4a89e0aaf6ed671" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n\n## 分组\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = island, fill = species)) +\n geom_bar()\n```\n:::\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/9954c/9954c22a0a59c4e59f4e3e43eb94356bd7213269" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n\n## 分组\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = island, fill = species)) +\n geom_bar(position = \"fill\")\n```\n:::\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/005cf/005cf0474ef7e9b1bf2b9a7c9cbeeca7796718bc" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 分组\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = flipper_length_mm, y = body_mass_g)) +\n geom_point()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/d5bff/d5bff0766029c94370fb9789ab9fc6de2d37d73a" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 分组\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = flipper_length_mm, y = body_mass_g)) +\n geom_point(aes(color = species, shape = island))\n```\n:::\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/aed65/aed6556f06d0b8120d28e377d2d71959c2182022" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n\n## 分面\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = flipper_length_mm, y = body_mass_g)) +\n geom_point(aes(color = species, shape = species)) +\n facet_wrap(~island)\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/06801/068011af73da061202fa1c95ab3fb35ec4991bd7" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 分面\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(\n data = penguins,\n mapping = aes(\n x = bill_length_mm, y = bill_depth_mm, \n color = species, shape = species\n )\n) +\n geom_point() +\n labs(color = \"Species\")\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/98a84/98a842d8d2d2e0d46c85f60fb2ebe5e5ba1f4075" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 练习\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell layout-ncol=\"2\"}\n\n```{.r .cell-code}\np1 <- ggplot(penguins, aes(x = island, fill = species)) +\n geom_bar(position = \"fill\")\np2 <- ggplot(penguins, aes(x = species, fill = island)) +\n geom_bar(position = \"fill\")\np <- p1 + p2\n```\n:::\n\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/99c8b/99c8b2c3569190055f421e8cc493597ae0db10b2" alt=""{width=960}\n:::\n:::\n\n\n::::\n\n## 练习\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(penguins,\n aes(x = flipper_length_mm, y = body_mass_g)) +\n geom_point()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/2bca3/2bca3622c16f8e58578ef5ebb8ea5530d4610422" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 练习\n\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(mpg, aes(x = class)) +\ngeom_bar()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/77425/774258f9745efdceea6b45e01c9c7e94d477fdd6" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 练习\n\n:::: {.panel-tabset}\n\n### Code\n\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(mpg, aes(x = cty, y = hwy)) +\ngeom_point()\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/4b18b/4b18bbe261d32ae450e93fcd2690e18904e5e04c" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 练习\n\n:::: {.panel-tabset}\n\n### Code\n\n\n::: {.cell}\n\n```{.r .cell-code}\np <- ggplot(data = mpg) +\ngeom_point(mapping = aes(x = displ, y = hwy))\n```\n:::\n\n\n### Graphic\n\n\n::: {.cell}\n::: {.cell-output-display}\ndata:image/s3,"s3://crabby-images/a1d9f/a1d9f0603127213f64090ef77b395e8783e4a30f" alt=""{width=768}\n:::\n:::\n\n\n::::\n\n## 欢迎讨论!{.center}\n\n\n[<svg viewBox=\"0 0 576 512\" style=\"height:1em;position:relative;display:inline-block;top:.1em;\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M280.37 148.26L96 300.11V464a16 16 0 0 0 16 16l112.06-.29a16 16 0 0 0 15.92-16V368a16 16 0 0 1 16-16h64a16 16 0 0 1 16 16v95.64a16 16 0 0 0 16 16.05L464 480a16 16 0 0 0 16-16V300L295.67 148.26a12.19 12.19 0 0 0-15.3 0zM571.6 251.47L488 182.56V44.05a12 12 0 0 0-12-12h-56a12 12 0 0 0-12 12v72.61L318.47 43a48 48 0 0 0-61 0L4.34 251.47a12 12 0 0 0-1.6 16.9l25.5 31A12 12 0 0 0 45.15 301l235.22-193.74a12.19 12.19 0 0 1 15.3 0L530.9 301a12 12 0 0 0 16.9-1.6l25.5-31a12 12 0 0 0-1.7-16.93z\"></path>\n</svg>[苏命|https://drwater.rcees.ac.cn](https://drwater.rcees.ac.cn); <svg viewBox=\"0 0 576 512\" style=\"height:1em;position:relative;display:inline-block;top:.1em;\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M528 32H48C21.5 32 0 53.5 0 80v352c0 26.5 21.5 48 48 48h480c26.5 0 48-21.5 48-48V80c0-26.5-21.5-48-48-48zm0 400H48V80h480v352zM208 256c35.3 0 64-28.7 64-64s-28.7-64-64-64-64 28.7-64 64 28.7 64 64 64zm-89.6 128h179.2c12.4 0 22.4-8.6 22.4-19.2v-19.2c0-31.8-30.1-57.6-67.2-57.6-10.8 0-18.7 8-44.8 8-26.9 0-33.4-8-44.8-8-37.1 0-67.2 25.8-67.2 57.6v19.2c0 10.6 10 19.2 22.4 19.2zM360 320h112c4.4 0 8-3.6 8-8v-16c0-4.4-3.6-8-8-8H360c-4.4 0-8 3.6-8 8v16c0 4.4 3.6 8 8 8zm0-64h112c4.4 0 8-3.6 8-8v-16c0-4.4-3.6-8-8-8H360c-4.4 0-8 3.6-8 8v16c0 4.4 3.6 8 8 8zm0-64h112c4.4 0 8-3.6 8-8v-16c0-4.4-3.6-8-8-8H360c-4.4 0-8 3.6-8 8v16c0 4.4 3.6 8 8 8z\"></path>\n</svg>[https://drwater.rcees.ac.cn/bcard](https://drwater.rcees.ac.cn/bcard); <svg viewBox=\"0 0 512 512\" style=\"height:1em;position:relative;display:inline-block;top:.1em;\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M326.612 185.391c59.747 59.809 58.927 155.698.36 214.59-.11.12-.24.25-.36.37l-67.2 67.2c-59.27 59.27-155.699 59.262-214.96 0-59.27-59.26-59.27-155.7 0-214.96l37.106-37.106c9.84-9.84 26.786-3.3 27.294 10.606.648 17.722 3.826 35.527 9.69 52.721 1.986 5.822.567 12.262-3.783 16.612l-13.087 13.087c-28.026 28.026-28.905 73.66-1.155 101.96 28.024 28.579 74.086 28.749 102.325.51l67.2-67.19c28.191-28.191 28.073-73.757 0-101.83-3.701-3.694-7.429-6.564-10.341-8.569a16.037 16.037 0 0 1-6.947-12.606c-.396-10.567 3.348-21.456 11.698-29.806l21.054-21.055c5.521-5.521 14.182-6.199 20.584-1.731a152.482 152.482 0 0 1 20.522 17.197zM467.547 44.449c-59.261-59.262-155.69-59.27-214.96 0l-67.2 67.2c-.12.12-.25.25-.36.37-58.566 58.892-59.387 154.781.36 214.59a152.454 152.454 0 0 0 20.521 17.196c6.402 4.468 15.064 3.789 20.584-1.731l21.054-21.055c8.35-8.35 12.094-19.239 11.698-29.806a16.037 16.037 0 0 0-6.947-12.606c-2.912-2.005-6.64-4.875-10.341-8.569-28.073-28.073-28.191-73.639 0-101.83l67.2-67.19c28.239-28.239 74.3-28.069 102.325.51 27.75 28.3 26.872 73.934-1.155 101.96l-13.087 13.087c-4.35 4.35-5.769 10.79-3.783 16.612 5.864 17.194 9.042 34.999 9.69 52.721.509 13.906 17.454 20.446 27.294 10.606l37.106-37.106c59.271-59.259 59.271-155.699.001-214.959z\"></path>\n</svg>[Slides](https://drwater.rcees.ac.cn/course/public/RWEP/@PUB/SD/)]{.r-fit-text}<br><br><div class=\"columns\"><div class=\"column\" style=\"width:30%;\">[<svg viewBox=\"0 0 512 512\" style=\"height:1em;position:relative;display:inline-block;top:.1em;\" xmlns=\"http://www.w3.org/2000/svg\">\n <path d=\"M464 64H48C21.49 64 0 85.49 0 112v288c0 26.51 21.49 48 48 48h416c26.51 0 48-21.49 48-48V112c0-26.51-21.49-48-48-48zm0 48v40.805c-22.422 18.259-58.168 46.651-134.587 106.49-16.841 13.247-50.201 45.072-73.413 44.701-23.208.375-56.579-31.459-73.413-44.701C106.18 199.465 70.425 171.067 48 152.805V112h416zM48 400V214.398c22.914 18.251 55.409 43.862 104.938 82.646 21.857 17.205 60.134 55.186 103.062 54.955 42.717.231 80.509-37.199 103.053-54.947 49.528-38.783 82.032-64.401 104.947-82.653V400H48z\"></path>\n</svg>[mingsu@rcees.ac.cn](mailto:mingsu@rcees.ac.cn); ]{.r-fit-text}<br></div></div>\n\n",
|
||
"supporting": [],
|
||
"filters": [
|
||
"rmarkdown/pagebreak.lua"
|
||
],
|
||
"includes": {
|
||
"include-in-header": [
|
||
"<script src=\"../../site_libs/jquery-3.6.0/jquery-3.6.0.min.js\"></script>\n<link href=\"../../site_libs/font-awesome-6.4.2/css/all.min.css\" rel=\"stylesheet\" />\n<link href=\"../../site_libs/font-awesome-6.4.2/css/v4-shims.min.css\" rel=\"stylesheet\" />\n<script src=\"../../site_libs/bootbox-5.5.2/bootbox.min.js\"></script>\n<script src=\"../../site_libs/idb-keyvalue-3.2.0/idb-keyval-iife-compat.min.js\"></script>\n<link href=\"../../site_libs/tutorial-0.11.5.9000/tutorial.css\" rel=\"stylesheet\" />\n<script src=\"../../site_libs/tutorial-0.11.5.9000/tutorial.js\"></script>\n<script src=\"../../site_libs/kePrint-0.0.1/kePrint.js\"></script>\n<link href=\"../../site_libs/lightable-0.0.1/lightable.css\" rel=\"stylesheet\" />\n"
|
||
],
|
||
"include-after-body": [
|
||
"\n<script>\n // htmlwidgets need to know to resize themselves when slides are shown/hidden.\n // Fire the \"slideenter\" event (handled by htmlwidgets.js) when the current\n // slide changes (different for each slide format).\n (function () {\n // dispatch for htmlwidgets\n function fireSlideEnter() {\n const event = window.document.createEvent(\"Event\");\n event.initEvent(\"slideenter\", true, true);\n window.document.dispatchEvent(event);\n }\n\n function fireSlideChanged(previousSlide, currentSlide) {\n fireSlideEnter();\n\n // dispatch for shiny\n if (window.jQuery) {\n if (previousSlide) {\n window.jQuery(previousSlide).trigger(\"hidden\");\n }\n if (currentSlide) {\n window.jQuery(currentSlide).trigger(\"shown\");\n }\n }\n }\n\n // hookup for slidy\n if (window.w3c_slidy) {\n window.w3c_slidy.add_observer(function (slide_num) {\n // slide_num starts at position 1\n fireSlideChanged(null, w3c_slidy.slides[slide_num - 1]);\n });\n }\n\n })();\n</script>\n\n"
|
||
]
|
||
},
|
||
"engineDependencies": {},
|
||
"preserve": {},
|
||
"postProcess": true
|
||
}
|
||
} |