Visual is a Javascript library for data visualization developed by the Statistical Institute of Catalonia (Idescat). It is based on popular open source solutions. Visual offers a simple interface that encapsulates the complexity of these solutions for the most common chart types.
- Supported visualizations
- Test
- Configuration
- Installation
- Options
- Maps
- Dependencies
- Known limitations
- How to contribute
Visual currently supports the following visualizations:
- Distribution of a categorical variable (vertical bar chart): bar
- Ranking (horizontal bar chart): rank
- Stacked/non-stacked time series (vertical bar chart): tsbar
- Time series (line chart): tsline
- Population pyramid: pyram
- Choropleth map: cmap
Download the full source and tests and try the examples in the test folder.
Edit visual.setup.js and visual.css to meet your needs. You might need to provide your own maps and adapt the VisualJS.func.legend function inside visual.maps.js (see the maps folder).
Visual allows three running modes: webpage (recommended), simple and manual. See the examples in the test folder.
In the webpage mode, the visualization is the only content in an html5 page. Use the webpage template to build your page. To embed the visualization, use an iframe pointing to your page (example).
In the simple mode, the visualization is embedded in a page using the VisualJS.iframe() function. Use the simple template to build your page. To embed the visualization, include the visual.js and visual.setup.js files and use a script tag with a unique ID and invoke VisualJS.iframe() passing a visual object (with the same ID as the script tag) and a CSS file (or CSS rules) (example).
Warning: This mode has not been fully tested in old browsers.
In the manual mode, the visualization is directly embedded in a page. Use the manual template as an example. If you are embedding a single visualization, include the same javascripts as in the webpage template (example).
If you are embedding more than one visualization in the page, LazyLoad will only include the javascripts needed for the first visualization in the visual function. Instead, include all the needed javascripts manually. Do not include LazyLoad. You will also need to specify an id and its size (in the fixed property: [width, height]) for each visualization.
Warning: This mode has not been fully tested in old browsers.
Visual is executed by passing a visual object to the visual function.
visual( {...} )
If you already have a visual function defined, you can run Visual like this:
VisualJS.load( {...} )
The visual object accepts the following properties:
String ("ca", "es", "en"). Language. Default (ca) is set in visual.setup.js.
String. First level title's text.
String. Text of footer.
String. Geographical area.
String (optional) or array of strings (required). Time period or periods.
Visual will treat the following string time formats using the "quarter" and "month" properties in visual.setup.js: "20131" (first quarter of 2013) and "201301" (January 2013). Any other time pattern will be displayed untreated.
Boolean. It determines if the heading is built by composition from "title", "geo" and "time". If false, only "title" will be used as heading. Default (true) is set in visual.setup.js.
Boolean. It determines if the chart legend must be shown. Default (true) is set in visual.setup.js.
Object with a single property: width (number). Default width (0) is set in visual.setup.js.
Object with two properties: x (boolean) and y (boolean). They determine if the axes must be shown. Default (true) is set in visual.setup.js.
Object with three properties: label (string), symbol (string) and symbol position (string. "start", "end"). All properties are optional. Default (no label, no symbol, position: end) is set in visual.setup.js.
Warning: label and symbol cannot contain HTML entities when type is "cmap".
Number. Number of decimals in the data. It is used in the tooltip and map legend. Even though this is an optional property, it is strongly recommended that the number of decimals is specified: otherwise, all unneeded trailing zeros will be removed and computed values could be shown with more decimals than the original values. Default value can be set in visual.setup.js.
String ("bar", "rank", "tsbar", "tsline", "pyram", "cmap"). Required. Chart type. It determines the data and time formats and the specific properties available.
Array. Required. It includes the data values but also series labels and IDs. The format is determined by type.
String. On simple mode and manual mode, it is the ID of the HTML element where the visualization has to be embedded.
Array. On simple mode and manual mode, it is the [width, height] in pixels of the visualization container.
Function. This function will be called after the chart has been drawn. The this keyword would point to an object with two properties: "id" (the chart's id: string) and "chart" (a boolean indicating if the chart is drawable or not: if false, VisualJS.chart() would not be defined).
Boolean. It determines if the chart must be shown. When false, all the necessary files will be included but the chart will not be inserted: you'll need to use a callback function that executes at some point VisualJS.chart(). Default is true.
VisualJS.load({
show: false,
callback: function(){
if(this.chart && window.confirm("Are you sure you want to see this chart?")){
VisualJS.chart();
}
},
...
});
Distribution of a categorical variable (vertical bar chart).
visual({
title: "BAR example",
geo: "Alt Camp",
time: "2012",
footer: "The source goes here.",
unit: {label: "persones"},
dec: 0,
type: "bar",
data : [
["0-14 anys", 7329],
["15-64 anys", 30231],
["65-84 anys", 6485],
["85 anys o més", 1254]
]
});
Examples: bar.html
String. Time period.
Array of arrays. Required. The first array contains as many elements as categories. Each element is an array of two elements: a string (label) and a number (value).
Ranking (horizontal bar chart).
visual({
title: "RANK example (40 data)",
geo: "Catalonia",
time: "2009",
footer: "The source goes here.",
unit: {label: "milers", symbol: "€"},
dec: 0,
type: "rank",
data : [
["Val d'Aran", 20300],
["Pallars Jussà", 19300],
["Ripollès", 19100],
["Urgell", 18900],
["Conca de Barberà", 18800],
["Gironès", 18700],
["Pallars Sobirà", 18700],
["Alta Ribagorça", 18600],
["Cerdanya", 18600],
["Garrotxa", 18600],
["Pla de l'Estany", 18600],
["Barcelonès", 18300],
["Priorat", 18300],
["Ribera d'Ebre", 18200],
["Segrià ", 18100],
["Garrigues", 18000],
["Baix Empordà", 17700],
["Maresme", 17700],
["Alt Camp", 17600],
["Noguera", 17600],
["Tarragonès", 17600],
["Terra Alta", 17600],
["Segarra", 17400],
["Alt Empordà", 17300],
["Baix Penedès", 17300],
["Solsonès", 17300],
["Vallès Occidental", 17300],
["Berguedà", 17200],
["Baix Camp", 17100],
["Pla d'Urgell", 17100],
["Montsià", 17000],
["Alt Penedès", 16900],
["Bages", 16900],
["Baix Ebre", 16900],
["Garraf", 16900],
["Alt Urgell", 16600],
["Selva", 16300],
["Osona", 16200],
["Vallès Oriental", 16200],
["Baix Llobregat", 16000],
["Anoia", 15800]
]
});
Examples: rank.html, rank10.html
String. Time period.
Array of arrays. Required. The first array contains as many elements as categories. Each element is an array of two elements: a string (label) and a number (value).
Stacked/non-stacked time series (vertical bar chart).
visual({
title: "TSBAR example",
geo: "Catalonia",
time : [
"1998", "1999", "2000", "2001", "2002",
"2003", "2004", "2005", "2006", "2007",
"2008", "2009", "2010", "2011", "2012"
],
footer: "The source goes here.",
unit: {label: "M", symbol: "€"},
dec: 1,
type: "tsbar",
data : [
{
label: "Exportacions",
val: [
27147.8, 27890.6, 33796.5, 36694.5, 37275.9,
37648.5, 39485.1, 42703.4, 47218.8, 49679.8,
50515.7, 41461.7, 48871.6, 54999.9, 58321.7
]
},
{
label: "Importacions",
val: [
36203.7, 40316.5, 48761.7, 50497.9, 51891.8,
54344.7, 60731, 67813.3, 74787.8, 80363.4,
77233.9, 57663.8, 67621.1, 72280.2, 69343.1
]
}
]
});
Examples: tsbar.html, tsbar2.html, tsbarns.html
Array of strings. Required. Time periods.
Array of objects. Required. The array contains as many elements as series. Each element is an object with two properties: label (string) and val (array of values).
Boolean. Default: false. When bars are not stacked, only three series are allowed.
Time series (line chart).
visual({
title: "TSLINE example",
geo: "Catalonia",
time : [
"1998", "1999", "2000", "2001", "2002",
"2003", "2004", "2005", "2006", "2007",
"2008", "2009", "2010", "2011", "2012"
],
footer: "The source goes here.",
unit: {label: "M", symbol: "€"},
dec: 1,
type: "tsline",
data : [
{
label: "Exportacions",
val: [
27147.8, 27890.6, 33796.5, 36694.5, 37275.9,
37648.5, 39485.1, 42703.4, 47218.8, 49679.8,
50515.7, 41461.7, 48871.6, 54999.9, 58321.7
]
},
{
label: "Importacions",
val: [
36203.7, 40316.5, 48761.7, 50497.9, 51891.8,
54344.7, 60731, 67813.3, 74787.8, 80363.4,
77233.9, 57663.8, 67621.1, 72280.2, 69343.1
]
}
]
});
Examples: tsline2.html
Array of strings. Required. Time periods.
Array of objects. Required. The array contains as many elements as series. Each element is an object with two properties: label (string) and val (array of values).
Population pyramid.
visual({
title: "PYRAM example",
geo: "Some country",
time: "2012",
footer: "The source goes here.",
unit: {label: "persones"},
dec: 0,
type: "pyram",
by: [
"0-4", "5-9", "10-14", "15-19", "20-24", "25-29",
"30-34", "35-39", "40-44", "45-49", "50-54", "55-59",
"60-64", "65-69", "70-74", "75-79", "80-84", "85-89",
"90-94", "95-99", "100+"
],
data: [
{
label: "Homes",
val: [
130229, 132460, 109072, 115983, 133972, 166757,
207016, 211782, 195472, 176832, 152151, 122107,
117375, 99405, 80274, 73283, 47597, 24195, 6997, 1532, 260
]
},
{
label: "Dones",
val: [
124757, 112944, 103163, 104773, 122879, 152743,
196767, 193411, 194849, 174780, 155177, 133712,
126386, 117169, 98444, 99468, 76448, 47515,17929, 4284, 548
]
}
]
});
Examples: pyram.html
String. Time period.
Array of objects. Required. The array contains two elements: one for each sex. Each element is an object with two properties: label (string) and val (array of values).
Array of strings. Required. Each element is an age label.
Choropleth map
visual({
title: "CMAP example with missing data",
geo: "Catalonia",
time: "2001",
footer: "The source goes here.",
unit: {symbol: "%"},
type: "cmap",
dec: 2,
by: "com",
data: [
{id: "01", val: 85.50},
{id: "02", val: 79.40},
{id: "03", val: 80.91},
{id: "04", val: 86.50},
{id: "05", val: 83.01},
{id: "06", val: 79.04},
{id: "07", val: 82.74},
{id: "08", val: 77.31},
{id: "09", val: 86.48},
{id: "10", val: 79.94},
{id: "11", val: 65.79},
{id: "12", val: 73.04},
{id: "13", val: 70.35},
{id: "14", val: 89.96},
{id: "15", val: 84.79},
{id: "16", val: 91.06},
{id: "17", val: 75.31},
{id: "18", val: 92.95},
{id: "19", val: 89.95},
{id: "20", val: 82.50},
{id: "21", val: 77.03},
{id: "22", val: 86.48},
{id: "23", val: 90.73},
{id: "24", val: 86.06},
{id: "25", val: 88.94},
{id: "26", val: 91.67},
{id: "27", val: 88.38},
{id: "28", val: 88.68},
{id: "29", val: 92.49},
{id: "30", val: 90.66},
{id: "31", val: 88.24},
{id: "32", val: 86.17},
{id: "33", val: 83.71},
{id: "34", val: 77.71},
{id: "35", val: 90.53},
{id: "36", val: 74.20},
{id: "34", val: 91.87},
{id: "38", val: 88.66},
{id: "39", val: 77.98},
{id: "40", val: 71.31},
{id: "41", val: 75.56}
]
});
Examples: cmap.html, cmap-com.html, cmap-f0.html, cmap-f020.html, cmap-groups1.html, cmap-groups2.html
String. Time period.
Array of objects. Required. The array contains as many elements as map areas. Each element is an object with at least one property: the area id (string). In this case, a map will be created with the included areas highlighted. If val (number) is included, it will be used to automatically assigned colors to areas, unless grouped has been specified. In that case, the group property (counter starting with 1) is required and will be used to assign colors, but val can still be specified if needed.
Array. Each element is a group label string (first label will be attached to areas with a group property of 1 in data, and so on).
String. Required. Selects a certain map. Possible values ("mun", "com", "prov") are set in visual.setup.js.
Number or array. It determines the color assignation. When it is a number, it must be between 0 and 0.49. Default: 0.05, which means color assignation excludes values below the 5th percentile and above the 95th percentile. When it is an array, it defines a range: it has two and only two elements. The first (number) is a minimum and the second (number) is a maximum. Color assignation will be done between those values.
The following sample maps are provided:
- Catalonia by municipalities, counties and provinces (3 maps)
- Counties of Catalonia by municipalities (41 maps)
- United States of America by states (1 map)
They are stored at the maps folder.
A map is a UTF-8 Javascript file that adds a new property (the name of the map) to the VisualJS.map object. The value of this new property is a Visual map object.
Geographic information must be provided in the GeoJSON format: it must be a feature collection object (a GeoJSON object with the type "FeatureCollection"). Just copy the "features" property of the GeoJSON object into the Visual map object.
"projection" (string) must be a valid D3 geo projection function name. "scale" is the projection scale (a number) and "center" is the projection center (a coordinate array).
projection: "mercator",
scale: 9000,
center: [1.74, 41.7],
If a projection does not support centering (for example, Albers USA), "center" is optional and, if present, it will be ignored.
Currently, Visual does not support rotation.
Use "id" and "label" to specify the properties in "features" that contain the regions' IDs and the regions' labels.
id: "STATE",
label: "NAME",
Use "area" to provide the canvas size in pixels (width, height) where your projection will be drawn. Use "legend" to specify the location in pixels (width, height) of the map legend in the canvas.
area: [500, 500],
legend: [280, 345],
These values will not determine the final size of your map (maps will scale to the available space): they are only important to determine the "scale" and "center" values.
Maps must be declared in visual.setup.js. To include a new map, edit visual.setup.js and create a new property with the name of the map inside VisualJS.setup.map. This name must match the name in VisualJS.map (in the Javascript map file) and will be used in the by property. The value of this property must be an object with two properties: the address of the map ("js") and an existence function ("exists").
Visual uses the following libraries internally:
- LazyLoad
- D3
- jQuery, required by Flot
- Flot (stack, categories), Flot orderBars, Flot Pyramid
- ExplorerCanvas
These libraries are only loaded when needed.
For convenience, they are included in the lib folder but you can use any location (for example, a CDN) in visual.setup.js.
D3 requires a modern browser (versions of Internet Explorer prior to 9 are not supported). Visual uses D3 only for choropleth maps (chart type: "cmap").
The non-stacked time series chart supports a maximum of three series. This is not a technical limitation but a visual one.
You are welcome to contribute to this project! Areas where your participation can be very useful are, for example:
- Support for new chart types
- Maps of your territory
To contribute, fork this repository, push changes to your personal fork and send a pull request.