/* ------------------------------------------------------------------------------ * * # Echarts - chart combinations * * Chart combination configurations * * Version: 1.0 * Latest update: August 1, 2015 * * ---------------------------------------------------------------------------- */ $(function () { // Set paths // ------------------------------ require.config({ paths: { echarts: 'assets/js/plugins/visualization/echarts' } }); // Configuration // ------------------------------ require( // Add necessary charts [ 'echarts', 'echarts/theme/limitless', 'echarts/chart/line', 'echarts/chart/bar', 'echarts/chart/pie', 'echarts/chart/scatter', 'echarts/chart/k', 'echarts/chart/radar', 'echarts/chart/gauge' ], // Charts setup function (ec, limitless) { // Initialize charts // ------------------------------ var line_bar = ec.init(document.getElementById('line_bar'), limitless); var column_pie = ec.init(document.getElementById('column_pie'), limitless); var scatter_pie = ec.init(document.getElementById('scatter_pie'), limitless); var scatter_line = ec.init(document.getElementById('scatter_line'), limitless); var connect_pie = ec.init(document.getElementById('connect_pie'), limitless); var connect_column = ec.init(document.getElementById('connect_column'), limitless); var candlestick_scatter = ec.init(document.getElementById('candlestick_scatter'), limitless); // Charts options // ------------------------------ // // Line and bar combination // line_bar_options = { // Setup grid grid: { x: 55, x2: 45, y: 35, y2: 25 }, // Add tooltip tooltip: { trigger: 'axis' }, // Enable drag recalculate calculable: true, // Add legend legend: { data: ['Evaporation','Precipitation','Temperature'] }, // Horizontal axis xAxis: [{ type: 'category', data: ['January','February','March','April','May','June','July','August','September','October','November','December'] }], // Vertical axis yAxis: [ { type: 'value', name: 'Water', axisLabel: { formatter: '{value} ml' } }, { type: 'value', name: 'Temp', axisLabel: { formatter: '{value} °C' } } ], // Add series series: [ { name: 'Evaporation', type: 'bar', data: [2.0, 4.9, 7.0, 23.2, 25.6, 76.7, 135.6, 162.2, 32.6, 20.0, 6.4, 3.3] }, { name: 'Precipitation', type: 'bar', data: [2.6, 5.9, 9.0, 26.4, 28.7, 70.7, 175.6, 182.2, 48.7, 18.8, 6.0, 2.3] }, { name: 'Temperature', type: 'line', yAxisIndex: 1, data: [2.0, 2.2, 3.3, 4.5, 6.3, 10.2, 20.3, 23.4, 23.0, 16.5, 12.0, 6.2] } ] }; // // Column and pie combination // column_pie_options = { // Setup grid grid: { x: 10, x2: 45, y: 35, y2: 25 }, // Add tooltip tooltip: { trigger: 'axis' }, // Enable drag recalculate calculable: true, // Add legend legend: { data: ['Direct','Email','Print','Video','Search engine','Google','Bing','Yahoo','Other'] }, // Horizontal axis xAxis: [{ type: 'category', splitLine: {show: false}, data: ['Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sunday'] }], // Vertical axis yAxis: [{ type: 'value', position: 'right' }], // Add series series: [ { name: 'Direct', type: 'bar', data: [320, 332, 301, 334, 390, 330, 320] }, { name: 'Email', type: 'bar', tooltip: {trigger: 'item'}, stack: 'Advertisement', data: [120, 132, 101, 134, 90, 230, 210] }, { name: 'Print', type: 'bar', tooltip: {trigger: 'item'}, stack: 'Advertisement', data: [220, 182, 191, 234, 290, 330, 310] }, { name: 'Video', type: 'bar', tooltip: {trigger: 'item'}, stack: 'Advertisement', data: [150, 232, 201, 154, 190, 330, 410] }, { name: 'Search engine', type: 'line', data: [862, 1018, 964, 1026, 1679, 1600, 1570] }, // Pie { name: 'Search engine', type: 'pie', tooltip: { trigger: 'item', formatter: '{a}
{b}: {c} ({d}%)' }, center: [150, 130], radius: [0, 50], itemStyle: { normal: { labelLine: { length: 20 } } }, data: [ {value: 1048, name: 'Google'}, {value: 251, name: 'Bing'}, {value: 147, name: 'Yahoo'}, {value: 102, name: 'Other'} ] } ] }; // // Scatter and pie combination // // Data set 1 var sData1 = (function () { var d = []; var len = 40; var value; while (len--) { d.push([ Math.round(Math.random()*10) * (Math.round(Math.random()*10) > 5 ? 1: -1), Math.round(Math.random()*10) * (Math.round(Math.random()*10) > 5 ? 1: -1), Math.round(Math.random()*20) ]); } return d; })(); // Data set 2 var sData2 = (function () { var d = []; var len = sData1.length; for (var i = 0; i < len; i++) { d.push([ sData1[i][0], sData1[i][1], Math.round(Math.random()*15) ]); } return d; })(); // Setup scatter_pie_options = { // Setup grid grid: { x: 35, x2: 35, y: 35, y2: 35 }, // Set custo, colors color: ['rgba(255, 69, 0, 0.5)', 'rgba(30, 144, 255, 0.5)'], // Add tooltip tooltip: { trigger: 'item', formatter: "{b}: {c} ({d}%)" }, // Horizontal axis xAxis: [{ type: 'value', splitNumber: 2 }], // Vertical axis yAxis: [{ type: 'value', splitNumber: 2 }], //animation: false, // Add series series: [ { type: 'scatter', symbol: 'none', data: sData1 }, { type: 'scatter', symbol: 'none', data: sData2 } ] }; // Generate pie series function buildPieSeries() { var xAxis = scatter_pie.component.xAxis.getAxis(0); var yAxis = scatter_pie.component.yAxis.getAxis(0); var len = sData1.length; scatter_pie_options.series = scatter_pie_options.series.slice(0,2); scatter_pie_options.legend = { data: ['Summer', 'Winter'] }; while (len--) { scatter_pie_options.series.push({ type: 'pie', itemStyle: { normal: { label: { show: false }, labelLine: { show: false } } }, radius: sData1[len][2] + sData2[len][2], center: [ xAxis.getCoord(sData1[len][0]), yAxis.getCoord(sData1[len][1]) ], data: [ {name: 'Summer', value: sData1[len][2]}, {name: 'Winter', value: sData2[len][2]} ] }) } scatter_pie_options.animation = true; scatter_pie.setOption(scatter_pie_options, true); } // Build pie charts instead of the original scatter setTimeout(buildPieSeries, 100); // // Scatter and line combination // scatter_line_options = { // Setup grid grid: { x: 35, x2: 35, y: 35, y2: 25 }, // Add tooltip tooltip: { trigger: 'axis' }, // Add data range dataRange: { min: 0, max: 100, orient: 'horizontal', y: 'top', x: 'center', color: ['#FF8A65','#FBE9E7'], splitNumber: 5 }, // Horizontal axis xAxis: [ { type: 'category', boundaryGap: false, data: function () { var list = []; for (var i = 1; i <= 15; i++) { list.push('2013-03-' + i); } return list; }() }, { type: 'value', scale: true, splitNumber: 15, axisLabel: {show: false}, splitLine: {show: false} } ], // Vertical axis yAxis: [ { type: 'value' }, { type: 'value' } ], // Add series series: [ { name: 'Scatter value', type: 'scatter', tooltip: { trigger: 'item', formatter: function (params) { return '2013-03-' + params.value[0] + '
' + params.seriesName + ': ' + params.value[1] + ', ' + params.value[2]; } }, yAxisIndex: 1, xAxisIndex: 1, symbol: 'circle', symbolSize: function (value){ return Math.round(value[2]/10); }, data: (function () { var d = []; var len = 200; var value; while (len--) { d.push([ Math.round(Math.random()*29) + 1, (Math.random()*30).toFixed(2) - 0, (Math.random()*100).toFixed(2) - 0 ]); } return d; })() }, { name: 'Line value', type: 'line', data: function (){ var list = []; for (var i = 1; i <= 30; i++) { list.push(Math.round(Math.random()* 30)); } return list; }() } ] }; // // Column and pie connection // // Pie options connect_pie_options = { // Add title title: { text: 'Browser popularity', subtext: 'Open source data', x: 'center' }, // Add tooltip tooltip: { trigger: 'item', formatter: "{a}
{b}: {c} ({d}%)" }, // Add legend legend: { orient: 'vertical', x: 'left', data: ['Internet Explorer','Opera','Safari','Firefox','Chrome'] }, // Enable drag recalculate calculable: true, // Add series series: [{ name: 'Browser', type: 'pie', radius: '75%', center: ['50%', '57.5%'], data: [ {value: 335, name: 'Internet Explorer'}, {value: 310, name: 'Opera'}, {value: 234, name: 'Safari'}, {value: 135, name: 'Firefox'}, {value: 1548, name: 'Chrome'} ] }] }; // Column options connect_column_options = { // Setup grid grid: { x: 40, x2: 47, y: 35, y2: 25 }, // Add tooltip tooltip: { trigger: 'axis', axisPointer: { type: 'shadow' } }, // Add legend legend: { data: ['Internet Explorer','Opera','Safari','Firefox','Chrome'] }, // Add toolbox toolbox: { show: true, orient: 'vertical', x: 'right', y: 35, feature: { mark: { show: true, title: { mark: 'Markline switch', markUndo: 'Undo markline', markClear: 'Clear markline' } }, magicType: { show: true, title: { line: 'Switch to line chart', bar: 'Switch to bar chart', stack: 'Switch to stack', tiled: 'Switch to tiled' }, type: ['line', 'bar', 'stack', 'tiled'] }, restore: { show: true, title: 'Restore' }, saveAsImage: { show: true, title: 'Same as image', lang: ['Save'] } } }, // Enable drag recalculate calculable: true, // Horizontal axis xAxis: [{ type: 'category', data: ['Monday','Tuesday','Wednesday','Thursday','Friday','Saturday','Sunday'] }], // Vertical axis yAxis: [{ type: 'value', splitArea: {show: true} }], // Add series series: [ { name: 'Internet Explorer', type: 'bar', stack: 'Total', data: [320, 332, 301, 334, 390, 330, 320] }, { name: 'Opera', type: 'bar', stack: 'Total', data: [120, 132, 101, 134, 90, 230, 210] }, { name: 'Safari', type: 'bar', stack: 'Total', data: [220, 182, 191, 234, 290, 330, 310] }, { name: 'Firefox', type: 'bar', stack: 'Total', data: [150, 232, 201, 154, 190, 330, 410] }, { name: 'Chrome', type: 'bar', stack: 'Total', data: [820, 932, 901, 934, 1290, 1330, 1320] } ] }; // Connect charts connect_pie.connect(connect_column); connect_column.connect(connect_pie); // // Dynamic data (scatter and candlestick combination) // candlestick_scatter_options = { // Setup grid grid: { x: 45, x2: 45, y: 60, y2: 90 }, // Add tooltip tooltip: { trigger: 'axis' }, // Add legend legend: { data:['Composite index', 'Turnover (million)'] }, // Display data zoom dataZoom: { show: true, realtime: true, start: 50, end: 100, height: 40 }, // Horizontal axis xAxis: [ { type: 'category', boundaryGap: true, data: [ "2013/1/24", "2013/1/25", "2013/1/28", "2013/1/29", "2013/1/30", "2013/1/31", "2013/2/1", "2013/2/4", "2013/2/5", "2013/2/6", "2013/2/7", "2013/2/8", "2013/2/18", "2013/2/19", "2013/2/20", "2013/2/21", "2013/2/22", "2013/2/25", "2013/2/26", "2013/2/27", "2013/2/28", "2013/3/1", "2013/3/4", "2013/3/5", "2013/3/6", "2013/3/7", "2013/3/8", "2013/3/11", "2013/3/12", "2013/3/13", "2013/3/14", "2013/3/15", "2013/3/18", "2013/3/19", "2013/3/20", "2013/3/21", "2013/3/22", "2013/3/25", "2013/3/26", "2013/3/27", "2013/3/28", "2013/3/29", "2013/4/1", "2013/4/2", "2013/4/3", "2013/4/8", "2013/4/9", "2013/4/10", "2013/4/11", "2013/4/12", "2013/4/15", "2013/4/16", "2013/4/17", "2013/4/18", "2013/4/19", "2013/4/22", "2013/4/23", "2013/4/24", "2013/4/25", "2013/4/26", "2013/5/2", "2013/5/3", "2013/5/6", "2013/5/7", "2013/5/8", "2013/5/9", "2013/5/10", "2013/5/13", "2013/5/14", "2013/5/15", "2013/5/16", "2013/5/17", "2013/5/20", "2013/5/21", "2013/5/22", "2013/5/23", "2013/5/24", "2013/5/27", "2013/5/28", "2013/5/29", "2013/5/30", "2013/5/31", "2013/6/3", "2013/6/4", "2013/6/5", "2013/6/6", "2013/6/7", "2013/6/13" ] }, { type: 'value', max: 100, scale: true } ], // Vertical axis yAxis: [ { type: 'value', scale: true, splitNumber: 5, boundaryGap: [0.05, 0.05] }, { type: 'value', splitNumber: 5, scale: true } ], // Add series series: [ { name: 'Composite index', type: 'k', data: [ [2320.26,2302.6,2287.3,2362.94], [2300,2291.3,2288.26,2308.38], [2295.35,2346.5,2295.35,2346.92], [2347.22,2358.98,2337.35,2363.8], [2360.75,2382.48,2347.89,2383.76], [2383.43,2385.42,2371.23,2391.82], [2377.41,2419.02,2369.57,2421.15], [2425.92,2428.15,2417.58,2440.38], [2411,2433.13,2403.3,2437.42], [2432.68,2434.48,2427.7,2441.73], [2430.69,2418.53,2394.22,2433.89], [2416.62,2432.4,2414.4,2443.03], [2441.91,2421.56,2415.43,2444.8], [2420.26,2382.91,2373.53,2427.07], [2383.49,2397.18,2370.61,2397.94], [2378.82,2325.95,2309.17,2378.82], [2322.94,2314.16,2308.76,2330.88], [2320.62,2325.82,2315.01,2338.78], [2313.74,2293.34,2289.89,2340.71], [2297.77,2313.22,2292.03,2324.63], [2322.32,2365.59,2308.92,2366.16], [2364.54,2359.51,2330.86,2369.65], [2332.08,2273.4,2259.25,2333.54], [2274.81,2326.31,2270.1,2328.14], [2333.61,2347.18,2321.6,2351.44], [2340.44,2324.29,2304.27,2352.02], [2326.42,2318.61,2314.59,2333.67], [2314.68,2310.59,2296.58,2320.96], [2309.16,2286.6,2264.83,2333.29], [2282.17,2263.97,2253.25,2286.33], [2255.77,2270.28,2253.31,2276.22], [2269.31,2278.4,2250,2312.08], [2267.29,2240.02,2239.21,2276.05], [2244.26,2257.43,2232.02,2261.31], [2257.74,2317.37,2257.42,2317.86], [2318.21,2324.24,2311.6,2330.81], [2321.4,2328.28,2314.97,2332], [2334.74,2326.72,2319.91,2344.89], [2318.58,2297.67,2281.12,2319.99], [2299.38,2301.26,2289,2323.48], [2273.55,2236.3,2232.91,2273.55], [2238.49,2236.62,2228.81,2246.87], [2229.46,2234.4,2227.31,2243.95], [2234.9,2227.74,2220.44,2253.42], [2232.69,2225.29,2217.25,2241.34], [2196.24,2211.59,2180.67,2212.59], [2215.47,2225.77,2215.47,2234.73], [2224.93,2226.13,2212.56,2233.04], [2236.98,2219.55,2217.26,2242.48], [2218.09,2206.78,2204.44,2226.26], [2199.91,2181.94,2177.39,2204.99], [2169.63,2194.85,2165.78,2196.43], [2195.03,2193.8,2178.47,2197.51], [2181.82,2197.6,2175.44,2206.03], [2201.12,2244.64,2200.58,2250.11], [2236.4,2242.17,2232.26,2245.12], [2242.62,2184.54,2182.81,2242.62], [2187.35,2218.32,2184.11,2226.12], [2213.19,2199.31,2191.85,2224.63], [2203.89,2177.91,2173.86,2210.58], [2170.78,2174.12,2161.14,2179.65], [2179.05,2205.5,2179.05,2222.81], [2212.5,2231.17,2212.5,2236.07], [2227.86,2235.57,2219.44,2240.26], [2242.39,2246.3,2235.42,2255.21], [2246.96,2232.97,2221.38,2247.86], [2228.82,2246.83,2225.81,2247.67], [2247.68,2241.92,2231.36,2250.85], [2238.9,2217.01,2205.87,2239.93], [2217.09,2224.8,2213.58,2225.19], [2221.34,2251.81,2210.77,2252.87], [2249.81,2282.87,2248.41,2288.09], [2286.33,2299.99,2281.9,2309.39], [2297.11,2305.11,2290.12,2305.3], [2303.75,2302.4,2292.43,2314.18], [2293.81,2275.67,2274.1,2304.95], [2281.45,2288.53,2270.25,2292.59], [2286.66,2293.08,2283.94,2301.7], [2293.4,2321.32,2281.47,2322.1], [2323.54,2324.02,2321.17,2334.33], [2316.25,2317.75,2310.49,2325.72], [2320.74,2300.59,2299.37,2325.53], [2300.21,2299.25,2294.11,2313.43], [2297.1,2272.42,2264.76,2297.1], [2270.71,2270.93,2260.87,2276.86], [2264.43,2242.11,2240.07,2266.69], [2242.26,2210.9,2205.07,2250.63], [2190.1,2148.35,2126.22,2190.1] ] }, { name: 'Turnover (million)', type: 'scatter', xAxisIndex: 1, yAxisIndex: 1, symbolSize: function (value) { return Math.round(value[2] / 4); }, data: (function () { var d = []; var len = 100; while (len--) { d.push([ (Math.random()*100).toFixed(2) - 0, (Math.random()*100).toFixed(2) - 0, (Math.random()*100).toFixed(2) - 0 ]); } return d; })() } ] }; var lastIndex = 0; var len = candlestick_scatter_options.series[0].data.length; clearInterval(random_data); var random_data = setInterval(function (){ lastIndex += 1; candlestick_scatter.addData([ [ 0, candlestick_scatter_options.series[0].data[lastIndex%len], false, false, candlestick_scatter_options.xAxis[0].data[lastIndex%len] ], [ 1, [ (Math.random()*100).toFixed(2) - 0, (Math.random()*100).toFixed(2) - 0, (Math.random()*100).toFixed(2) - 0 ], false, false ] ]); }, 2000); // Apply options // ------------------------------ line_bar.setOption(line_bar_options); column_pie.setOption(column_pie_options); scatter_pie.setOption(scatter_pie_options); scatter_line.setOption(scatter_line_options); candlestick_scatter.setOption(candlestick_scatter_options); connect_pie.setOption(connect_pie_options); connect_column.setOption(connect_column_options); // Resize charts // ------------------------------ window.onresize = function () { setTimeout(function (){ line_bar.resize(); column_pie.resize(); scatter_pie.resize(); buildPieSeries(); scatter_line.resize(); candlestick_scatter.resize(); connect_pie.resize(); connect_column.resize(); }, 200); } } ); });