forked from wch/rgcookbook
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathch10.Rmd
573 lines (393 loc) · 20.9 KB
/
ch10.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
---
output:
bookdown::html_document2:
fig_caption: yes
editor_options:
chunk_output_type: console
---
```{r echo = FALSE, cache = FALSE}
# This block needs cache=FALSE to set fig.width and fig.height, and have those
# persist across cached builds.
source("utils.R", local = TRUE)
knitr::opts_chunk$set(fig.width = 3.5, fig.height = 3.5)
```
Legends {#CHAPTER-LEGEND}
=======
Like the x- or y-axis, a legend is a guide: it shows people how to map visual (aesthetic) properties back to data values.
Removing the Legend {#RECIPE-LEGEND-REMOVE}
-------------------
### Problem
You want to remove the legend from a graph.
### Solution
Use `guides()`, and specify the scale that should have its legend removed (Figure \@ref(fig:FIG-LEGEND-REMOVE)):
```{r FIG-LEGEND-REMOVE, fig.cap="Default appearance (left); With legend removed (right)"}
# Create the base plot (with legend)
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
pg_plot
# Remove the legend for fill
pg_plot +
guides(fill = FALSE)
```
### Discussion
Another way to remove a legend is to set `guide = FALSE` in the scale. This will result in the exact same output as the preceding code:
```{r eval=FALSE}
# Remove the legend for fill
pg_plot +
scale_fill_discrete(guide = FALSE)
```
Yet another way to remove the legend is to use the theming system. If you have more than one aesthetic mapping with a legend (`color` and `shape`, for example), this will remove legends for all of them:
```{r eval=FALSE}
pg_plot +
theme(legend.position = "none")
```
Sometimes a legend is redundant, or it is supplied in another graph that will be displayed with the current one. In these cases, it can be useful to remove the legend from a graph.
In the example used here, the colors provide the same information that is on the x-axis, so the legend is unnecessary. Notice that with the legend removed, the area used for graphing the data is larger. If you want to achieve the same proportions in the graphing area, you will need to adjust the overall dimensions of the graph.
When a variable is mapped to `fill`, the default scale used is `scale_fill_discrete()` (equivalent to `scale_fill_hue()`), which maps the factor levels to colors that are equally spaced around the color wheel. There are other scales for `fill`, such as `scale_fill_manual()`. If you use scales for other aesthetics, such as `colour` (for lines and points) or `shape` (for points), you must use the appropriate scale. Commonly used scales include:
* `scale_fill_discrete()`
* `scale_fill_hue()`
* `scale_fill_manual()`
* `scale_fill_grey()`
* `scale_fill_brewer()`
* `scale_colour_discrete()`
* `scale_colour_hue()`
* `scale_colour_manual()`
* `scale_colour_grey()`
* `scale_colour_brewer()`
* `scale_shape_manual()`
* `scale_linetype()`
Changing the Position of a Legend {#RECIPE-LEGEND-POSITION}
---------------------------------
### Problem
You want to move the legend from its default place on the right side.
### Solution
Use `theme(legend.position = ...)`. It can be put on the top, left, right, or bottom by using one of those strings as the position (Figure \@ref(fig:FIG-LEGEND-POSITION), left).
```{r FIG-LEGEND-POSITION-1, eval=FALSE}
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot() +
scale_fill_brewer(palette = "Pastel2")
pg_plot +
theme(legend.position = "top")
```
The legend can also be placed inside the plotting area by specifying a coordinate position, as in `legend.position = c(.8, .3)` (Figure \@ref(fig:FIG-LEGEND-POSITION), right). The coordinate space starts at (0, 0) in the bottom left and goes to (1, 1) in the top right.
```{r FIG-LEGEND-POSITION-2, eval=FALSE}
pg_plot +
theme(legend.position = c(.8, .3))
```
```{r FIG-LEGEND-POSITION, ref.label=c("FIG-LEGEND-POSITION-1", "FIG-LEGEND-POSITION-2"), echo=FALSE, fig.cap="Legend on top (left); Legend inside of plotting area (right)"}
```
### Discussion
You can also use `legend.justification` to set which *part* of the legend box is set to the position at `legend.position`. By default, the center of the legend (.5, .5) is placed at the coordinate, but it is often useful to specify a different point.
For example, this will place the bottom-right corner of the legend (1, 0) in the bottom-right corner of the plotting area (1, 0) (Figure \@ref(fig:FIG-LEGEND-POSITION-JUSTIFICATION), left):
```{r FIG-LEGEND-POSITION-JUSTIFICATION-1, eval=FALSE}
pg_plot +
theme(legend.position = c(1, 0), legend.justification = c(1, 0))
```
And this will place the top-right corner of the legend in the top-right corner of the graphing area (Figure \@ref(fig:FIG-LEGEND-POSITION-JUSTIFICATION), right):
```{r FIG-LEGEND-POSITION-JUSTIFICATION-2, eval=FALSE}
pg_plot +
theme(legend.position = c(1, 1), legend.justification = c(1, 1))
```
```{r FIG-LEGEND-POSITION-JUSTIFICATION, ref.label=c("FIG-LEGEND-POSITION-JUSTIFICATION-1", "FIG-LEGEND-POSITION-JUSTIFICATION-2"), echo=FALSE, fig.cap="Legend in bottom-right corner (left); Legend in top-right corner (right)"}
```
When placing the legend inside of the graphing area, it may be helpful to add an opaque border to set it apart (Figure \@ref(fig:FIG-LEGEND-POSITION-BACKGROUND), left):
```{r FIG-LEGEND-POSITION-BACKGROUND-1, eval=FALSE}
pg_plot +
theme(legend.position = c(.85, .2)) +
theme(legend.background = element_rect(fill = "white", colour = "black"))
```
You can also remove the border around its elements so that it blends in
(Figure \@ref(fig:FIG-LEGEND-POSITION-BACKGROUND), right):
```{r FIG-LEGEND-POSITION-BACKGROUND-2, eval=FALSE}
pg_plot +
theme(legend.position = c(.85, .2)) +
theme(legend.background = element_blank()) + # Remove overall border
theme(legend.key = element_blank()) # Remove border around each item
```
```{r FIG-LEGEND-POSITION-BACKGROUND, ref.label=c("FIG-LEGEND-POSITION-BACKGROUND-1", "FIG-LEGEND-POSITION-BACKGROUND-2"), echo=FALSE, fig.cap="Legend with opaque background and outline (left); With no background or outlines (right)", fig.width=3}
```
Changing the Order of Items in a Legend {#RECIPE-LEGEND-ORDER}
---------------------------------------
### Problem
You want to change the order of the items in a legend.
### Solution
Set the limits in the scale to the desired order (Figure \@ref(fig:FIG-LEGEND-ORDER)):
```{r FIG-LEGEND-ORDER, fig.cap="Default order for legend (left); Modified order (right)"}
# Create the base plot
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
pg_plot
# Change the order of items
pg_plot +
scale_fill_discrete(limits = c("trt1", "trt2", "ctrl"))
```
### Discussion
Note that the order of the items on the x-axis did not change. To do that, you would have to set the limits of `scale_x_discrete()` (Recipe \@ref(RECIPE-AXIS-ORDER)), or change the data to have a different factor level order (Recipe \@ref(RECIPE-DATAPREP-FACTOR-REORDER)).
In the preceding example, group was mapped to the fill aesthetic. By default this uses `scale_fill_discrete()` (which is the sameas `scale_fill_hue()`), which maps the factor levels to colors that are equally spaced around the color wheel. We could have used a different `scale_fill_`**`xxx`**`()`, though. For example, we could use a grey palette (Figure \@ref(fig:FIG-LEGEND-ORDER2), left):
```{r FIG-LEGEND-ORDER2-1, eval=FALSE}
pg_plot +
scale_fill_grey(start = .5, end = 1, limits = c("trt1", "trt2", "ctrl"))
```
Or we could use a palette from RColorBrewer
(Figure \@ref(fig:FIG-LEGEND-ORDER2), right):
```{r FIG-LEGEND-ORDER2-2, eval=FALSE}
pg_plot +
scale_fill_brewer(palette = "Pastel2", limits = c("trt1", "trt2", "ctrl"))
```
```{r FIG-LEGEND-ORDER2, ref.label=c("FIG-LEGEND-ORDER2-1", "FIG-LEGEND-ORDER2-2"), echo=FALSE, fig.cap="Modified order with a grey palette (left); With a palette from RColorBrewer (right)"}
```
All the previous examples were for fill. If you use scales for other aesthetics, such as colour (for lines and points) or shape (for points), you must use the appropriate scale. Commonly used scales include:
* `scale_fill_discrete()`
* `scale_fill_hue()`
* `scale_fill_manual()`
* `scale_fill_grey()`
* `scale_fill_brewer()`
* `scale_colour_discrete()`
* `scale_colour_hue()`
* `scale_colour_manual()`
* `scale_colour_grey()`
* `scale_colour_brewer()`
* `scale_shape_manual()`
* `scale_linetype()`
By default, using `scale_fill_discrete()` is equivalent to using `scale_fill_hue()`; the same is true for color scales.
### See Also
To reverse the order of the legend, see Recipe \@ref(RECIPE-LEGEND-REVERSE).
To change the order of factor levels, see Recipe \@ref(RECIPE-DATAPREP-FACTOR-REORDER). To order legend items based on values in another variable, see Recipe \@ref(RECIPE-DATAPREP-FACTOR-REORDER-VALUE).
Reversing the Order of Items in a Legend {#RECIPE-LEGEND-REVERSE}
----------------------------------------
### Problem
You want to reverse the order of items in a legend.
### Solution
Add guides (`fill = guide_legend(reverse = TRUE)`) to reverse the order of the legend, as in Figure \@ref(fig:FIG-LEGEND-TITLE-REVERSE) (for other aesthetics, replace `fill` with the name of the aesthetic, such as `colour` or `size`):
```{r FIG-LEGEND-TITLE-REVERSE, fig.cap="Default order for legend (left); Reversed order (right)"}
# Create the base plot
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
pg_plot
# Reverse the legend order
pg_plot +
guides(fill = guide_legend(reverse = TRUE))
```
### Discussion
It is also possible to control the legend when specifying the scale, as in the following:
```{r eval=FALSE}
scale_fill_hue(guide = guide_legend(reverse = TRUE))
```
Changing a Legend Title {#RECIPE-LEGEND-TITLE-TEXT}
-----------------------
### Problem
You want to change the text of a legend title.
### Solution
Use `labs()` and set the value of `fill`, `colour`, `shape`, or whatever aesthetic is appropriate for the legend (Figure \@ref(fig:FIG-LEGEND-TITLE)):
```{r FIG-LEGEND-TITLE, fig.cap='With the legend title set to "Condition"'}
# Create the base plot
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
pg_plot
# Set the legend title to "Condition"
pg_plot + labs(fill = "Condition")
```
### Discussion
It's also possible to set the title of the legend in the scale specification. Since legends and axes are both guides, this works the same way as setting the title of the x- or y-axis.
This would have the same effect as the previous code:
```{r eval=FALSE}
pg_plot + scale_fill_discrete(name = "Condition")
```
If there are multiple variables mapped to aesthetics with a legend (those other than x and y), you can set the title of each individually. In the example here we'll use `\n` to add a line break in one of the titles (Figure \@ref(fig:FIG-LEGEND-TITLE-MULTI)):
```{r FIG-LEGEND-TITLE-MULTI, fig.cap="Two legends with original titles (left); With new titles (right)"}
library(gcookbook) # Load gcookbook for the heightweight data set
# Load gcookbook for the heightweight data set
hw_plot <- ggplot(heightweight, aes(x = ageYear, y = heightIn, colour = sex)) +
geom_point(aes(size = weightLb)) +
scale_size_continuous(range = c(1, 4))
hw_plot
# With new legend titles
hw_plot +
labs(colour = "Male/Female", size = "Weight\n(pounds)")
```
If you have one variable mapped to two separate aesthetics, the default is to have a single legend that combines both. For example, if we map `sex` to both `shape` and `weight`, there will be just one legend (Figure \@ref(fig:FIG-LEGEND-TITLE-MULTI-SAME), left):
```{r FIG-LEGEND-TITLE-MULTI-SAME-1, eval=FALSE}
hw_plot2 <- ggplot(heightweight, aes(x = ageYear, y = heightIn, shape = sex, colour = sex)) +
geom_point()
hw_plot2
```
To change the title (Figure \@ref(fig:FIG-LEGEND-TITLE-MULTI-SAME), right), you need to set the name for both of them. If you change the name for just one, it will result in two separate legends (Figure \@ref(fig:FIG-LEGEND-TITLE-MULTI-SAME), middle):
```{r FIG-LEGEND-TITLE-MULTI-SAME-2, eval=FALSE}
# Change just shape
hw_plot2 +
labs(shape = "Male/Female")
# Change both shape and colour
hw_plot2 +
labs(shape = "Male/Female", colour = "Male/Female")
```
It is also possible to control the legend title with the `guides()` function. It's a little more verbose, but it can be useful when you're already using it to control other properties:
```{r FIG-LEGEND-TITLE-MULTI-SAME-3, eval=FALSE}
hw_plot +
guides(fill = guide_legend(title = "Condition"))
```
```{r FIG-LEGEND-TITLE-MULTI-SAME, ref.label=c("FIG-LEGEND-TITLE-MULTI-SAME-1", "FIG-LEGEND-TITLE-MULTI-SAME-2", "FIG-LEGEND-TITLE-MULTI-SAME-3"), echo=FALSE, fig.cap="Default legend with a variable mapped to shape and colour (left); With shape renamed (middle); With both shape and colour renamed (right)"}
```
Changing the Appearance of a Legend Title {#RECIPE-LEGEND-TITLE-APPEARANCE}
-----------------------------------------
### Problem
You want to change the appearance of a legend title's text.
### Solution
Use theme(`legend.title = element_text()`) (Figure \@ref(fig:FIG-LEGEND-TITLE-APPEARANCE)):
```{r FIG-LEGEND-TITLE-APPEARANCE, fig.cap="Customized legend title appearance"}
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
pg_plot +
theme(legend.title = element_text(
face = "italic",
family = "Times",
colour = "red",
size = 14)
)
```
### Discussion
It's also possible to specify the legend title's appearance via `guides()`, but this method can be a bit verbose. This has the same effect as the previous code:
```{r, eval=FALSE}
pg_plot +
guides(fill = guide_legend(title.theme = element_text(
face = "italic",
family = "times",
colour = "red",
size = 14))
)
```
### See Also
See Recipe \@ref(RECIPE-APPEARANCE-TEXT-APPEARANCE) for more on controlling the appearance of text.
Removing a Legend Title {#RECIPE-LEGEND-TITLE-REMOVE}
-----------------------
### Problem
You want to remove a legend title.
### Solution
Add `guides(fill = guide_legend(title = NULL))` to remove the title from a legend, as in Figure \@ref(fig:FIG-LEGEND-TITLE-REMOVE) (for other aesthetics, replace `fill` with the name of the aesthetic, such as `colour` or `size`):
```{r FIG-LEGEND-TITLE-REMOVE, fig.cap="Box plot with no legend title"}
ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot() +
guides(fill = guide_legend(title = NULL))
```
### Discussion
It is also possible to control the legend title when specifying the scale. This has the same effect as the preceding code:
```{r, eval=FALSE}
scale_fill_hue(guide = guide_legend(title = NULL))
```
Changing the Labels in a Legend {#RECIPE-LEGEND-LABEL-TEXT}
-------------------------------
### Problem
You want to change the text of labels in a legend.
### Solution
Set the labels in the scale (Figure \@ref(fig:FIG-LEGEND-LABEL), left):
```{r FIG-LEGEND-LABEL-1, eval=FALSE}
library(gcookbook) # Load gcookbook for the PlantGrowth data set
# The base plot
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
# Change the legend labels
pg_plot +
scale_fill_discrete(labels = c("Control", "Treatment 1", "Treatment 2"))
```
### Discussion
Note that the labels on the x-axis did not change. To do that, you would have to set the labels of `scale_x_discrete()` (Recipe \@ref(RECIPE-AXES-AXIS-LABEL)), or change the data to have different factor level names (Recipe \@ref(RECIPE-DATAPREP-FACTOR-RENAME)).
In the preceding example, group was mapped to the fill aesthetic. By default this uses `scale_fill_discrete()`, which maps the factor levels to colors that are equally spaced around the color wheel (the same as `scale_fill_hue()`). There are other fill scales we could use, and setting the labels works the same way. For example, to produce the graph on the right in Figure \@ref(fig:FIG-LEGEND-LABEL):
```{r FIG-LEGEND-LABEL-2, eval=FALSE}
pg_plot +
scale_fill_grey(start = .5, end = 1, labels = c("Control", "Treatment 1", "Treatment 2"))
```
```{r FIG-LEGEND-LABEL, ref.label=c("FIG-LEGEND-LABEL-1", "FIG-LEGEND-LABEL-2"), echo=FALSE, fig.cap="Manually specified legend labels with the default discrete scale (left); Manually specified labels with a different scale (right)"}
```
If you are also changing the order of items in the legend, the labels are matched to the items by position. In this example we'll change the item order, and make sure to set the labels in the same order (Figure \@ref(fig:FIG-LEGEND-LABEL-ORDER)):
```{r FIG-LEGEND-LABEL-ORDER, fig.cap="Modified legend label order and manually specified labels (note that the x-axis labels and their order are unchanged)"}
pg_plot +
scale_fill_discrete(
limits = c("trt1", "trt2", "ctrl"),
labels = c("Treatment 1", "Treatment 2", "Control")
)
```
If you have one variable mapped to two separate aesthetics, the default is to have a single legend that combines both. If you want to change the legend labels, you must change them for both scales; otherwise you will end up with two separate legends, as shown in Figure \@ref(fig:FIG-LEGEND-LABEL-MULTI-APPEARANCE):
(ref:cap-FIG-LEGEND-LABEL-MULTI-APPEARANCE) A variable mapped to `shape` and `colour` (top left); With new labels for `shape` (top right); With new labels combining both `shape` and colour` (bottom)
```{r FIG-LEGEND-LABEL-MULTI-APPEARANCE, fig.cap="(ref:cap-FIG-LEGEND-LABEL-MULTI-APPEARANCE)"}
# Create the base plot
hw_plot <- ggplot(heightweight, aes(x = ageYear, y = heightIn, shape = sex, colour = sex)) +
geom_point()
hw_plot
# Change the labels for one scale
hw_plot +
scale_shape_discrete(labels = c("Female", "Male"))
# Change the labels for both scales
hw_plot +
scale_shape_discrete(labels = c("Female", "Male")) +
scale_colour_discrete(labels = c("Female", "Male"))
```
Other commonly used scales with legends include:
* `scale_fill_discrete()`
* `scale_fill_hue()`
* `scale_fill_manual()`
* `scale_fill_grey()`
* `scale_fill_brewer()`
* `scale_colour_discrete()`
* `scale_colour_hue()`
* `scale_colour_manual()`
* `scale_colour_grey()`
* `scale_color_viridis_c()`
* `scale_color_viridis_d()`
* `scale_shape_manual()`
* `scale_linetype()`
By default, using `scale_fill_discrete()` is equivalent to using `scale_fill_hue()`; the same is true for color scales.
Changing the Appearance of Legend Labels {#RECIPE-LEGEND-LABEL-APPEARANCE}
----------------------------------------
### Problem
You want to change the appearance of labels in a legend.
### Solution
Use `theme(legend.text=element_text())` (Figure \@ref(fig:FIG-LEGEND-LABEL-APPEARANCE)):
```{r FIG-LEGEND-LABEL-APPEARANCE, fig.cap="Customized legend label appearance"}
# Create the base plot
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
# Change the legend label appearance
pg_plot +
theme(legend.text = element_text(
face = "italic",
family = "Times",
colour = "red",
size = 14)
)
```
### Discussion
It's also possible to specify the legend label appearance via `guides()`, although this method is a bit unwieldy. This has the same effect as the previous code:
```{r eval=FALSE}
# Changes the legend title text for the fill legend
pg_plot +
guides(fill = guide_legend(title.theme = element_text(
face = "italic",
family = "times",
colour = "red",
size = 14))
)
```
### See Also
See Recipe \@ref(RECIPE-APPEARANCE-TEXT-APPEARANCE) for more on controlling the appearance of text.
Using Labels with Multiple Lines of Text {#RECIPE-LEGEND-LABEL-MULTILINE}
----------------------------------------
### Problem
You want to use legend labels that have more than one line of text.
### Solution
Set the labels in the scale, using `\n` to represent a newline. In this example, we'll use `scale_fill_discrete()` to control the legend for the fill scale (Figure \@ref(fig:FIG-LEGEND-LABEL-MULTILINE), left):
```{r FIG-LEGEND-LABEL-MULTILINE-1, eval=FALSE}
pg_plot <- ggplot(PlantGrowth, aes(x = group, y = weight, fill = group)) +
geom_boxplot()
# Labels that have more than one line
pg_plot +
scale_fill_discrete(labels = c("Control", "Type 1\ntreatment", "Type 2\ntreatment"))
```
### Discussion
As you can see in the version on the left in Figure \@ref(fig:FIG-LEGEND-LABEL-MULTILINE), with the default settings the lines of text will run into each other when you use labels that have more than one line. To deal with this problem, you can increase the height of the legend keys and decrease the spacing between lines, using `theme()` (Figure \@ref(fig:FIG-LEGEND-LABEL-MULTILINE), right). To do this, you will need to specify the height using the `unit()` function from the grid package:
```{r FIG-LEGEND-LABEL-MULTILINE-2, eval=FALSE}
library(grid)
pg_plot +
scale_fill_discrete(labels = c("Control", "Type 1\ntreatment", "Type 2\ntreatment")) +
theme(legend.text = element_text(lineheight = .8), legend.key.height = unit(1, "cm"))
```
```{r FIG-LEGEND-LABEL-MULTILINE, ref.label=c("FIG-LEGEND-LABEL-MULTILINE-1", "FIG-LEGEND-LABEL-MULTILINE-2"), echo=FALSE, fig.cap="Multiline legend labels (left); With increased key height and reduced line spacing (right)"}
```