Skip to content

Repo that goes with the "Boost D3.js Charts with SVG Gradients" NET magazine tutorial

Notifications You must be signed in to change notification settings

nbremer/svggradienttutorial

Repository files navigation

#Boost D3.js Charts with SVG Gradients

The GitHub repo containing the code for the NET magazine tutorial

In this repo you can find all of the code that I discuss in my article for NET magazine, and a bit more. You'll find the code that created the images. In some cases I've also added a simpler version that strips it down to the basics of adding an SVG gradient without the extra's I added to create a visually more interesting data visualization. The NET tutorial contained 4 sections and the folders in this repo are ordered in the same way

###Part 1: Linear Gradients In this folder you can find the first and simplest example, found in the "Linear Gradients" section in which I explain how to add an SVG gradient to a line chart to make it more noticeable.

![Linear gradient | An two color SVG gradient applied to an area chart that lies below the line chart](img/1. Area Chart Gradient.png "Linear gradient | An two color SVG gradient applied to an area chart that lies below the line chart")

I've added one extra example that uses more than two colors.

![Linear gradient | An multiple color SVG gradient applied to an area chart that lies below the line chart](img/1. Area Chart Gradient - Multiple Colors.png "Linear gradient | An multiple color SVG gradient applied to an area chart that lies below the line chart")

###Part 2: A Smooth Legend These are the examples from the section "A Smooth Legend" explaining how you can create a simple legend by filling an SVG rectangle with a gradient. In the original example I added two small data visualizations about the min, max and average temperature in New York and Beijing (recreated after the wonderful work of weather-radials.com) to serve as the chart that the SVG gradient legend refers to.

![Smooth gradient | Filling a rectangle with an SVG gradient of many colors to act as a legend for a temperature dta visualization](img/2. Multi Color Legend - Weather.png "Smooth gradient | Filling a rectangle with an SVG gradient of many colors to act as a legend for a temperature dta visualization")

But in essence it all came down to the two rectangles, so there is also a code version showing how to create only the two rectangles with D3.

![Smooth gradient | Filling a rectangle with an SVG gradient of many colors (which can act as a legend)](img/2. Multi Color Legend - Simple.png "Smooth gradient | Filling a rectangle with an SVG gradient of many colors (which can act as a legend)")

Part 3: Data-Based Gradients

Taken from the section "Data-Based gradients" in which we recreated part of my Exoplanets data visualization nbremer.github.io/exoplanets, but using our own Solar system planets to see how you can use values from a dataset to create a unique gradient for each data point.

![Data-based gradients | Each planet has its gradient made in such a way to make it look like a sphere](img/3. Solar system.png "Data-based gradients | Each planet has its gradient made in such a way to make it look like a sphere")

And a stripped down version with only the circles on a row, made to look more like spheres by applying a radial gradient, where the subtleties come from the color per planet as defined in the dataset.

![Data-based gradients | Each planet has its gradient made in such a way to make it look like a sphere - simple version with all the planets in a row](img/3. Solar system - Simple.png "Data-based gradients | Each planet has its gradient made in such a way to make it look like a sphere - simple version with all the planets in a row")

Part 4: Playing with Orientations

The last section "Playing with the Orientations" expands on the 3rd section, but in this case the orientations of the linear gradients are based on the data as well. Only one version in this folder, the Chord diagram that shows how often the Avengers have collaborated in the MCU movies (up until Thor: Ragnarok).

![Gradient orientations | Each chord has its own unique gradient where the orientations (and color) are defined by the data](img/4. Position and Data Based Gradient - Avengers Collaborations.png "Gradient orientations | Each chord has its own unique gradient where the orientations (and color) are defined by the data")

About

Repo that goes with the "Boost D3.js Charts with SVG Gradients" NET magazine tutorial

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published