How to plot a good story. Choose a theme from our selection of plot generators. Give us some keywords to play with or let us prompt some ideas at random. We automatically create a plot, title and a cover for your novel or film. Plot is often represented as an arc. To learn about plot in detail, read the article: “What is a Plot.” 4. Conflict: Every story must have a conflict, i.e. A challenge or problem around which the plot is based. Without conflict, the story will have no purpose or trajectory. Theme: Idea, belief, moral, lesson or insight.
Plot vs. Theme
In every narrative, story or literary entry, there are various elements to be considered. Among these elements, two are often regarded as the most important. These are the plot and the theme.
In the simplest explanation, a plot is synonymous to the storyline, whereas the theme is more the main thought or idea being tackled. Being the storyline, the plot is what one would expect to transpire into a story, or narrative. For example, the events that occur or happen with the characters, what they will do, where they will go, and when they will make an appearance are all part of the plot.
With regard to the theme, common examples are: Love, abortion, war, revenge and many others. The theme simply talks about the issue of the story. The theme is also the underlying topic or message that the writer, author or director wants to impart to their readers or audience. Other people may also regard themes as ornaments of the story. However, themes are very important decorations that unify the whole concept of the literary work.
It is even surprising that some confuse the theme with the plot, and vice versa, when in fact it is the genre that is closer in definition to the theme than the plot. The plot, as a whole, starts from the beginning of the story and ends when the story ends. It is a broad collection of events that justify the theme or subject. That’s why it is designed in several parts, which include: The exposition (beginning), conflict (where the problems are unveiled), rising action (leads to the climax), climax (the highest and often the most exciting part of the story), falling action (shows the outcome of the climax), and resolution (where the conclusion is reached).
Stories, fiction entries and the like may contain several plots, even as many as there can be governing themes. The simplest of all plots are obviously those that are mostly unidirectional, and linear approaches, which don’t derail the readers from thinking about the conclusion’s outcome. Nevertheless, when the plot is composed of a combination of multiple or complex plots, it is then called an imbroglio.
Lastly, some authors have different styles in conveying the theme of the story. Many use different figures of speech to express their ideas more effectively, like similes, metaphors and personification, amongst others.
In conclusion, the difference between a plot and theme is the following:
1. Themes are more of the controlling idea, or the motif of the story, whereas the plot is the storyline of the story that includes what happens from start to finish.
2. The plot is more structured compared to the theme.
- Difference Between IHRM and Domestic HRM - November 22, 2011
- Difference Between Heifer and Cow - November 22, 2011
- Difference Between Deacons and Elders - November 22, 2011
18.1 Introduction
In this chapter you will learn how to use the ggplot2 theme system, which allows you to exercise fine control over the non-data elements of your plot. The theme system does not affect how the data is rendered by geoms, or how it is transformed by scales. Themes don’t change the perceptual properties of the plot, but they do help you make the plot aesthetically pleasing or match an existing style guide. Themes give you control over things like fonts, ticks, panel strips, and backgrounds.
This separation of control into data and non-data parts is quite different from base and lattice graphics. In base and lattice graphics, most functions take a large number of arguments that specify both data and non-data appearance, which makes the functions complicated and harder to learn. ggplot2 takes a different approach: when creating the plot you determine how the data is displayed, then after it has been created you can edit every detail of the rendering, using the theming system.
Plots And Theme
The theming system is composed of four main components:
Theme elements specify the non-data elements that you can control.For example, the
plot.title
element controls the appearance of theplot title;axis.ticks.x
, the ticks on the x axis;legend.key.height
,the height of the keys in the legend.Each element is associated with an element function, which describesthe visual properties of the element. For example,
element_text()
setsthe font size, colour and face of text elements likeplot.title
.The
theme()
function which allows you to override the default themeelements by calling element functions, liketheme(plot.title = element_text(colour = 'red'))
.Complete themes, like
theme_grey()
set all of the theme elements tovalues designed to work together harmoniously.
For example, imagine you’ve made the following plot of your data.
It’s served its purpose for you: you’ve learned that cty
and hwy
are highly correlated, both are tightly coupled with cyl
, and that hwy
is always greater than cty
(and the difference increases as cty
increases). Now you want to share the plot with others, perhaps by publishing it in a paper. That requires some changes. First, you need to make sure the plot can stand alone by:
- Improving the axes and legend labels.
- Adding a title for the plot.
- Tweaking the colour scale.
Fortunately you know how to do that already because you’ve read Section 8.1 and Chapter (scale-colour):
Next, you need to make sure the plot matches the style guidelines of your journal:
- The background should be white, not pale grey.
- The legend should be placed inside the plot if there’s room.
- Major gridlines should be a pale grey and minor gridlines should be removed.
- The plot title should be 12pt bold text.
In this chapter, you’ll learn how to use the theming system to make those changes, as shown below:
Finally, the journal wants the figure as a 600 dpi TIFF file. You’ll learn the fine details of ggsave()
in Section 18.5.
18.2 Complete themes
ggplot2 comes with a number of built in themes. The most important is theme_grey()
, the signature ggplot2 theme with a light grey background and white gridlines. The theme is designed to put the data forward while supporting comparisons, following the advice of.Edward R. Tufte, Beautiful Evidence (Graphics Press, 2006); Cynthia A. Brewer, “Color Use Guidelines for Mapping and Visualization,” in Visualization in Modern Cartography, ed. A. M. MacEachren and D. R. F. Taylor (Elsevier Science, 1994), 123–47; Dan Carr, “Graphical Displays,” in Encyclopedia of Environmetrics, ed. Abdel H. El-Shaarawi and Walter W. Piegorsch, vol. 2 (John Wiley & Sons, 2002), 933–60, http://www.galaxy.gmu.edu/~dcarr/lib/EnvironmentalGraphics.pdf; Dan Carr, “Using Gray in Plots,” ASA Statistical Computing and Graphics Newsletter 2, no. 5 (1994): 11–14, http://www.galaxy.gmu.edu/~dcarr/lib/v5n2.pdf; Dan Carr and Ru Sun, “Using Layering and Perceptual Grouping in Statistical Graphics,” ASA Statistical Computing and Graphics Newsletter 10, no. 1 (1999): 25–31.
There are seven other themes built in to ggplot2 1.1.0:
theme_bw()
: a variation ontheme_grey()
that uses a white backgroundand thin grey grid lines.theme_linedraw()
: A theme with only black lines of various widths on whitebackgrounds, reminiscent of a line drawing.theme_light()
: similar totheme_linedraw()
but with light grey lines andaxes, to direct more attention towards the data.theme_dark()
: the dark cousin oftheme_light()
, with similar line sizesbut a dark background. Useful to make thin coloured lines pop out.theme_minimal()
: A minimalistic theme with no background annotations.theme_classic()
: A classic-looking theme, with x and y axis lines and nogridlines.theme_void()
: A completely empty theme.
All themes have a base_size
parameter which controls the base font size. The base font size is the size that the axis titles use: the plot title is usually bigger (1.2x), and the tick and strip labels are smaller (0.8x). If you want to control these sizes separately, you’ll need to modify the individual elements as described below.
Plot And Theme Videos For 2nd Graders
As well as applying themes a plot at a time, you can change the default theme with theme_set()
. For example, if you really hate the default grey background, run theme_set(theme_bw())
to use a white background for all plots.
You’re not limited to the themes built-in to ggplot2. Other packages, like ggthemes by Jeffrey Arnold, add even more. Here’s a few of my favourites from ggthemes:
The complete themes are a great place to start but don’t give you a lot of control. To modify individual elements, you need to use theme()
to override the default setting for an element with an element function.
18.2.1 Exercises
Try out all the themes in ggthemes. Which do you like the best?
What aspects of the default theme do you like? What don’t you like?
What would you change?Look at the plots in your favourite scientific journal. What themedo they most resemble? What are the main differences?
18.3 Modifying theme components
To modify an individual theme component you use code like plot + theme(element.name = element_function())
. In this section you’ll learn about the basic element functions, and then in the next section, you’ll see all the elements that you can modify.
There are four basic types of built-in element functions: text, lines, rectangles, and blank. Each element function has a set of parameters that control the appearance:
element_text()
draws labels and headings. You can control the fontfamily
,face
,colour
,size
(in points),hjust
,vjust
,angle
(in degrees) andlineheight
(as ratio offontcase
). More details onthe parameters can be found invignette('ggplot2-specs')
.Setting the font face is particularly challenging.You can control the margins around the text with the
margin
argument andmargin()
function.margin()
has four arguments: the amount of space(in points) to add to the top, right, bottom and left sides of the text.Any elements not specified default to 0.element_line()
draws lines parameterised bycolour
,size
andlinetype
:element_rect()
draws rectangles, mostly used for backgrounds, parameterisedbyfill
colour and bordercolour
,size
andlinetype
.element_blank()
draws nothing. Use this if you don’t want anything drawn,and no space allocated for that element. The following example useselement_blank()
to progressively suppress the appearance of elementswe’re not interested in. Notice how the plot automatically reclaimsthe space previously used by these elements: if you don’t want this tohappen (perhaps because they need to line up with other plots on the page),usecolour = NA, fill = NA
to create invisible elements thatstill take up space.A few other settings take grid units. Create them with
unit(1, 'cm')
orunit(0.25, 'in')
.
To modify theme elements for all future plots, use theme_update()
. It returns the previous theme settings, so you can easily restore the original parameters once you’re done.
18.4 Theme elements
There are around 40 unique elements that control the appearance of the plot. They can be roughly grouped into five categories: plot, axis, legend, panel and facet. The following sections describe each in turn.
18.4.1 Plot elements
Some elements affect the plot as a whole:
Element | Setter | Description |
---|---|---|
plot.background | element_rect() | plot background |
plot.title | element_text() | plot title |
plot.margin | margin() | margins around plot |
plot.background
draws a rectangle that underlies everything else on the plot. By default, ggplot2 uses a white background which ensures that the plot is usable wherever it might end up (e.g. even if you save as a png and put on a slide with a black background). When exporting plots to use in other systems, you might want to make the background transparent with fill = NA
. Similarly, if you’re embedding a plot in a system that already has margins you might want to eliminate the built-in margins. Note that a small margin is still necessary if you want to draw a border around the plot.
18.4.2 Axis elements
The axis elements control the apperance of the axes:
Element | Setter | Description |
---|---|---|
axis.line | element_line() | line parallel to axis (hidden in default themes) |
axis.text | element_text() | tick labels |
axis.text.x | element_text() | x-axis tick labels |
axis.text.y | element_text() | y-axis tick labels |
axis.title | element_text() | axis titles |
axis.title.x | element_text() | x-axis title |
axis.title.y | element_text() | y-axis title |
axis.ticks | element_line() | axis tick marks |
axis.ticks.length | unit() | length of tick marks |
Note that axis.text
(and axis.title
) comes in three forms: axis.text
, axis.text.x
, and axis.text.y
. Use the first form if you want to modify the properties of both axes at once: any properties that you don’t explicitly set in axis.text.x
and axis.text.y
will be inherited from axis.text
.
The most common adjustment is to rotate the x-axis labels to avoid long overlapping labels. If you do this, note negative angles tend to look best and you should set hjust = 0
and vjust = 1
:
18.4.3 Legend elements
The legend elements control the apperance of all legends. You can also modify the appearance of individual legends by modifying the same elements in guide_legend()
or guide_colourbar()
.
Element | Setter | Description |
---|---|---|
legend.background | element_rect() | legend background |
legend.key | element_rect() | background of legend keys |
legend.key.size | unit() | legend key size |
legend.key.height | unit() | legend key height |
legend.key.width | unit() | legend key width |
legend.margin | unit() | legend margin |
legend.text | element_text() | legend labels |
legend.text.align | 0–1 | legend label alignment (0 = right, 1 = left) |
legend.title | element_text() | legend name |
legend.title.align | 0–1 | legend name alignment (0 = right, 1 = left) |
These options are illustrated below:
There are four other properties that control how legends are laid out in the context of the plot (legend.position
, legend.direction
, legend.justification
, legend.box
). They are described in Section 11.6.1.
18.4.4 Panel elements
Panel elements control the appearance of the plotting panels:
Element | Setter | Description |
---|---|---|
panel.background | element_rect() | panel background (under data) |
panel.border | element_rect() | panel border (over data) |
panel.grid.major | element_line() | major grid lines |
panel.grid.major.x | element_line() | vertical major grid lines |
panel.grid.major.y | element_line() | horizontal major grid lines |
panel.grid.minor | element_line() | minor grid lines |
panel.grid.minor.x | element_line() | vertical minor grid lines |
panel.grid.minor.y | element_line() | horizontal minor grid lines |
aspect.ratio | numeric | plot aspect ratio |
The main difference between panel.background
and panel.border
is that the background is drawn underneath the data, and the border is drawn on top of it. For that reason, you’ll always need to assign fill = NA
when overriding panel.border
.
Note that aspect ratio controls the aspect ratio of the panel, not the overall plot:
18.4.5 Faceting elements
The following theme elements are associated with faceted ggplots:
Element | Setter | Description |
---|---|---|
strip.background | element_rect() | background of panel strips |
strip.text | element_text() | strip text |
strip.text.x | element_text() | horizontal strip text |
strip.text.y | element_text() | vertical strip text |
panel.margin | unit() | margin between facets |
panel.margin.x | unit() | margin between facets (vertical) |
panel.margin.y | unit() | margin between facets (horizontal) |
Element strip.text.x
affects both facet_wrap()
or facet_grid()
; strip.text.y
only affects facet_grid()
.
18.4.6 Exercises
Create the ugliest plot possible! (Contributed by Andrew D. Steen,University of Tennessee - Knoxville)
theme_dark()
makes the inside of the plot dark, but not theoutside. Change the plot background to black, and then update thetext settings so you can still read the labels.Make an elegant theme that uses “linen” as the background colour anda serif font for the text.
Systematically explore the effects of
hjust
when you have a multilinetitle. Why doesn’tvjust
do anything?
18.5 Saving your output
When saving a plot to use in another program, you have two basic choices of output: raster or vector:
Vector graphics describe a plot as sequence of operations: draw a linefrom ((x_1, y_1)) to ((x_2, y_2)), draw a circle at ((x_3, x_4)) withradius (r). This means that they are effectively ‘infinitely’ zoomable;there is no loss of detail. The most useful vector graphic formats arepdf and svg.
Raster graphics are stored as an array of pixel colours and have a fixedoptimal viewing size. The most useful raster graphic format is png.
Figure 18.1 illustrates the basic differences in these formats for a circle. A good description is available at http://tinyurl.com/rstrvctr.
Figure 18.1: The schematic difference between raster (left) and vector (right) graphics.
Unless there is a compelling reason not to, use vector graphics: they look better in more places. There are two main reasons to use raster graphics:
You have a plot (e.g. a scatterplot) with thousands of graphical objects(i.e. points). A vector version will be large and slow to render.
You want to embed the graphic in MS Office. MS has poor support for vectorgraphics (except for their own DrawingXML format which is not currentlyeasy to make from R), so raster graphics are easier.
There are two ways to save output from ggplot2. You can use the standard R approach where you open a graphics device, generate the plot, then close the device:
This works for all packages, but is verbose. ggplot2 provides a convenient shorthand with ggsave()
:
ggsave()
is optimised for interactive use: you can use it after you’ve drawn a plot. It has the following important arguments:
The first argument,
path
, specifies the path where the image should besaved. The file extension will be used to automatically select the correctgraphics device.ggsave()
can produce.eps
,.pdf
,.svg
,.wmf
,.png
,.jpg
,.bmp
, and.tiff
.width
andheight
control the output size, specified in inches. If leftblank, they’ll use the size of the on-screen graphics device.For raster graphics (i.e.
.png
,.jpg
), thedpi
argument controls theresolution of the plot. It defaults to 300, which is appropriate for mostprinters, but you may want to use 600 for particularly high-resolution output,or 96 for on-screen (e.g., web) display.
See ?ggsave
for more details.