|  | 
 | <!-- | 
 | 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> | 
 |     </head> | 
 |     <body> | 
 |         <style> | 
 |             #main { | 
 |                 position: relative; | 
 |                 text-align: center; | 
 |             } | 
 |             .title { | 
 |                 display: block; | 
 |                 cursor: pointer; | 
 |                 text-decoration: none; | 
 |                 clear: both; | 
 |                 text-align: center; | 
 |                 margin: 0; | 
 |                 background: #eef; | 
 |                 line-height: 22px; | 
 |             } | 
 |             .block { | 
 |                 display: inline-block; | 
 |                 *display: inline; | 
 |                 *zoom: 1; | 
 |                 vertical-align: top; | 
 |                 margin: 30px 0 30px 50px; | 
 |             } | 
 |             .block .ec { | 
 |                 width: 800px; | 
 |                 height: 240px; | 
 |             } | 
 |             .block .info { | 
 |                 display: block; | 
 |                 text-align: left; | 
 |                 background: #eee; | 
 |                 border-radius: 3px; | 
 |                 font-size: 12px; | 
 |                 line-height: 18px; | 
 |                 padding: 0 5px; | 
 |             } | 
 |             .block .info td { | 
 |                 font-size: 12px; | 
 |                 border: 1px solid #bbb; | 
 |                 padding: 1px 3px; | 
 |             } | 
 |             strong { | 
 |                 color: red; | 
 |                 font-weight: bold; | 
 |                 font-size: 18px; | 
 |                 padding: 0 3px; | 
 |             } | 
 |         </style> | 
 |         <div id="main"></div> | 
 |  | 
 |  | 
 |  | 
 |  | 
 |         <script> | 
 |  | 
 |             var echarts; | 
 |             var zrUtil; | 
 |             var charts = []; | 
 |             var els = []; | 
 |  | 
 |             require(['echarts'], function (ec) { | 
 |                 echarts = ec; | 
 |                 zrUtil = echarts.util; | 
 |  | 
 |  | 
 |                 renderTitle('Order sensitive in processing: no min/max on y (<strong>Try zooming y slider to check if normal</strong>)'); | 
 |                 makeChart(getOption( | 
 |                     makeSpecialTrendData(), | 
 |                     { | 
 |                         xAxisType: 'value', | 
 |                         xStart: 15, | 
 |                         xEnd: 80, | 
 |                         yScale: true, | 
 |                         symbolSize: 5 | 
 |                     } | 
 |                 ), 500); | 
 |  | 
 |  | 
 |                 renderTitle('Order sensitive in processing: min/max set on y (<strong>Try zooming y slider to check if normal</strong>)'); | 
 |                 makeChart(getOption( | 
 |                     makeSpecialTrendData(), | 
 |                     { | 
 |                         xAxisType: 'value', | 
 |                         xStart: 15, | 
 |                         xEnd: 80, | 
 |                         yScale: true, | 
 |                         symbolSize: 5, | 
 |                         yMin: 500, | 
 |                         yMax: 3000 | 
 |                     } | 
 |                 ), 500); | 
 |  | 
 |  | 
 |                 renderTitle('Order sensitive in processing: only max set on y and scale (<strong>Try zooming y slider to check if normal</strong>)'); | 
 |                 makeChart(getOption( | 
 |                     makeSpecialTrendData(), | 
 |                     { | 
 |                         xAxisType: 'value', | 
 |                         xStart: 15, | 
 |                         xEnd: 80, | 
 |                         yScale: true, | 
 |                         symbolSize: 5, | 
 |                         yMax: 3000 | 
 |                     } | 
 |                 ), 500); | 
 |  | 
 |  | 
 |                 renderTitle('Order sensitive in processing: only max set on y and no scale (<strong>Try zooming y slider to check if normal</strong>)'); | 
 |                 makeChart(getOption( | 
 |                     makeSpecialTrendData(), | 
 |                     { | 
 |                         xAxisType: 'value', | 
 |                         xStart: 15, | 
 |                         xEnd: 80, | 
 |                         yScale: false, | 
 |                         symbolSize: 5, | 
 |                         yMax: 3000 | 
 |                     } | 
 |                 ), 500); | 
 |             }); | 
 |  | 
 |  | 
 |  | 
 |             function makeSpecialTrendData() { | 
 |                 var data = {data1: []}; | 
 |                 var base = -100; | 
 |                 for (var i = 0; i < 50; i++) { | 
 |                     if (i < 10) { | 
 |                         data.data1.push([i * 10, base += 197 + random(3)]); | 
 |                     } | 
 |                     else if (i < 20) { | 
 |                         data.data1.push([i * 10, base -= 17 + random(3)]); | 
 |                     } | 
 |                     else if (i < 30) { | 
 |                         data.data1.push([i * 10, base += 3 + random(3)]); | 
 |                     } | 
 |                     else if (i < 40) { | 
 |                         data.data1.push([i * 10, base -= 5 + random(3)]); | 
 |                     } | 
 |                     else { | 
 |                         data.data1.push([i * 10, base += 157 + random(3)]); | 
 |                     } | 
 |                 } | 
 |                 return data; | 
 |             } | 
 |  | 
 |  | 
 |             function renderTitle(label) { | 
 |                 var containerEl = document.getElementById('main'); | 
 |                 var el = document.createElement('a'); | 
 |                 el.className = 'title'; | 
 |                 var html = label; // label is html | 
 |                 el.innerHTML = html; | 
 |                 el.href = '#' + html.replace(/\s/g, '_'); | 
 |                 el.name = html.replace(/\s/g, '_'); | 
 |                 containerEl.appendChild(el); | 
 |             } | 
 |  | 
 |             function makeChart(opt, height) { | 
 |                 var heightStyle = height ? ' style="height:' + height + 'px;" ' : ''; | 
 |  | 
 |                 var containerEl = document.getElementById('main'); | 
 |                 var el = document.createElement('div'); | 
 |                 el.className = 'block'; | 
 |                 el.innerHTML = '<div ' + heightStyle + ' class="ec"></div><div class="info"></div>'; | 
 |                 containerEl.appendChild(el); | 
 |  | 
 |                 var chart = echarts.init(el.firstChild, null, { }); | 
 |                 chart.setOption(opt); | 
 |  | 
 |                 charts.push(chart); | 
 |                 els.push(el); | 
 |  | 
 |                 chart.on('dataZoom', zrUtil.curry(renderProp, chart, el, false)); | 
 |                 renderProp(chart, el, true); | 
 |             } | 
 |  | 
 |             function renderProp(chart, el, isInit) { | 
 |                 var resultOpt = chart.getOption(); | 
 |                 var dataZoomOpt = zrUtil.map(resultOpt.dataZoom, function (rawOpt) { | 
 |                     return '' | 
 |                         + '<tr>' | 
 |                         + '<td>name:</td><td>' + encodeHTML(rawOpt.name) + '</td>' | 
 |                         + '<td>start:</td><td>' + encodeHTML(rawOpt.start) + '</td>' | 
 |                         + '<td>end:</td><td>' + encodeHTML(rawOpt.end) + '</td>' | 
 |                         + '<td>startValue:</td><td>' + encodeHTML(rawOpt.startValue) + '</td>' | 
 |                         + '<td>endValue:</td><td>' + encodeHTML(rawOpt.endValue) + '</td>' | 
 |                         + '</tr>'; | 
 |                 }); | 
 |  | 
 |                 el.lastChild.innerHTML = '' | 
 |                     + (isInit ? 'ON_INIT: ' : 'ON_EVENT: ') + '<br>' | 
 |                     + '<table><tbody>' + dataZoomOpt.join('') + '</tbody></table>'; | 
 |             } | 
 |  | 
 |             function encodeHTML(source) { | 
 |                 return source == null | 
 |                     ? '' | 
 |                     : String(source) | 
 |                         .replace(/&/g, '&') | 
 |                         .replace(/</g, '<') | 
 |                         .replace(/>/g, '>') | 
 |                         .replace(/"/g, '"') | 
 |                         .replace(/'/g, '''); | 
 |             } | 
 |  | 
 |             function random(max) { | 
 |                 return +(Math.random() * max).toFixed(3); | 
 |             }; | 
 |  | 
 |             function getOption(data, args) { | 
 |                 args = zrUtil.defaults( | 
 |                     args || {}, | 
 |                     { | 
 |                         symbol: null, | 
 |                         xStart: 1, | 
 |                         xEnd: 5, | 
 |                         yStart: 0, | 
 |                         yEnd: 100, | 
 |                         yFilterMode: 'empty', | 
 |                         symbolSize: 10 | 
 |                     } | 
 |                 ); | 
 |  | 
 |                 var option = { | 
 |                     animation: false, | 
 |                     legend: { | 
 |                         data: ['n1', 'n2'] | 
 |                     }, | 
 |                     toolbox: { | 
 |                         feature: { | 
 |                             dataView: {}, | 
 |                             dataZoom: {show: true}, | 
 |                             restore: {show: true}, | 
 |                             saveAsImage: {} | 
 |                         } | 
 |                     }, | 
 |                     tooltip: { | 
 |                         trigger: 'axis' | 
 |                     }, | 
 |                     xAxis: { | 
 |                         type: args.xAxisType, | 
 |                         splitLine: { | 
 |                             show: true | 
 |                         }, | 
 |                         data: args.xAxisData | 
 |                     }, | 
 |                     yAxis: { | 
 |                         scale: args.yScale, | 
 |                         type: 'value', | 
 |                         min: args.yMin, | 
 |                         max: args.yMax, | 
 |                         splitLine: { | 
 |                             show: true | 
 |                         } | 
 |                     }, | 
 |                     dataZoom: [ | 
 |                         { | 
 |                             id: 'xSlider', | 
 |                             name: 'xSlider', | 
 |                             show: true, | 
 |                             handleIcon: 'image://asset/echarts-logo.png', | 
 |                             filterMode: args.xFilterMode, | 
 |                             xAxisIndex: [0], | 
 |                             start: args.xStart, | 
 |                             end: args.xEnd | 
 |                         }, | 
 |                         { | 
 |                             name: 'ySlider', | 
 |                             show: true, | 
 |                             handleIcon: 'image://asset/echarts-logo.png', | 
 |                             filterMode: args.yFilterMode, | 
 |                             yAxisIndex: [0], | 
 |                             start: args.yStart, | 
 |                             end: args.yEnd | 
 |                         }, | 
 |                         { | 
 |                             name: 'xInside', | 
 |                             type: 'inside', | 
 |                             filterMode: args.xFilterMode, | 
 |                             xAxisIndex: [0], | 
 |                             start: args.xStart, | 
 |                             end: args.xEnd | 
 |                         }, | 
 |                         { | 
 |                             name: 'yInside', | 
 |                             type: 'inside', | 
 |                             filterMode: args.yFilterMode, | 
 |                             yAxisIndex: [0], | 
 |                             start: args.yStart, | 
 |                             end: args.yEnd | 
 |                         } | 
 |                     ], | 
 |                     series: [ | 
 |                         { | 
 |                             name: 'n1', | 
 |                             type: 'line', | 
 |                             symbolSize: args.symbolSize, | 
 |                             symbol: args.symbol, | 
 |                             data: data.data1 | 
 |                         }, | 
 |                         { | 
 |                             name: 'n2', | 
 |                             type: 'line', | 
 |                             symbol: args.symbol, | 
 |                             symbolSize: args.symbolSize, | 
 |                             data: data.data2 | 
 |                         } | 
 |                     ] | 
 |                 }; | 
 |  | 
 |                 if (!data.data2) { | 
 |                     option.series.splice(1, 1); | 
 |                 } | 
 |  | 
 |                 return option; | 
 |             } | 
 |  | 
 |  | 
 |         </script> | 
 |  | 
 |     </body> | 
 | </html> |