| |
| <!-- |
| Licensed to the Apache Software Foundation (ASF) under one |
| or more contributor license agreements. See the NOTICE file |
| distributed with this work for additional information |
| regarding copyright ownership. The ASF licenses this file |
| to you under the Apache License, Version 2.0 (the |
| "License"); you may not use this file except in compliance |
| with the License. You may obtain a copy of the License at |
| |
| http://www.apache.org/licenses/LICENSE-2.0 |
| |
| Unless required by applicable law or agreed to in writing, |
| software distributed under the License is distributed on an |
| "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| KIND, either express or implied. See the License for the |
| specific language governing permissions and limitations |
| under the License. |
| --> |
| |
| <html> |
| <head> |
| <meta charset='utf-8'> |
| <script src='lib/simpleRequire.js'></script> |
| <script src='lib/config.js'></script> |
| <script src='lib/jquery.min.js'></script> |
| <meta name="viewport" content="width=device-width, initial-scale=1" /> |
| </head> |
| <body> |
| <style> |
| html, body, #main { |
| width: 100%; |
| height: 100%; |
| margin: 0; |
| } |
| #next { |
| position: absolute; |
| left: 10px; |
| top: 10px; |
| } |
| </style> |
| <div id='main'></div> |
| <button id="next">NEXT</button> |
| <script> |
| |
| require([ |
| 'echarts', |
| 'data/usa.json' |
| ], function (echarts, geojson) { |
| |
| echarts.registerMap('USA', geojson, { |
| Alaska: { // 把阿拉斯加移到美国主大陆左下方 |
| left: -131, |
| top: 25, |
| width: 15 |
| }, |
| Hawaii: { |
| left: -110, // 夏威夷 |
| top: 28, |
| width: 5 |
| }, |
| 'Puerto Rico': { // 波多黎各 |
| left: -76, |
| top: 26, |
| width: 2 |
| } |
| }); |
| |
| const tmpChart = echarts.init(document.createElement('div'), null, { |
| width: window.innerWidth, |
| height: window.innerHeight |
| }); |
| tmpChart.setOption({ |
| geo: { |
| map: 'USA' |
| } |
| }); |
| |
| const geo = tmpChart.getModel().getComponent('geo').coordinateSystem; |
| const regionsMap = geo.regions.reduce(function (obj, region) { |
| obj[region.properties.name] = region; |
| return obj; |
| }, {}); |
| |
| const transform = geo.transform; |
| |
| const data = [ |
| {name: 'Alabama', value: 4822023}, |
| {name: 'Alaska', value: 731449}, |
| {name: 'Arizona', value: 6553255}, |
| {name: 'Arkansas', value: 2949131}, |
| {name: 'California', value: 38041430}, |
| {name: 'Colorado', value: 5187582}, |
| {name: 'Connecticut', value: 3590347}, |
| {name: 'Delaware', value: 917092}, |
| {name: 'District of Columbia', value: 632323}, |
| {name: 'Florida', value: 19317568}, |
| {name: 'Georgia', value: 9919945}, |
| {name: 'Hawaii', value: 1392313}, |
| {name: 'Idaho', value: 1595728}, |
| {name: 'Illinois', value: 12875255}, |
| {name: 'Indiana', value: 6537334}, |
| {name: 'Iowa', value: 3074186}, |
| {name: 'Kansas', value: 2885905}, |
| {name: 'Kentucky', value: 4380415}, |
| {name: 'Louisiana', value: 4601893}, |
| {name: 'Maine', value: 1329192}, |
| {name: 'Maryland', value: 5884563}, |
| {name: 'Massachusetts', value: 6646144}, |
| {name: 'Michigan', value: 9883360}, |
| {name: 'Minnesota', value: 5379139}, |
| {name: 'Mississippi', value: 2984926}, |
| {name: 'Missouri', value: 6021988}, |
| {name: 'Montana', value: 1005141}, |
| {name: 'Nebraska', value: 1855525}, |
| {name: 'Nevada', value: 2758931}, |
| {name: 'New Hampshire', value: 1320718}, |
| {name: 'New Jersey', value: 8864590}, |
| {name: 'New Mexico', value: 2085538}, |
| {name: 'New York', value: 19570261}, |
| {name: 'North Carolina', value: 9752073}, |
| {name: 'North Dakota', value: 699628}, |
| {name: 'Ohio', value: 11544225}, |
| {name: 'Oklahoma', value: 3814820}, |
| {name: 'Oregon', value: 3899353}, |
| {name: 'Pennsylvania', value: 12763536}, |
| {name: 'Rhode Island', value: 1050292}, |
| {name: 'South Carolina', value: 4723723}, |
| {name: 'South Dakota', value: 833354}, |
| {name: 'Tennessee', value: 6456243}, |
| {name: 'Texas', value: 26059203}, |
| {name: 'Utah', value: 2855287}, |
| {name: 'Vermont', value: 626011}, |
| {name: 'Virginia', value: 8185867}, |
| {name: 'Washington', value: 6897012}, |
| {name: 'West Virginia', value: 1855413}, |
| {name: 'Wisconsin', value: 5726398}, |
| {name: 'Wyoming', value: 576412}, |
| {name: 'Puerto Rico', value: 3667084} |
| ]; |
| |
| const myChart = echarts.init(document.getElementById('main')); |
| |
| function createMapOption() { |
| return { |
| series: [{ |
| coordinateSystem: 'none', |
| type: 'custom', |
| data, |
| animationDurationUpdate: 2000, |
| universalTransition: { |
| enabled: true |
| }, |
| renderItem(params, api) { |
| const dataItem = data[params.dataIndex]; |
| const geometries = regionsMap[dataItem.name].geometries.slice(); |
| // Pick the main polygon |
| // TODO Multipolygon |
| geometries.sort((a, b) => b.exterior.length - a.exterior.length); |
| const points = geometries[0].exterior; |
| const newPoints = []; |
| for (let i = 0; i < points.length; i++) { |
| newPoints.push([ |
| points[i][0] * transform[0] + transform[4], |
| points[i][1] * transform[3] + transform[5] |
| ]); |
| } |
| return { |
| type: 'polygon', |
| shape: { |
| points: newPoints |
| }, |
| style: { |
| fill: '#aaa', |
| stroke: '#555', |
| strokeNoScale: true |
| } |
| } |
| } |
| }] |
| }; |
| } |
| |
| function renderBarItem(params, api) { |
| const dataItem = data[params.dataIndex]; |
| const start = api.coord([params.dataIndex, 0]); |
| const size = api.size([0, api.value(1)]); |
| const width = 20; |
| return { |
| type: 'rect', |
| shape: { |
| x: start[0] - width / 2, |
| y: start[1], |
| width: width, |
| height: -size[1] |
| }, |
| style: { |
| fill: '#aaa', |
| stroke: '#555', |
| strokeNoScale: true |
| }, |
| }; |
| } |
| |
| |
| function renderBubbleItem(params, api) { |
| const dataItem = data[params.dataIndex]; |
| const center = api.coord([params.dataIndex, api.value(1)]); |
| return { |
| type: 'circle', |
| shape: { |
| cx: center[0], |
| cy: center[1], |
| r: api.value(1) / 5e5 |
| }, |
| style: { |
| fill: '#aaa', |
| stroke: '#555', |
| strokeNoScale: true |
| }, |
| }; |
| } |
| |
| function createCartesianOption(renderItem) { |
| return { |
| xAxis: { |
| data: data.map(item => item.name) |
| }, |
| yAxis: { |
| }, |
| series: [{ |
| type: 'custom', |
| data, |
| animationDurationUpdate: 2000, |
| universalTransition: { |
| enabled: true |
| }, |
| renderItem |
| }] |
| }; |
| } |
| |
| function createPieOption(renderItem) { |
| const pieData = data.slice(); |
| pieData.reverse(); |
| const totalValue = pieData.reduce(function (val, item) { |
| return val + item.value; |
| }, 0); |
| let angles = []; |
| let currentAngle = -Math.PI / 2; |
| for (let i = 0; i < pieData.length; i++) { |
| const angle = pieData[i].value / totalValue * Math.PI * 2; |
| angles.push([currentAngle, angle + currentAngle]); |
| currentAngle += angle; |
| } |
| return { |
| series: [{ |
| type: 'custom', |
| coordinateSystem: 'none', |
| data: pieData, |
| animationDurationUpdate: 2000, |
| universalTransition: { |
| enabled: true |
| }, |
| renderItem(params, api) { |
| const width = myChart.getWidth(); |
| const height = myChart.getHeight(); |
| return { |
| type: 'sector', |
| shape: { |
| cx: width / 2, |
| cy: height / 2, |
| r: Math.min(width, height) / 3, |
| r0: Math.min(width, height) / 5, |
| startAngle: angles[params.dataIndex][0], |
| endAngle: angles[params.dataIndex][1], |
| clockwise: true |
| }, |
| style: { |
| fill: '#aaa', |
| stroke: '#555', |
| strokeNoScale: true |
| }, |
| }; |
| } |
| }] |
| }; |
| } |
| |
| const options = [ |
| createMapOption(), |
| createCartesianOption(renderBarItem), |
| createCartesianOption(renderBubbleItem), |
| createPieOption() |
| ]; |
| |
| let currentIndex = 0; |
| myChart.setOption(options[currentIndex]); |
| |
| function transitionToNext() { |
| const nextIndex = (currentIndex + 1) % options.length; |
| myChart.setOption(options[nextIndex], true); |
| currentIndex = nextIndex; |
| } |
| |
| document.querySelector('#next').onclick = function () { |
| transitionToNext(); |
| } |
| }); |
| |
| </script> |
| </body> |
| </html> |