|  |  | 
|  | <!-- | 
|  | 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"> | 
|  | <title>calendar</title> | 
|  | <meta name="viewport" content="width=device-width, initial-scale=1" /> | 
|  | <link rel="stylesheet" href="lib/reset.css"> | 
|  | <script src="lib/simpleRequire.js"></script> | 
|  | <script src="lib/config.js"></script> | 
|  | <script src="lib/jquery.min.js"></script> | 
|  | </head> | 
|  | <body> | 
|  | <style> | 
|  | html, body, #main { | 
|  | width: 100%; | 
|  | height: 100%; | 
|  | } | 
|  | </style> | 
|  | <div id="main"></div> | 
|  | <script> | 
|  |  | 
|  |  | 
|  | var getVirtulData =  function(year) { | 
|  |  | 
|  | year = year || '2017'; | 
|  |  | 
|  | var datas = []; | 
|  |  | 
|  | var arr31 = [1, 3, 5, 7, 8, 10, 12]; | 
|  | var arr30 = [4, 6, 9, 11]; | 
|  | for (var i = 1; i <= 31; i++) { | 
|  | for (var j = arr31.length - 1; j >= 0; j--) { | 
|  | datas.push([year + '-' + arr31[j] + '-' + i, Math.floor(Math.random() * 1000)]); | 
|  | } | 
|  | } | 
|  | for (var i = 1; i <= 30; i++) { | 
|  | for (var j = arr30.length - 1; j >= 0; j--) { | 
|  | datas.push([year + '-' + arr30[j] + '-' + i, Math.floor(Math.random() * 1000)]); | 
|  | } | 
|  | } | 
|  | for (var i = 1; i <= 29; i++) { | 
|  | datas.push([year + '-2-' + i, Math.floor(Math.random() * 1000)]); | 
|  | } | 
|  | return datas; | 
|  | } | 
|  | require(['echarts'], function (echarts) { | 
|  |  | 
|  | var chart = echarts.init(document.getElementById('main')); | 
|  |  | 
|  | chart.setOption({ | 
|  | tooltip: { | 
|  | position: 'top' | 
|  | }, | 
|  | visualMap: { | 
|  | min: 0, | 
|  | max: 1000, | 
|  | calculable: true, | 
|  | orient: 'horizontal', | 
|  | left: 'center', | 
|  | top: 'top' | 
|  | }, | 
|  |  | 
|  | calendar: [ | 
|  | { | 
|  | cellSize: ['auto', 20], | 
|  | right: 20, | 
|  | range: '2017' | 
|  | }, | 
|  | { | 
|  | top: 260, | 
|  | range: '2016' | 
|  | }, | 
|  | { | 
|  | orient: 'vertical', | 
|  | top: 500, | 
|  | range: '2015-03' | 
|  | }, | 
|  | { | 
|  | orient: 'vertical', | 
|  | top: 500, | 
|  | left: 400, | 
|  | range: '2015-04' | 
|  | }, | 
|  | { | 
|  | orient: 'vertical', | 
|  | top: 500, | 
|  | left: 800, | 
|  | range: '2015-05' | 
|  | }], | 
|  |  | 
|  | series: [{ | 
|  | type: 'heatmap', | 
|  | coordinateSystem: 'calendar', | 
|  | calendarIndex: 0, | 
|  | data: getVirtulData(2017) | 
|  | }, { | 
|  | type: 'heatmap', | 
|  | coordinateSystem: 'calendar', | 
|  | calendarIndex: 1, | 
|  | data: getVirtulData(2016) | 
|  | }, { | 
|  | type: 'heatmap', | 
|  | coordinateSystem: 'calendar', | 
|  | calendarIndex: 2, | 
|  | data: getVirtulData(2015) | 
|  | }, { | 
|  | type: 'heatmap', | 
|  | coordinateSystem: 'calendar', | 
|  | calendarIndex: 3, | 
|  | data: getVirtulData(2015) | 
|  | }, { | 
|  | type: 'heatmap', | 
|  | coordinateSystem: 'calendar', | 
|  | calendarIndex: 4, | 
|  | data: getVirtulData(2015) | 
|  | }] | 
|  |  | 
|  | }); | 
|  |  | 
|  |  | 
|  | $(window).resize(function() { | 
|  | chart.resize(); | 
|  | }); | 
|  | }); | 
|  | </script> | 
|  | </body> | 
|  | </html> |