Download the data vis project template from the bottom of this page
and look over the code, starting with stekch.js
to get an overview
of how the programme works. Try running the code.
All visualisations are stored in the gallery
global variable. This
variable can be used for debugging in the console to access properties
and methods defined within each visualisation.
Lines you need to complete in this case study are marked ???.
Complete the visualisation defined in tech-diversity-gender.js
to
create a stacked bar chart by adding the proportion of men employed at
each company.
-
Look up the documentation for Table.
-
Look at the raw data:
./data/tech-diversity/gender-2018.csv
. Use a spreadsheet program or text editor, and make sure you understand the data format (this first line is special). This data will be automatically loaded and stored in thedata
property (see thepreload()
method). -
In the
for
loop in thedraw()
method extract the relevant data from each table row and store it in thecompany
object.- Hint: Look up the
getString()
andgetNum()
table methods, and use the appropriate method to ensure the data is parsed correctly. - Check that bars representing the proportion of female employees is correctly drawn on the plot.
- Hint: Look up the
-
Look at how the rectangle representing the proportion of female employees is defined. Draw a rectangle representing the male proportion using the parameters and methods defined in this object.
- The ratio of female:male staff at Indiegogo is 50:50. Make sure that this is correctly visualised on the plot.
Complete the visualisation defined in pay-gap-1997-2017.js
to create
a line graph representing the pay gap between female and male
employees over time.
-
Look at the raw data:
./data/pay-gap/all-employees-hourly-pay-by-gender-1997-2017.csv
. -
In the
for
loop in thedraw()
method extract the relevant data from each table row and store it in thecurrent
object. -
Complete the
mapPayGapToHeight()
method. Look at howmapYearToWidth()
works.- Check that the y-axis tick labels are drawn correctly.
-
Complete the
line()
function in thedraw()
method to plot the pay gap over time. You will need to use bothmapYearToWidth()
andmapPayGapToHeight()
methods.
Complete the visualisation defined in climate-change.js
to create a
line graph with gradient fill background representing the change in
the Earth’s surface temperature.
-
Using the
mapTemperatureToColour()
method set thefill()
in thedraw()
method. You need to pass the current temperature to this method to get the correct colour. -
Complete the
rect()
function below thefill()
to create a gradient effect background (rectangles spaced evenly across the x-axis – one rectangle per year). All of the values you need are already accessible within this visualisation object – you need to find them!- Hint: Look at the
mapYearToWidth()
method, thelayout
object, and thesegmentWidth
variable.
- Hint: Look at the
Complete the visualisation defined in tech-diversity-race.js
to
create a pie chart to represent the racial diversity of prominent tech
companies.
-
Look at the raw data:
./data/tech-diversity/race-2018.csv
. -
In the
setup()
method create a select DOM element using the p5createSelect
) function and populate the options programmatically using the company names obtained from the columns ofthis.data
.- Hint: you need to write a
for
loop. - Hint: look up the p5.Table
columns
property.
- Hint: you need to write a
-
In the
draw()
method change the hard-coded company name to instead get the value from the select. -
Test that when selecting a company name from the list the correct data is visualised on the canvas and the correct title is generated.
Complete the visualisation defined in pay-gap-by-job-2017.js
to
create a scatter plot representing the difference in pay for men and
women across different jobs.
In the draw()
method complete the for
loop that draws all of the
data points on the canvas as ellipses with the following properties.
- x = proportion of female employees
- y = pay gap
- size = number of jobs
Hint: You will need to use map()
.