Box & Whisker

The Box and Whisker series (AKA boxplots) show groups of numerical data through their quartiles. They have lines extending vertically from the boxes (whiskers) indicating variability outside the upper and lower quartiles.

This sample also shows how to use the showInnerPoints, showOutliers, showMeanLine, showMeanMarker and rotated properties to customize the look and feel of your Box and Whisker series.

Learn about FlexChart | Box and Whisker Documentation | FlexChart API Reference

app.js
index.html
data.js
styles.css
Copy to CodeMine
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; // import { isArray } from '@mescius/wijmo'; import { FlexChart, Palettes } from '@mescius/wijmo.chart'; import { BoxWhisker } from '@mescius/wijmo.chart.analytics'; import { getData } from './data'; // document.readyState === 'complete' ? init() : window.onload = init; // function init() { // create the chart let theChart = new FlexChart('#theChart', { itemsSource: getData(), bindingX: 'country', tooltip: { content: '{seriesName}: <b>{x}</b>' }, palette: getRandomPalette() }); // // create BoxWhisker series for 'sales' and add it to the chart theChart.series.push(new BoxWhisker({ name: 'Sales', binding: 'sales', groupWidth: 0.7, gapWidth: 0.2 })); // // create BoxWhisker series for 'expenses' and add it to the chart theChart.series.push(new BoxWhisker({ name: 'Expenses', binding: 'expenses', groupWidth: 0.7, gapWidth: 0.2 })); // // customize the BoxWhisker series document.querySelector('#innerPoints').addEventListener('click', e => { theChart.series.forEach((series) => { series.showInnerPoints = e.target.checked; }); }); document.querySelector('#outliers').addEventListener('click', e => { theChart.series.forEach((series) => { series.showOutliers = e.target.checked; }); }); document.querySelector('#meanline').addEventListener('click', e => { theChart.series.forEach((series) => { series.showMeanLine = e.target.checked; }); }); document.querySelector('#meanmarker').addEventListener('click', e => { theChart.series.forEach((series) => { series.showMeanMarker = e.target.checked; }); }); document.querySelector('#rotated').addEventListener('click', e => { theChart.rotated = e.target.checked; }); // // randomize the data document.querySelector('#btnRandomize').addEventListener('click', () => { theChart.itemsSource = getData(); }); } // function getRandomPalette() { let palettes = Object.keys(Palettes).filter(prop => isArray(Palettes[prop])); let rand = Math.floor(Math.random() * palettes.length); // return Palettes[palettes[rand]]; }
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; // import { isArray } from '@mescius/wijmo'; import { FlexChart, Palettes } from '@mescius/wijmo.chart'; import { BoxWhisker } from '@mescius/wijmo.chart.analytics'; import { getData } from './data'; // document.readyState === 'complete' ? init() : window.onload = init; // function init() { // create the chart let theChart = new FlexChart('#theChart', { itemsSource: getData(), bindingX: 'country', tooltip: { content: '{seriesName}: <b>{x}</b>' }, palette: getRandomPalette() }); // // create BoxWhisker series for 'sales' and add it to the chart theChart.series.push(new BoxWhisker({ name: 'Sales', binding: 'sales', groupWidth: 0.7, gapWidth: 0.2 })); // // create BoxWhisker series for 'expenses' and add it to the chart theChart.series.push(new BoxWhisker({ name: 'Expenses', binding: 'expenses', groupWidth: 0.7, gapWidth: 0.2 })); // // customize the BoxWhisker series document.querySelector('#innerPoints').addEventListener('click', e => { theChart.series.forEach((series) => { series.showInnerPoints = e.target.checked; }); }); document.querySelector('#outliers').addEventListener('click', e => { theChart.series.forEach((series) => { series.showOutliers = e.target.checked; }); }); document.querySelector('#meanline').addEventListener('click', e => { theChart.series.forEach((series) => { series.showMeanLine = e.target.checked; }); }); document.querySelector('#meanmarker').addEventListener('click', e => { theChart.series.forEach((series) => { series.showMeanMarker = e.target.checked; }); }); document.querySelector('#rotated').addEventListener('click', e => { theChart.rotated = e.target.checked; }); // // randomize the data document.querySelector('#btnRandomize').addEventListener('click', () => { theChart.itemsSource = getData(); }); } // function getRandomPalette() { let palettes = Object.keys(Palettes).filter(prop => isArray(Palettes[prop])); let rand = Math.floor(Math.random() * palettes.length); // return Palettes[palettes[rand]]; }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>MESCIUS Wijmo FlexChart BoxWhisker</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- SystemJS --> <script src="https://cdnjs.cloudflare.com/ajax/libs/systemjs/0.21.5/system.src.js" integrity="sha512-skZbMyvYdNoZfLmiGn5ii6KmklM82rYX2uWctBhzaXPxJgiv4XBwJnFGr5k8s+6tE1pcR1nuTKghozJHyzMcoA==" crossorigin="anonymous"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app'); </script> </head> <body> <div class="container-fluid"> <div class="form-group"> <label for="innerPoints">Show Inner Points:</label> <input id="innerPoints" type="checkbox"> <label for="outliers">Show Outliers:</label> <input id="outliers" type="checkbox"> </div> <div class="form-group"> <label for="meanline">Show Mean Line:</label> <input id="meanline" type="checkbox"> <label for="meanmarker">Show Mean Marker:</label> <input id="meanmarker" type="checkbox"> </div> <div class="form-group"> <label for="rotated">Rotated:</label> <input id="rotated" type="checkbox"> <label for="btnRandomize">Randomize Data</label> <button id="btnRandomize" class="btn btn-default"> Go </button> </div> <div id="theChart"></div> </div> </body> </html>
// create some random data // the data items contain arrays of values rather than single values export function getData() { let countries = ['US', 'Canada', 'Mexico', 'Germany', 'UK', 'France', 'Japan', 'Korea', 'China'], data = []; // for (let i = 0; i < countries.length; i++) { data.push({ country: countries[i], sales: getRandomArray(20, 10000), expenses: getRandomArray(20, 5000) }); } // return data; } // function getRandomArray(count, max) { let arr = []; // for (var i = 0; i < count; i++) { arr.push(Math.random() * max / 3 + Math.random() * max / 3 + Math.random() * max / 3); } // return arr; }
.wj-flexchart { height: 300px; } label { width: 160px; text-align: right; } body { margin-bottom: 24px; }
(function (global) { System.config({ transpiler: 'plugin-babel', babelOptions: { es2015: true }, meta: { '*.css': { loader: 'css' } }, paths: { // paths serve as alias 'npm:': 'node_modules/' }, // map tells the System loader where to look for things map: { 'jszip': 'npm:jszip/dist/jszip.js', '@mescius/wijmo': 'npm:@mescius/wijmo/index.js', '@mescius/wijmo.input': 'npm:@mescius/wijmo.input/index.js', '@mescius/wijmo.styles': 'npm:@mescius/wijmo.styles', '@mescius/wijmo.cultures': 'npm:@mescius/wijmo.cultures', '@mescius/wijmo.chart': 'npm:@mescius/wijmo.chart/index.js', '@mescius/wijmo.chart.analytics': 'npm:@mescius/wijmo.chart.analytics/index.js', '@mescius/wijmo.chart.animation': 'npm:@mescius/wijmo.chart.animation/index.js', '@mescius/wijmo.chart.annotation': 'npm:@mescius/wijmo.chart.annotation/index.js', '@mescius/wijmo.chart.finance': 'npm:@mescius/wijmo.chart.finance/index.js', '@mescius/wijmo.chart.finance.analytics': 'npm:@mescius/wijmo.chart.finance.analytics/index.js', '@mescius/wijmo.chart.hierarchical': 'npm:@mescius/wijmo.chart.hierarchical/index.js', '@mescius/wijmo.chart.interaction': 'npm:@mescius/wijmo.chart.interaction/index.js', '@mescius/wijmo.chart.radar': 'npm:@mescius/wijmo.chart.radar/index.js', '@mescius/wijmo.chart.render': 'npm:@mescius/wijmo.chart.render/index.js', '@mescius/wijmo.chart.webgl': 'npm:@mescius/wijmo.chart.webgl/index.js', '@mescius/wijmo.chart.map': 'npm:@mescius/wijmo.chart.map/index.js', '@mescius/wijmo.gauge': 'npm:@mescius/wijmo.gauge/index.js', '@mescius/wijmo.grid': 'npm:@mescius/wijmo.grid/index.js', '@mescius/wijmo.grid.detail': 'npm:@mescius/wijmo.grid.detail/index.js', '@mescius/wijmo.grid.filter': 'npm:@mescius/wijmo.grid.filter/index.js', '@mescius/wijmo.grid.search': 'npm:@mescius/wijmo.grid.search/index.js', '@mescius/wijmo.grid.style': 'npm:@mescius/wijmo.grid.style/index.js', '@mescius/wijmo.grid.grouppanel': 'npm:@mescius/wijmo.grid.grouppanel/index.js', '@mescius/wijmo.grid.multirow': 'npm:@mescius/wijmo.grid.multirow/index.js', '@mescius/wijmo.grid.transposed': 'npm:@mescius/wijmo.grid.transposed/index.js', '@mescius/wijmo.grid.transposedmultirow': 'npm:@mescius/wijmo.grid.transposedmultirow/index.js', '@mescius/wijmo.grid.pdf': 'npm:@mescius/wijmo.grid.pdf/index.js', '@mescius/wijmo.grid.sheet': 'npm:@mescius/wijmo.grid.sheet/index.js', '@mescius/wijmo.grid.xlsx': 'npm:@mescius/wijmo.grid.xlsx/index.js', '@mescius/wijmo.grid.selector': 'npm:@mescius/wijmo.grid.selector/index.js', '@mescius/wijmo.grid.cellmaker': 'npm:@mescius/wijmo.grid.cellmaker/index.js', '@mescius/wijmo.nav': 'npm:@mescius/wijmo.nav/index.js', '@mescius/wijmo.odata': 'npm:@mescius/wijmo.odata/index.js', '@mescius/wijmo.olap': 'npm:@mescius/wijmo.olap/index.js', '@mescius/wijmo.rest': 'npm:@mescius/wijmo.rest/index.js', '@mescius/wijmo.pdf': 'npm:@mescius/wijmo.pdf/index.js', '@mescius/wijmo.pdf.security': 'npm:@mescius/wijmo.pdf.security/index.js', '@mescius/wijmo.viewer': 'npm:@mescius/wijmo.viewer/index.js', '@mescius/wijmo.xlsx': 'npm:@mescius/wijmo.xlsx/index.js', '@mescius/wijmo.undo': 'npm:@mescius/wijmo.undo/index.js', '@mescius/wijmo.interop.grid': 'npm:@mescius/wijmo.interop.grid/index.js', '@mescius/wijmo.touch': 'npm:@mescius/wijmo.touch/index.js', '@mescius/wijmo.cloud': 'npm:@mescius/wijmo.cloud/index.js', '@mescius/wijmo.barcode': 'npm:@mescius/wijmo.barcode/index.js', '@mescius/wijmo.barcode.common': 'npm:@mescius/wijmo.barcode.common/index.js', '@mescius/wijmo.barcode.composite': 'npm:@mescius/wijmo.barcode.composite/index.js', '@mescius/wijmo.barcode.specialized': 'npm:@mescius/wijmo.barcode.specialized/index.js', 'jszip': 'npm:jszip/dist/jszip.js', 'bootstrap.css': 'npm:bootstrap/dist/css/bootstrap.min.css', 'css': 'npm:systemjs-plugin-css/css.js', 'plugin-babel': 'npm:systemjs-plugin-babel/plugin-babel.js', 'systemjs-babel-build':'npm:systemjs-plugin-babel/systemjs-babel-browser.js' }, // packages tells the System loader how to load when no filename and/or no extension packages: { src: { defaultExtension: 'js' }, "node_modules": { defaultExtension: 'js' }, } }); })(this);