Server IP : 144.76.124.212 / Your IP : 216.73.216.29 Web Server : LiteSpeed System : Linux l4cp.vnetindia.com 4.18.0-553.40.1.lve.el8.x86_64 #1 SMP Wed Feb 12 18:54:57 UTC 2025 x86_64 User : rakcha ( 1356) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home5/rakcha/www/control/assets/plugins/echarts/ |
Upload File : |
var define, require, esl; ! function(e) { function t(e) { m(e, J) || (O[e] = 1) } function i(e, t) { function i(e) { 0 === e.indexOf(".") && a.push(e) } var a = []; if ("string" == typeof e ? i(e) : C(e, function(e) { i(e) }), a.length > 0) throw new Error("[REQUIRE_FATAL]Relative ID is not allowed in global require: " + a.join(", ")); var o = N.waitSeconds; return o && e instanceof Array && (E && clearTimeout(E), E = setTimeout(n, 1e3 * o)), D(e, t) } function n() { function e(r, s) { if (!o[r] && !m(r, J)) { o[r] = 1, m(r, F) || n[r] || (n[r] = 1, t.push(r)); var l = z[r]; l ? s && (n[r] || (n[r] = 1, t.push(r)), C(l.depMs, function(t) { e(t.absId, t.hard) })) : a[r] || (a[r] = 1, i.push(r)) } } var t = [], i = [], n = {}, a = {}, o = {}; for (var r in O) e(r, 1); if (t.length || i.length) throw new Error("[MODULE_TIMEOUT]Hang( " + (t.join(", ") || "none") + " ) Miss( " + (i.join(", ") || "none") + " )") } function a(e) { C(B, function(t) { s(e, t.deps, t.factory) }), B.length = 0 } function o(e, t, i) { if (null == i && (null == t ? (i = e, e = null) : (i = t, t = null, e instanceof Array && (t = e, e = null))), null != i) { var n = window.opera; if (!e && document.attachEvent && (!n || "[object Opera]" !== n.toString())) { var a = I(); e = a && a.getAttribute("data-require-id") } e ? s(e, t, i) : B[0] = { deps: t, factory: i } } } function r() { var e = N.config[this.id]; return e && "object" == typeof e ? e : {} } function s(e, t, i) { z[e] || (z[e] = { id: e, depsDec: t, deps: t || ["require", "exports", "module"], factoryDeps: [], factory: i, exports: {}, config: r, state: A, require: v(e), depMs: [], depMkv: {}, depRs: [] }) } function l(e) { var t = z[e]; if (t && !m(e, M)) { var i = t.deps, n = t.factory, a = 0; "function" == typeof n && (a = Math.min(n.length, i.length), !t.depsDec && n.toString().replace(/(\/\*([\s\S]*?)\*\/|([^:]|^)\/\/(.*)$)/gm, "").replace(/require\(\s*(['"'])([^'"]+)\1\s*\)/g, function(e, t, n) { i.push(n) })); var o = [], r = []; C(i, function(i, n) { var s, l, h = W(i), d = L(h.mod, e); d && !P[d] ? (h.res && (l = { id: i, mod: d, res: h.res }, r.push(i), t.depRs.push(l)), s = t.depMkv[d], s || (s = { id: h.mod, absId: d, hard: a > n }, t.depMs.push(s), t.depMkv[d] = s, o.push(d))) : s = { absId: d }, a > n && t.factoryDeps.push(l || s) }), t.state = M, c(e), g(o), r.length && t.require(r, function() { C(t.depRs, function(t) { t.absId || (t.absId = L(t.id, e)) }), h() }) } } function h() { for (var e in O) l(e), d(e), p(e) } function d(e) { function t(e) { if (l(e), !m(e, M)) return !1; if (m(e, F) || i[e]) return !0; i[e] = 1; var n = z[e], a = !0; return C(n.depMs, function(e) { return a = t(e.absId) }), a && C(n.depRs, function(e) { return a = !!e.absId }), a && (n.state = F), a } var i = {}; t(e) } function c(t) { function i() { if (!n && a.state === F) { n = 1; var i = 1; if (C(a.factoryDeps, function(e) { var t = e.absId; return P[t] ? void 0 : (p(t), i = m(t, J)) }), i) { try { var o = a.factory, r = "function" == typeof o ? o.apply(e, u(a.factoryDeps, { require: a.require, exports: a.exports, module: a })) : o; null != r && (a.exports = r), a.invokeFactory = null } catch (s) { if (/^\[MODULE_MISS\]"([^"]+)/.test(s.message)) { var l = a.depMkv[RegExp.$1]; return l && (l.hard = 1), void(n = 0) } throw s } U(t) } } } var n, a = z[t]; a.invokeFactory = i } function m(e, t) { return z[e] && z[e].state >= t } function p(e) { var t = z[e]; t && t.invokeFactory && t.invokeFactory() } function u(e, t) { var i = []; return C(e, function(e, n) { "object" == typeof e && (e = e.absId), i[n] = t[e] || z[e].exports }), i } function V(e, t) { if (m(e, J)) return void t(); var i = H[e]; i || (i = H[e] = []), i.push(t) } function U(e) { var t = z[e]; t.state = J, delete O[e]; for (var i = H[e] || [], n = i.length; n--;) i[n](); i.length = 0, H[e] = null } function g(t, i, n) { function a() { if ("function" == typeof i && !o) { var n = 1; C(t, function(e) { return P[e] ? void 0 : n = !!m(e, J) }), n && (o = 1, i.apply(e, u(t, P))) } } var o = 0; C(t, function(e) { P[e] || m(e, J) || (V(e, a), (e.indexOf("!") > 0 ? y : f)(e, n)) }), a() } function f(t) { function i() { var e = Q[t]; S(e || t, n) } function n() { if (r) { var i; "function" == typeof r.init && (i = r.init.apply(e, u(s, P))), null == i && r.exports && (i = e, C(r.exports.split("."), function(e) { return i = i[e], !!i })), o(t, s, i || {}) } else a(t); h() } if (!R[t] && !z[t]) { R[t] = 1; var r = N.shim[t]; r instanceof Array && (N.shim[t] = r = { deps: r }); var s = r && (r.deps || []); s ? (C(s, function(e) { N.shim[e] || (N.shim[e] = {}) }), D(s, i)) : i() } } function y(e, t) { function i(t) { l.exports = t || !0, U(e) } function n(n) { var a = t ? z[t].require : D; n.load(s.res, a, i, r.call({ id: e })) } if (!z[e]) { var o = Q[e]; if (o) return void f(o); var s = W(e), l = { id: e, state: M }; z[e] = l, i.fromText = function(e, t) { new Function(t)(), a(e) }, n(D(s.mod)) } } function b(e, t) { var i = X(e, 1, t); return i.sort(T), i } function _() { function e(e) { Q[e] = t } N.baseUrl = N.baseUrl.replace(/\/$/, "") + "/", G = b(N.paths), Z = b(N.map, 1), C(Z, function(e) { e.v = b(e.v) }), Y = [], C(N.packages, function(e) { var t = e; "string" == typeof e && (t = { name: e.split("/")[0], location: e, main: "main" }), t.location = t.location || t.name, t.main = (t.main || "main").replace(/\.js$/i, ""), t.reg = K(t.name), Y.push(t) }), Y.sort(T), q = b(N.urlArgs, 1), Q = {}; for (var t in N.bundles) C(N.bundles[t], e) } function x(e, t, i) { C(t, function(t) { return t.reg.test(e) ? (i(t.v, t.k, t), !1) : void 0 }) } function k(e) { var t = /(\.[a-z0-9]+)$/i, i = /(\?[^#]*)$/, n = "", a = e, o = ""; i.test(e) && (o = RegExp.$1, e = e.replace(i, "")), t.test(e) && (n = RegExp.$1, a = e.replace(t, "")); var r, s = a; return x(a, G, function(e, t) { s = s.replace(t, e), r = 1 }), r || x(a, Y, function(e, t, i) { s = s.replace(i.name, i.location) }), /^([a-z]{2,10}:\/)?\//i.test(s) || (s = N.baseUrl + s), s += n + o, x(a, q, function(e) { s += (s.indexOf("?") > 0 ? "&" : "?") + e }), s } function v(e) { function i(i, a) { if ("string" == typeof i) { if (!n[i]) { var o = L(i, e); if (p(o), !m(o, J)) throw new Error('[MODULE_MISS]"' + o + '" is not exists!'); n[i] = z[o].exports } return n[i] } if (i instanceof Array) { var r = [], s = []; C(i, function(i, n) { var a = W(i), o = L(a.mod, e), l = a.res, h = o; if (l) { var d = o + "!" + l; 0 !== l.indexOf(".") && Q[d] ? o = h = d : h = null } s[n] = h, t(o), r.push(o) }), g(r, function() { C(s, function(n, a) { null == n && (n = s[a] = L(i[a], e), t(n)) }), g(s, a, e), h() }, e), h() } } var n = {}; return i.toUrl = function(t) { return k(L(t, e)) }, i } function L(e, t) { if (!e) return ""; t = t || ""; var i = W(e); if (!i) return e; var n = i.res, a = w(i.mod, t); if (C(Y, function(e) { var t = e.name; return t === a ? (a = t + "/" + e.main, !1) : void 0 }), x(t, Z, function(e) { x(a, e, function(e, t) { a = a.replace(t, e) }) }), n) { var o = m(a, J) && D(a); n = o && o.normalize ? o.normalize(n, function(e) { return L(e, t) }) : L(n, t), a += "!" + n } return a } function w(e, t) { if (0 === e.indexOf(".")) { var i = t.split("/"), n = e.split("/"), a = i.length - 1, o = n.length, r = 0, s = 0; e: for (var l = 0; o > l; l++) switch (n[l]) { case "..": if (!(a > r)) break e; r++, s++; break; case ".": s++; break; default: break e } return i.length = a - r, n = n.slice(s), i.concat(n).join("/") } return e } function W(e) { var t = e.split("!"); return t[0] ? { mod: t[0], res: t[1] } : void 0 } function X(e, t, i) { var n = []; for (var a in e) if (e.hasOwnProperty(a)) { var o = { k: a, v: e[a] }; n.push(o), t && (o.reg = "*" === a && i ? /^/ : K(a)) } return n } function I() { if (j) return j; if ($ && "interactive" === $.readyState) return $; for (var e = document.getElementsByTagName("script"), t = e.length; t--;) { var i = e[t]; if ("interactive" === i.readyState) return $ = i, i } } function S(e, t) { function i() { var e = n.readyState; ("undefined" == typeof e || /^(loaded|complete)$/.test(e)) && (n.onload = n.onreadystatechange = null, n = null, t()) } var n = document.createElement("script"); n.setAttribute("data-require-id", e), n.src = k(e + ".js"), n.async = !0, n.readyState ? n.onreadystatechange = i : n.onload = i, j = n, te ? ee.insertBefore(n, te) : ee.appendChild(n), j = null } function K(e) { return new RegExp("^" + e + "(/|$)") } function C(e, t) { if (e instanceof Array) for (var i = 0, n = e.length; n > i && t(e[i], i) !== !1; i++); } function T(e, t) { var i = e.k || e.name, n = t.k || t.name; return "*" === n ? -1 : "*" === i ? 1 : n.length - i.length } var E, z = {}, A = 1, M = 2, F = 3, J = 4, O = {}, P = { require: i, exports: 1, module: 1 }, D = v(), N = { baseUrl: "./", paths: {}, config: {}, map: {}, packages: [], shim: {}, waitSeconds: 0, bundles: {}, urlArgs: {} }; i.version = "2.0.2", i.loader = "esl", i.toUrl = D.toUrl; var B = []; o.amd = {}; var H = {}, R = {}; i.config = function(e) { if (e) { for (var t in N) { var i = e[t], n = N[t]; if (i) if ("urlArgs" === t && "string" == typeof i) N.urlArgs["*"] = i; else if (n instanceof Array) n.push.apply(n, i); else if ("object" == typeof n) for (var a in i) n[a] = i[a]; else N[t] = i } _() } }, _(); var G, Y, Z, Q, q, j, $, ee = document.getElementsByTagName("head")[0], te = document.getElementsByTagName("base")[0]; te && (ee = te.parentNode), define || (define = o, require || (require = i), esl = i) }(this), define("echarts", ["echarts/echarts"], function(e) { return e }), define("echarts/echarts", ["require", "./config", "zrender/tool/util", "zrender/tool/event", "zrender/tool/env", "zrender", "zrender/config", "./chart/island", "./component/toolbox", "./component", "./component/title", "./component/tooltip", "./component/legend", "./util/ecData", "./chart", "zrender/tool/color", "./component/timeline", "zrender/shape/Image", "zrender/loadingEffect/Bar", "zrender/loadingEffect/Bubble", "zrender/loadingEffect/DynamicLine", "zrender/loadingEffect/Ring", "zrender/loadingEffect/Spin", "zrender/loadingEffect/Whirling", "./theme/macarons", "./theme/infographic"], function(e) { function t() { r.Dispatcher.call(this) } function i(e) { e.innerHTML = "", this._themeConfig = {}, this.dom = e, this._connected = !1, this._status = { dragIn: !1, dragOut: !1, needRefresh: !1 }, this._curEventType = !1, this._chartList = [], this._messageCenter = new t, this._messageCenterOutSide = new t, this.resize = this.resize(), this._init() } function n(e, t, i, n, a) { for (var o = e._chartList, r = o.length; r--;) { var s = o[r]; "function" == typeof s[t] && s[t](i, n, a) } } var a = e("./config"), o = e("zrender/tool/util"), r = e("zrender/tool/event"), s = {}, l = e("zrender/tool/env").canvasSupported, h = new Date - 0, d = {}, c = "_echarts_instance_"; s.version = "2.2.7", s.dependencies = { zrender: "2.1.1" }, s.init = function(t, n) { var a = e("zrender"); a.version.replace(".", "") - 0 < s.dependencies.zrender.replace(".", "") - 0 && console.error("ZRender " + a.version + " is too old for ECharts " + s.version + ". Current version need ZRender " + s.dependencies.zrender + "+"), t = t instanceof Array ? t[0] : t; var o = t.getAttribute(c); return o || (o = h++, t.setAttribute(c, o)), d[o] && d[o].dispose(), d[o] = new i(t), d[o].id = o, d[o].canvasSupported = l, d[o].setTheme(n), d[o] }, s.getInstanceById = function(e) { return d[e] }, o.merge(t.prototype, r.Dispatcher.prototype, !0); var m = e("zrender/config").EVENT, p = ["CLICK", "DBLCLICK", "MOUSEOVER", "MOUSEOUT", "DRAGSTART", "DRAGEND", "DRAGENTER", "DRAGOVER", "DRAGLEAVE", "DROP"]; return i.prototype = { _init: function() { var t = this, i = e("zrender").init(this.dom); this._zr = i, this._messageCenter.dispatch = function(e, i, n, a) { n = n || {}, n.type = e, n.event = i, t._messageCenter.dispatchWithContext(e, n, a), t._messageCenterOutSide.dispatchWithContext(e, n, a) }, this._onevent = function(e) { return t.__onevent(e) }; for (var n in a.EVENT) "CLICK" != n && "DBLCLICK" != n && "HOVER" != n && "MOUSEOUT" != n && "MAP_ROAM" != n && this._messageCenter.bind(a.EVENT[n], this._onevent, this); var o = {}; this._onzrevent = function(e) { return t[o[e.type]](e) }; for (var r = 0, s = p.length; s > r; r++) { var l = p[r], h = m[l]; o[h] = "_on" + l.toLowerCase(), i.on(h, this._onzrevent) } this.chart = {}, this.component = {}; var d = e("./chart/island"); this._island = new d(this._themeConfig, this._messageCenter, i, {}, this), this.chart.island = this._island; var c = e("./component/toolbox"); this._toolbox = new c(this._themeConfig, this._messageCenter, i, {}, this), this.component.toolbox = this._toolbox; var u = e("./component"); u.define("title", e("./component/title")), u.define("tooltip", e("./component/tooltip")), u.define("legend", e("./component/legend")), (0 === i.getWidth() || 0 === i.getHeight()) && console.error("Dom’s width & height should be ready before init.") }, __onevent: function(e) { e.__echartsId = e.__echartsId || this.id; var t = e.__echartsId === this.id; switch (this._curEventType || (this._curEventType = e.type), e.type) { case a.EVENT.LEGEND_SELECTED: this._onlegendSelected(e); break; case a.EVENT.DATA_ZOOM: if (!t) { var i = this.component.dataZoom; i && (i.silence(!0), i.absoluteZoom(e.zoom), i.silence(!1)) } this._ondataZoom(e); break; case a.EVENT.DATA_RANGE: t && this._ondataRange(e); break; case a.EVENT.MAGIC_TYPE_CHANGED: if (!t) { var n = this.component.toolbox; n && (n.silence(!0), n.setMagicType(e.magicType), n.silence(!1)) } this._onmagicTypeChanged(e); break; case a.EVENT.DATA_VIEW_CHANGED: t && this._ondataViewChanged(e); break; case a.EVENT.TOOLTIP_HOVER: t && this._tooltipHover(e); break; case a.EVENT.RESTORE: this._onrestore(); break; case a.EVENT.REFRESH: t && this._onrefresh(e); break; case a.EVENT.TOOLTIP_IN_GRID: case a.EVENT.TOOLTIP_OUT_GRID: if (t) { if (this._connected) { var o = this.component.grid; o && (e.x = (e.event.zrenderX - o.getX()) / o.getWidth(), e.y = (e.event.zrenderY - o.getY()) / o.getHeight()) } } else { var o = this.component.grid; o && this._zr.trigger("mousemove", { connectTrigger: !0, zrenderX: o.getX() + e.x * o.getWidth(), zrenderY: o.getY() + e.y * o.getHeight() }) } } if (this._connected && t && this._curEventType === e.type) { for (var r in this._connected) this._connected[r].connectedEventHandler(e); this._curEventType = null }(!t || !this._connected && t) && (this._curEventType = null) }, _onclick: function(e) { if (n(this, "onclick", e), e.target) { var t = this._eventPackage(e.target); t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.CLICK, e.event, t, this) } }, _ondblclick: function(e) { if (n(this, "ondblclick", e), e.target) { var t = this._eventPackage(e.target); t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.DBLCLICK, e.event, t, this) } }, _onmouseover: function(e) { if (e.target) { var t = this._eventPackage(e.target); t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.HOVER, e.event, t, this) } }, _onmouseout: function(e) { if (e.target) { var t = this._eventPackage(e.target); t && null != t.seriesIndex && this._messageCenter.dispatch(a.EVENT.MOUSEOUT, e.event, t, this) } }, _ondragstart: function(e) { this._status = { dragIn: !1, dragOut: !1, needRefresh: !1 }, n(this, "ondragstart", e) }, _ondragenter: function(e) { n(this, "ondragenter", e) }, _ondragover: function(e) { n(this, "ondragover", e) }, _ondragleave: function(e) { n(this, "ondragleave", e) }, _ondrop: function(e) { n(this, "ondrop", e, this._status), this._island.ondrop(e, this._status) }, _ondragend: function(e) { if (n(this, "ondragend", e, this._status), this._timeline && this._timeline.ondragend(e, this._status), this._island.ondragend(e, this._status), this._status.needRefresh) { this._syncBackupData(this._option); var t = this._messageCenter; t.dispatch(a.EVENT.DATA_CHANGED, e.event, this._eventPackage(e.target), this), t.dispatch(a.EVENT.REFRESH, null, null, this) } }, _onlegendSelected: function(e) { this._status.needRefresh = !1, n(this, "onlegendSelected", e, this._status), this._status.needRefresh && this._messageCenter.dispatch(a.EVENT.REFRESH, null, null, this) }, _ondataZoom: function(e) { this._status.needRefresh = !1, n(this, "ondataZoom", e, this._status), this._status.needRefresh && this._messageCenter.dispatch(a.EVENT.REFRESH, null, null, this) }, _ondataRange: function(e) { this._clearEffect(), this._status.needRefresh = !1, n(this, "ondataRange", e, this._status), this._status.needRefresh && this._zr.refreshNextFrame() }, _onmagicTypeChanged: function() { this._clearEffect(), this._render(this._toolbox.getMagicOption()) }, _ondataViewChanged: function(e) { this._syncBackupData(e.option), this._messageCenter.dispatch(a.EVENT.DATA_CHANGED, null, e, this), this._messageCenter.dispatch(a.EVENT.REFRESH, null, null, this) }, _tooltipHover: function(e) { var t = []; n(this, "ontooltipHover", e, t) }, _onrestore: function() { this.restore() }, _onrefresh: function(e) { this._refreshInside = !0, this.refresh(e), this._refreshInside = !1 }, _syncBackupData: function(e) { this.component.dataZoom && this.component.dataZoom.syncBackupData(e) }, _eventPackage: function(t) { if (t) { var i = e("./util/ecData"), n = i.get(t, "seriesIndex"), a = i.get(t, "dataIndex"); return a = -1 != n && this.component.dataZoom ? this.component.dataZoom.getRealDataIndex(n, a) : a, { seriesIndex: n, seriesName: (i.get(t, "series") || {}).name, dataIndex: a, data: i.get(t, "data"), name: i.get(t, "name"), value: i.get(t, "value"), special: i.get(t, "special") } } }, _noDataCheck: function(e) { for (var t = e.series, i = 0, n = t.length; n > i; i++) if (t[i].type == a.CHART_TYPE_MAP || t[i].data && t[i].data.length > 0 || t[i].markPoint && t[i].markPoint.data && t[i].markPoint.data.length > 0 || t[i].markLine && t[i].markLine.data && t[i].markLine.data.length > 0 || t[i].nodes && t[i].nodes.length > 0 || t[i].links && t[i].links.length > 0 || t[i].matrix && t[i].matrix.length > 0 || t[i].eventList && t[i].eventList.length > 0) return !1; var o = this._option && this._option.noDataLoadingOption || this._themeConfig.noDataLoadingOption || a.noDataLoadingOption || { text: this._option && this._option.noDataText || this._themeConfig.noDataText || a.noDataText, effect: this._option && this._option.noDataEffect || this._themeConfig.noDataEffect || a.noDataEffect }; return this.clear(), this.showLoading(o), !0 }, _render: function(t) { if (this._mergeGlobalConifg(t), !this._noDataCheck(t)) { var i = t.backgroundColor; if (i) if (l || -1 == i.indexOf("rgba")) this.dom.style.backgroundColor = i; else { var n = i.split(","); this.dom.style.filter = "alpha(opacity=" + 100 * n[3].substring(0, n[3].lastIndexOf(")")) + ")", n.length = 3, n[0] = n[0].replace("a", ""), this.dom.style.backgroundColor = n.join(",") + ")" } this._zr.clearAnimation(), this._chartList = []; var o = e("./chart"), r = e("./component"); (t.xAxis || t.yAxis) && (t.grid = t.grid || {}, t.dataZoom = t.dataZoom || {}); for (var s, h, d, c = ["title", "legend", "tooltip", "dataRange", "roamController", "grid", "dataZoom", "xAxis", "yAxis", "polar"], m = 0, p = c.length; p > m; m++) h = c[m], d = this.component[h], t[h] ? (d ? d.refresh && d.refresh(t) : (s = r.get(/^[xy]Axis$/.test(h) ? "axis" : h), d = new s(this._themeConfig, this._messageCenter, this._zr, t, this, h), this.component[h] = d), this._chartList.push(d)) : d && (d.dispose(), this.component[h] = null, delete this.component[h]); for (var u, V, U, g = {}, m = 0, p = t.series.length; p > m; m++) V = t.series[m].type, V ? g[V] || (g[V] = !0, u = o.get(V), u ? (this.chart[V] ? (U = this.chart[V], U.refresh(t)) : U = new u(this._themeConfig, this._messageCenter, this._zr, t, this), this._chartList.push(U), this.chart[V] = U) : console.error(V + " has not been required.")) : console.error("series[" + m + "] chart type has not been defined."); for (V in this.chart) V == a.CHART_TYPE_ISLAND || g[V] || (this.chart[V].dispose(), this.chart[V] = null, delete this.chart[V]); this.component.grid && this.component.grid.refixAxisShape(this.component), this._island.refresh(t), this._toolbox.refresh(t), t.animation && !t.renderAsImage ? this._zr.refresh() : this._zr.render(); var f = "IMG" + this.id, y = document.getElementById(f); t.renderAsImage && l ? (y ? y.src = this.getDataURL(t.renderAsImage) : (y = this.getImage(t.renderAsImage), y.id = f, y.style.position = "absolute", y.style.left = 0, y.style.top = 0, this.dom.firstChild.appendChild(y)), this.un(), this._zr.un(), this._disposeChartList(), this._zr.clear()) : y && y.parentNode.removeChild(y), y = null, this._option = t } }, restore: function() { this._clearEffect(), this._option = o.clone(this._optionRestore), this._disposeChartList(), this._island.clear(), this._toolbox.reset(this._option, !0), this._render(this._option) }, refresh: function(e) { this._clearEffect(), e = e || {}; var t = e.option; !this._refreshInside && t && (t = this.getOption(), o.merge(t, e.option, !0), o.merge(this._optionRestore, e.option, !0), this._toolbox.reset(t)), this._island.refresh(t), this._toolbox.refresh(t), this._zr.clearAnimation(); for (var i = 0, n = this._chartList.length; n > i; i++) this._chartList[i].refresh && this._chartList[i].refresh(t); this.component.grid && this.component.grid.refixAxisShape(this.component), this._zr.refresh() }, _disposeChartList: function() { this._clearEffect(), this._zr.clearAnimation(); for (var e = this._chartList.length; e--;) { var t = this._chartList[e]; if (t) { var i = t.type; this.chart[i] && delete this.chart[i], this.component[i] && delete this.component[i], t.dispose && t.dispose() } } this._chartList = [] }, _mergeGlobalConifg: function(t) { for (var i = ["backgroundColor", "calculable", "calculableColor", "calculableHolderColor", "nameConnector", "valueConnector", "animation", "animationThreshold", "animationDuration", "animationDurationUpdate", "animationEasing", "addDataAnimation", "symbolList", "DRAG_ENABLE_TIME"], n = i.length; n--;) { var o = i[n]; null == t[o] && (t[o] = null != this._themeConfig[o] ? this._themeConfig[o] : a[o]) } var r = t.color; r && r.length || (r = this._themeConfig.color || a.color), this._zr.getColor = function(t) { var i = e("zrender/tool/color"); return i.getColor(t, r) }, l || (t.animation = !1, t.addDataAnimation = !1) }, setOption: function(e, t) { return e.timeline ? this._setTimelineOption(e) : this._setOption(e, t) }, _setOption: function(e, t, i) { return !t && this._option ? this._option = o.merge(this.getOption(), o.clone(e), !0) : (this._option = o.clone(e), !i && this._timeline && this._timeline.dispose()), this._optionRestore = o.clone(this._option), this._option.series && 0 !== this._option.series.length ? (this.component.dataZoom && (this._option.dataZoom || this._option.toolbox && this._option.toolbox.feature && this._option.toolbox.feature.dataZoom && this._option.toolbox.feature.dataZoom.show) && this.component.dataZoom.syncOption(this._option), this._toolbox.reset(this._option), this._render(this._option), this) : void this._zr.clear() }, getOption: function() { function e(e) { var n = i._optionRestore[e]; if (n) if (n instanceof Array) for (var a = n.length; a--;) t[e][a].data = o.clone(n[a].data); else t[e].data = o.clone(n.data) } var t = o.clone(this._option), i = this; return e("xAxis"), e("yAxis"), e("series"), t }, setSeries: function(e, t) { return t ? (this._option.series = e, this.setOption(this._option, t)) : this.setOption({ series: e }), this }, getSeries: function() { return this.getOption().series }, _setTimelineOption: function(t) { this._timeline && this._timeline.dispose(); var i = e("./component/timeline"), n = new i(this._themeConfig, this._messageCenter, this._zr, t, this); return this._timeline = n, this.component.timeline = this._timeline, this }, addData: function(e, t, i, n, r) { function s() { if (c._zr) { c._zr.clearAnimation(); for (var e = 0, t = w.length; t > e; e++) w[e].motionlessOnce = h.addDataAnimation && w[e].addDataAnimation; c._messageCenter.dispatch(a.EVENT.REFRESH, null, { option: h }, c) } } for (var l = e instanceof Array ? e : [ [e, t, i, n, r] ], h = this.getOption(), d = this._optionRestore, c = this, m = 0, p = l.length; p > m; m++) { e = l[m][0], t = l[m][1], i = l[m][2], n = l[m][3], r = l[m][4]; var u = d.series[e], V = i ? "unshift" : "push", U = i ? "pop" : "shift"; if (u) { var g = u.data, f = h.series[e].data; if (g[V](t), f[V](t), n || (g[U](), t = f[U]()), null != r) { var y, b; if (u.type === a.CHART_TYPE_PIE && (y = d.legend) && (b = y.data)) { var _ = h.legend.data; if (b[V](r), _[V](r), !n) { var x = o.indexOf(b, t.name); - 1 != x && b.splice(x, 1), x = o.indexOf(_, t.name), -1 != x && _.splice(x, 1) } } else if (null != d.xAxis && null != d.yAxis) { var k, v, L = u.xAxisIndex || 0; (null == d.xAxis[L].type || "category" === d.xAxis[L].type) && (k = d.xAxis[L].data, v = h.xAxis[L].data, k[V](r), v[V](r), n || (k[U](), v[U]())), L = u.yAxisIndex || 0, "category" === d.yAxis[L].type && (k = d.yAxis[L].data, v = h.yAxis[L].data, k[V](r), v[V](r), n || (k[U](), v[U]())) } } this._option.series[e].data = h.series[e].data } } this._zr.clearAnimation(); for (var w = this._chartList, W = 0, X = function() { W--, 0 === W && s() }, m = 0, p = w.length; p > m; m++) h.addDataAnimation && w[m].addDataAnimation && (W++, w[m].addDataAnimation(l, X)); return this.component.dataZoom && this.component.dataZoom.syncOption(h), this._option = h, h.addDataAnimation || setTimeout(s, 0), this }, addMarkPoint: function(e, t) { return this._addMark(e, t, "markPoint") }, addMarkLine: function(e, t) { return this._addMark(e, t, "markLine") }, _addMark: function(e, t, i) { var n, a = this._option.series; if (a && (n = a[e])) { var r = this._optionRestore.series, s = r[e], l = n[i], h = s[i]; l = n[i] = l || { data: [] }, h = s[i] = h || { data: [] }; for (var d in t) "data" === d ? (l.data = l.data.concat(t.data), h.data = h.data.concat(t.data)) : "object" != typeof t[d] || null == l[d] ? l[d] = h[d] = t[d] : (o.merge(l[d], t[d], !0), o.merge(h[d], t[d], !0)); var c = this.chart[n.type]; c && c.addMark(e, t, i) } return this }, delMarkPoint: function(e, t) { return this._delMark(e, t, "markPoint") }, delMarkLine: function(e, t) { return this._delMark(e, t, "markLine") }, _delMark: function(e, t, i) { var n, a, o, r = this._option.series; if (!(r && (n = r[e]) && (a = n[i]) && (o = a.data))) return this; t = t.split(" > "); for (var s = -1, l = 0, h = o.length; h > l; l++) { var d = o[l]; if (d instanceof Array) { if (d[0].name === t[0] && d[1].name === t[1]) { s = l; break } } else if (d.name === t[0]) { s = l; break } } if (s > -1) { o.splice(s, 1), this._optionRestore.series[e][i].data.splice(s, 1); var c = this.chart[n.type]; c && c.delMark(e, t.join(" > "), i) } return this }, getDom: function() { return this.dom }, getZrender: function() { return this._zr }, getDataURL: function(e) { if (!l) return ""; if (0 === this._chartList.length) { var t = "IMG" + this.id, i = document.getElementById(t); if (i) return i.src } var n = this.component.tooltip; switch (n && n.hideTip(), e) { case "jpeg": break; default: e = "png" } var a = this._option.backgroundColor; return a && "rgba(0,0,0,0)" === a.replace(" ", "") && (a = "#fff"), this._zr.toDataURL("image/" + e, a) }, getImage: function(e) { var t = this._optionRestore.title, i = document.createElement("img"); return i.src = this.getDataURL(e), i.title = t && t.text || "ECharts", i }, getConnectedDataURL: function(t) { if (!this.isConnected()) return this.getDataURL(t); var i = this.dom, n = { self: { img: this.getDataURL(t), left: i.offsetLeft, top: i.offsetTop, right: i.offsetLeft + i.offsetWidth, bottom: i.offsetTop + i.offsetHeight } }, a = n.self.left, o = n.self.top, r = n.self.right, s = n.self.bottom; for (var l in this._connected) i = this._connected[l].getDom(), n[l] = { img: this._connected[l].getDataURL(t), left: i.offsetLeft, top: i.offsetTop, right: i.offsetLeft + i.offsetWidth, bottom: i.offsetTop + i.offsetHeight }, a = Math.min(a, n[l].left), o = Math.min(o, n[l].top), r = Math.max(r, n[l].right), s = Math.max(s, n[l].bottom); var h = document.createElement("div"); h.style.position = "absolute", h.style.left = "-4000px", h.style.width = r - a + "px", h.style.height = s - o + "px", document.body.appendChild(h); var d = e("zrender").init(h), c = e("zrender/shape/Image"); for (var l in n) d.addShape(new c({ style: { x: n[l].left - a, y: n[l].top - o, image: n[l].img } })); d.render(); var m = this._option.backgroundColor; m && "rgba(0,0,0,0)" === m.replace(/ /g, "") && (m = "#fff"); var p = d.toDataURL("image/png", m); return setTimeout(function() { d.dispose(), h.parentNode.removeChild(h), h = null }, 100), p }, getConnectedImage: function(e) { var t = this._optionRestore.title, i = document.createElement("img"); return i.src = this.getConnectedDataURL(e), i.title = t && t.text || "ECharts", i }, on: function(e, t) { return this._messageCenterOutSide.bind(e, t, this), this }, un: function(e, t) { return this._messageCenterOutSide.unbind(e, t), this }, connect: function(e) { if (!e) return this; if (this._connected || (this._connected = {}), e instanceof Array) for (var t = 0, i = e.length; i > t; t++) this._connected[e[t].id] = e[t]; else this._connected[e.id] = e; return this }, disConnect: function(e) { if (!e || !this._connected) return this; if (e instanceof Array) for (var t = 0, i = e.length; i > t; t++) delete this._connected[e[t].id]; else delete this._connected[e.id]; for (var n in this._connected) return this; return this._connected = !1, this }, connectedEventHandler: function(e) { e.__echartsId != this.id && this._onevent(e) }, isConnected: function() { return !!this._connected }, showLoading: function(t) { var i = { bar: e("zrender/loadingEffect/Bar"), bubble: e("zrender/loadingEffect/Bubble"), dynamicLine: e("zrender/loadingEffect/DynamicLine"), ring: e("zrender/loadingEffect/Ring"), spin: e("zrender/loadingEffect/Spin"), whirling: e("zrender/loadingEffect/Whirling") }; this._toolbox.hideDataView(), t = t || {}; var n = t.textStyle || {}; t.textStyle = n; var r = o.merge(o.merge(o.clone(n), this._themeConfig.textStyle), a.textStyle); n.textFont = r.fontStyle + " " + r.fontWeight + " " + r.fontSize + "px " + r.fontFamily, n.text = t.text || this._option && this._option.loadingText || this._themeConfig.loadingText || a.loadingText, null != t.x && (n.x = t.x), null != t.y && (n.y = t.y), t.effectOption = t.effectOption || {}, t.effectOption.textStyle = n; var s = t.effect; return ("string" == typeof s || null == s) && (s = i[t.effect || this._option && this._option.loadingEffect || this._themeConfig.loadingEffect || a.loadingEffect] || i.spin), this._zr.showLoading(new s(t.effectOption)), this }, hideLoading: function() { return this._zr.hideLoading(), this }, setTheme: function(t) { if (t) { if ("string" == typeof t) switch (t) { case "macarons": t = e("./theme/macarons"); break; case "infographic": t = e("./theme/infographic"); break; default: t = {} } else t = t || {}; this._themeConfig = t } if (!l) { var i = this._themeConfig.textStyle; i && i.fontFamily && i.fontFamily2 && (i.fontFamily = i.fontFamily2), i = a.textStyle, i.fontFamily = i.fontFamily2 } this._timeline && this._timeline.setTheme(!0), this._optionRestore && this.restore() }, resize: function() { var e = this; return function() { if (e._clearEffect(), e._zr.resize(), e._option && e._option.renderAsImage && l) return e._render(e._option), e; e._zr.clearAnimation(), e._island.resize(), e._toolbox.resize(), e._timeline && e._timeline.resize(); for (var t = 0, i = e._chartList.length; i > t; t++) e._chartList[t].resize && e._chartList[t].resize(); return e.component.grid && e.component.grid.refixAxisShape(e.component), e._zr.refresh(), e._messageCenter.dispatch(a.EVENT.RESIZE, null, null, e), e } }, _clearEffect: function() { this._zr.modLayer(a.EFFECT_ZLEVEL, { motionBlur: !1 }), this._zr.painter.clearLayer(a.EFFECT_ZLEVEL) }, clear: function() { return this._disposeChartList(), this._zr.clear(), this._option = {}, this._optionRestore = {}, this.dom.style.backgroundColor = null, this }, dispose: function() { var e = this.dom.getAttribute(c); e && delete d[e], this._island.dispose(), this._toolbox.dispose(), this._timeline && this._timeline.dispose(), this._messageCenter.unbind(), this.clear(), this._zr.dispose(), this._zr = null } }, s }), define("echarts/config", [], function() { var e = { CHART_TYPE_LINE: "line", CHART_TYPE_BAR: "bar", CHART_TYPE_SCATTER: "scatter", CHART_TYPE_PIE: "pie", CHART_TYPE_RADAR: "radar", CHART_TYPE_VENN: "venn", CHART_TYPE_TREEMAP: "treemap", CHART_TYPE_TREE: "tree", CHART_TYPE_MAP: "map", CHART_TYPE_K: "k", CHART_TYPE_ISLAND: "island", CHART_TYPE_FORCE: "force", CHART_TYPE_CHORD: "chord", CHART_TYPE_GAUGE: "gauge", CHART_TYPE_FUNNEL: "funnel", CHART_TYPE_EVENTRIVER: "eventRiver", CHART_TYPE_WORDCLOUD: "wordCloud", CHART_TYPE_HEATMAP: "heatmap", COMPONENT_TYPE_TITLE: "title", COMPONENT_TYPE_LEGEND: "legend", COMPONENT_TYPE_DATARANGE: "dataRange", COMPONENT_TYPE_DATAVIEW: "dataView", COMPONENT_TYPE_DATAZOOM: "dataZoom", COMPONENT_TYPE_TOOLBOX: "toolbox", COMPONENT_TYPE_TOOLTIP: "tooltip", COMPONENT_TYPE_GRID: "grid", COMPONENT_TYPE_AXIS: "axis", COMPONENT_TYPE_POLAR: "polar", COMPONENT_TYPE_X_AXIS: "xAxis", COMPONENT_TYPE_Y_AXIS: "yAxis", COMPONENT_TYPE_AXIS_CATEGORY: "categoryAxis", COMPONENT_TYPE_AXIS_VALUE: "valueAxis", COMPONENT_TYPE_TIMELINE: "timeline", COMPONENT_TYPE_ROAMCONTROLLER: "roamController", backgroundColor: "rgba(0,0,0,0)", color: ["#ff7f50", "#87cefa", "#da70d6", "#32cd32", "#6495ed", "#ff69b4", "#ba55d3", "#cd5c5c", "#ffa500", "#40e0d0", "#1e90ff", "#ff6347", "#7b68ee", "#00fa9a", "#ffd700", "#6699FF", "#ff6666", "#3cb371", "#b8860b", "#30e0e0"], markPoint: { clickable: !0, symbol: "pin", symbolSize: 10, large: !1, effect: { show: !1, loop: !0, period: 15, type: "scale", scaleSize: 2, bounceDistance: 10 }, itemStyle: { normal: { borderWidth: 2, label: { show: !0, position: "inside" } }, emphasis: { label: { show: !0 } } } }, markLine: { clickable: !0, symbol: ["circle", "arrow"], symbolSize: [2, 4], smoothness: .2, precision: 2, effect: { show: !1, loop: !0, period: 15, scaleSize: 2 }, bundling: { enable: !1, maxTurningAngle: 45 }, itemStyle: { normal: { borderWidth: 1.5, label: { show: !0, position: "end" }, lineStyle: { type: "dashed" } }, emphasis: { label: { show: !1 }, lineStyle: {} } } }, textStyle: { decoration: "none", fontFamily: "Arial, Verdana, sans-serif", fontFamily2: "微软雅黑", fontSize: 12, fontStyle: "normal", fontWeight: "normal" }, EVENT: { REFRESH: "refresh", RESTORE: "restore", RESIZE: "resize", CLICK: "click", DBLCLICK: "dblclick", HOVER: "hover", MOUSEOUT: "mouseout", DATA_CHANGED: "dataChanged", DATA_ZOOM: "dataZoom", DATA_RANGE: "dataRange", DATA_RANGE_SELECTED: "dataRangeSelected", DATA_RANGE_HOVERLINK: "dataRangeHoverLink", LEGEND_SELECTED: "legendSelected", LEGEND_HOVERLINK: "legendHoverLink", MAP_SELECTED: "mapSelected", PIE_SELECTED: "pieSelected", MAGIC_TYPE_CHANGED: "magicTypeChanged", DATA_VIEW_CHANGED: "dataViewChanged", TIMELINE_CHANGED: "timelineChanged", MAP_ROAM: "mapRoam", FORCE_LAYOUT_END: "forceLayoutEnd", TOOLTIP_HOVER: "tooltipHover", TOOLTIP_IN_GRID: "tooltipInGrid", TOOLTIP_OUT_GRID: "tooltipOutGrid", ROAMCONTROLLER: "roamController" }, DRAG_ENABLE_TIME: 120, EFFECT_ZLEVEL: 10, effectBlendAlpha: .95, symbolList: ["circle", "rectangle", "triangle", "diamond", "emptyCircle", "emptyRectangle", "emptyTriangle", "emptyDiamond"], loadingEffect: "spin", loadingText: "数据读取中...", noDataEffect: "bubble", noDataText: "暂无数据", calculable: !1, calculableColor: "rgba(255,165,0,0.6)", calculableHolderColor: "#ccc", nameConnector: " & ", valueConnector: ": ", animation: !0, addDataAnimation: !0, animationThreshold: 2e3, animationDuration: 2e3, animationDurationUpdate: 500, animationEasing: "ExponentialOut" }; return e }), define("zrender/tool/util", ["require", "../dep/excanvas"], function(e) { function t(e) { return e && 1 === e.nodeType && "string" == typeof e.nodeName } function i(e) { if ("object" == typeof e && null !== e) { var n = e; if (e instanceof Array) { n = []; for (var a = 0, o = e.length; o > a; a++) n[a] = i(e[a]) } else if (!g[f.call(e)] && !t(e)) { n = {}; for (var r in e) e.hasOwnProperty(r) && (n[r] = i(e[r])) } return n } return e } function n(e, i, n, o) { if (i.hasOwnProperty(n)) { var r = e[n]; "object" != typeof r || g[f.call(r)] || t(r) ? !o && n in e || (e[n] = i[n]) : a(e[n], i[n], o) } } function a(e, t, i) { for (var a in t) n(e, t, a, i); return e } function o() { if (!m) if (e("../dep/excanvas"), window.G_vmlCanvasManager) { var t = document.createElement("div"); t.style.position = "absolute", t.style.top = "-1000px", document.body.appendChild(t), m = G_vmlCanvasManager.initElement(t).getContext("2d"); } else m = document.createElement("canvas").getContext("2d"); return m } function r(e, t) { if (e.indexOf) return e.indexOf(t); for (var i = 0, n = e.length; n > i; i++) if (e[i] === t) return i; return -1 } function s(e, t) { function i() {} var n = e.prototype; i.prototype = t.prototype, e.prototype = new i; for (var a in n) e.prototype[a] = n[a]; e.constructor = e } function l(e, t, i) { if (e && t) if (e.forEach && e.forEach === u) e.forEach(t, i); else if (e.length === +e.length) for (var n = 0, a = e.length; a > n; n++) t.call(i, e[n], n, e); else for (var o in e) e.hasOwnProperty(o) && t.call(i, e[o], o, e) } function h(e, t, i) { if (e && t) { if (e.map && e.map === V) return e.map(t, i); for (var n = [], a = 0, o = e.length; o > a; a++) n.push(t.call(i, e[a], a, e)); return n } } function d(e, t, i) { if (e && t) { if (e.filter && e.filter === U) return e.filter(t, i); for (var n = [], a = 0, o = e.length; o > a; a++) t.call(i, e[a], a, e) && n.push(e[a]); return n } } function c(e, t) { return function() { e.apply(t, arguments) } } var m, p = Array.prototype, u = p.forEach, V = p.map, U = p.filter, g = { "[object Function]": 1, "[object RegExp]": 1, "[object Date]": 1, "[object Error]": 1, "[object CanvasGradient]": 1 }, f = Object.prototype.toString; return { inherits: s, clone: i, merge: a, getContext: o, indexOf: r, each: l, map: h, filter: d, bind: c } }), define("zrender/tool/event", ["require", "../mixin/Eventful"], function(e) { "use strict"; function t(e) { return "undefined" != typeof e.zrenderX && e.zrenderX || "undefined" != typeof e.offsetX && e.offsetX || "undefined" != typeof e.layerX && e.layerX || "undefined" != typeof e.clientX && e.clientX } function i(e) { return "undefined" != typeof e.zrenderY && e.zrenderY || "undefined" != typeof e.offsetY && e.offsetY || "undefined" != typeof e.layerY && e.layerY || "undefined" != typeof e.clientY && e.clientY } function n(e) { return "undefined" != typeof e.zrenderDelta && e.zrenderDelta || "undefined" != typeof e.wheelDelta && e.wheelDelta || "undefined" != typeof e.detail && -e.detail } var a = e("../mixin/Eventful"), o = "function" == typeof window.addEventListener ? function(e) { e.preventDefault(), e.stopPropagation(), e.cancelBubble = !0 } : function(e) { e.returnValue = !1, e.cancelBubble = !0 }; return { getX: t, getY: i, getDelta: n, stop: o, Dispatcher: a } }), define("zrender/tool/env", [], function() { function e(e) { var t = this.os = {}, i = this.browser = {}, n = e.match(/Web[kK]it[\/]{0,1}([\d.]+)/), a = e.match(/(Android);?[\s\/]+([\d.]+)?/), o = e.match(/(iPad).*OS\s([\d_]+)/), r = e.match(/(iPod)(.*OS\s([\d_]+))?/), s = !o && e.match(/(iPhone\sOS)\s([\d_]+)/), l = e.match(/(webOS|hpwOS)[\s\/]([\d.]+)/), h = l && e.match(/TouchPad/), d = e.match(/Kindle\/([\d.]+)/), c = e.match(/Silk\/([\d._]+)/), m = e.match(/(BlackBerry).*Version\/([\d.]+)/), p = e.match(/(BB10).*Version\/([\d.]+)/), u = e.match(/(RIM\sTablet\sOS)\s([\d.]+)/), V = e.match(/PlayBook/), U = e.match(/Chrome\/([\d.]+)/) || e.match(/CriOS\/([\d.]+)/), g = e.match(/Firefox\/([\d.]+)/), f = e.match(/MSIE ([\d.]+)/), y = n && e.match(/Mobile\//) && !U, b = e.match(/(iPhone|iPod|iPad).*AppleWebKit(?!.*Safari)/) && !U, f = e.match(/MSIE\s([\d.]+)/); return (i.webkit = !!n) && (i.version = n[1]), a && (t.android = !0, t.version = a[2]), s && !r && (t.ios = t.iphone = !0, t.version = s[2].replace(/_/g, ".")), o && (t.ios = t.ipad = !0, t.version = o[2].replace(/_/g, ".")), r && (t.ios = t.ipod = !0, t.version = r[3] ? r[3].replace(/_/g, ".") : null), l && (t.webos = !0, t.version = l[2]), h && (t.touchpad = !0), m && (t.blackberry = !0, t.version = m[2]), p && (t.bb10 = !0, t.version = p[2]), u && (t.rimtabletos = !0, t.version = u[2]), V && (i.playbook = !0), d && (t.kindle = !0, t.version = d[1]), c && (i.silk = !0, i.version = c[1]), !c && t.android && e.match(/Kindle Fire/) && (i.silk = !0), U && (i.chrome = !0, i.version = U[1]), g && (i.firefox = !0, i.version = g[1]), f && (i.ie = !0, i.version = f[1]), y && (e.match(/Safari/) || t.ios) && (i.safari = !0), b && (i.webview = !0), f && (i.ie = !0, i.version = f[1]), t.tablet = !!(o || V || a && !e.match(/Mobile/) || g && e.match(/Tablet/) || f && !e.match(/Phone/) && e.match(/Touch/)), t.phone = !(t.tablet || t.ipod || !(a || s || l || m || p || U && e.match(/Android/) || U && e.match(/CriOS\/([\d.]+)/) || g && e.match(/Mobile/) || f && e.match(/Touch/))), { browser: i, os: t, canvasSupported: document.createElement("canvas").getContext ? !0 : !1 } } return e(navigator.userAgent) }), define("zrender", ["zrender/zrender"], function(e) { return e }), define("zrender/zrender", ["require", "./dep/excanvas", "./tool/util", "./tool/log", "./tool/guid", "./Handler", "./Painter", "./Storage", "./animation/Animation", "./tool/env"], function(e) { function t(e) { return function() { e._needsRefreshNextFrame && e.refresh() } } e("./dep/excanvas"); var i = e("./tool/util"), n = e("./tool/log"), a = e("./tool/guid"), o = e("./Handler"), r = e("./Painter"), s = e("./Storage"), l = e("./animation/Animation"), h = {}, d = {}; d.version = "2.1.1", d.init = function(e) { var t = new c(a(), e); return h[t.id] = t, t }, d.dispose = function(e) { if (e) e.dispose(); else { for (var t in h) h[t].dispose(); h = {} } return d }, d.getInstance = function(e) { return h[e] }, d.delInstance = function(e) { return delete h[e], d }; var c = function(i, n) { this.id = i, this.env = e("./tool/env"), this.storage = new s, this.painter = new r(n, this.storage), this.handler = new o(n, this.storage, this.painter), this.animation = new l({ stage: { update: t(this) } }), this.animation.start(); var a = this; this.painter.refreshNextFrame = function() { a.refreshNextFrame() }, this._needsRefreshNextFrame = !1; var a = this, h = this.storage, d = h.delFromMap; h.delFromMap = function(e) { var t = h.get(e); a.stopAnimation(t), d.call(h, e) } }; return c.prototype.getId = function() { return this.id }, c.prototype.addShape = function(e) { return this.addElement(e), this }, c.prototype.addGroup = function(e) { return this.addElement(e), this }, c.prototype.delShape = function(e) { return this.delElement(e), this }, c.prototype.delGroup = function(e) { return this.delElement(e), this }, c.prototype.modShape = function(e, t) { return this.modElement(e, t), this }, c.prototype.modGroup = function(e, t) { return this.modElement(e, t), this }, c.prototype.addElement = function(e) { return this.storage.addRoot(e), this._needsRefreshNextFrame = !0, this }, c.prototype.delElement = function(e) { return this.storage.delRoot(e), this._needsRefreshNextFrame = !0, this }, c.prototype.modElement = function(e, t) { return this.storage.mod(e, t), this._needsRefreshNextFrame = !0, this }, c.prototype.modLayer = function(e, t) { return this.painter.modLayer(e, t), this._needsRefreshNextFrame = !0, this }, c.prototype.addHoverShape = function(e) { return this.storage.addHover(e), this }, c.prototype.render = function(e) { return this.painter.render(e), this._needsRefreshNextFrame = !1, this }, c.prototype.refresh = function(e) { return this.painter.refresh(e), this._needsRefreshNextFrame = !1, this }, c.prototype.refreshNextFrame = function() { return this._needsRefreshNextFrame = !0, this }, c.prototype.refreshHover = function(e) { return this.painter.refreshHover(e), this }, c.prototype.refreshShapes = function(e, t) { return this.painter.refreshShapes(e, t), this }, c.prototype.resize = function() { return this.painter.resize(), this }, c.prototype.animate = function(e, t, a) { var o = this; if ("string" == typeof e && (e = this.storage.get(e)), e) { var r; if (t) { for (var s = t.split("."), l = e, h = 0, d = s.length; d > h; h++) l && (l = l[s[h]]); l && (r = l) } else r = e; if (!r) return void n('Property "' + t + '" is not existed in element ' + e.id); null == e.__animators && (e.__animators = []); var c = e.__animators, m = this.animation.animate(r, { loop: a }).during(function() { o.modShape(e) }).done(function() { var t = i.indexOf(e.__animators, m); t >= 0 && c.splice(t, 1) }); return c.push(m), m } n("Element not existed") }, c.prototype.stopAnimation = function(e) { if (e.__animators) { for (var t = e.__animators, i = t.length, n = 0; i > n; n++) t[n].stop(); t.length = 0 } return this }, c.prototype.clearAnimation = function() { return this.animation.clear(), this }, c.prototype.showLoading = function(e) { return this.painter.showLoading(e), this }, c.prototype.hideLoading = function() { return this.painter.hideLoading(), this }, c.prototype.getWidth = function() { return this.painter.getWidth() }, c.prototype.getHeight = function() { return this.painter.getHeight() }, c.prototype.toDataURL = function(e, t, i) { return this.painter.toDataURL(e, t, i) }, c.prototype.shapeToImage = function(e, t, i) { var n = a(); return this.painter.shapeToImage(n, e, t, i) }, c.prototype.on = function(e, t, i) { return this.handler.on(e, t, i), this }, c.prototype.un = function(e, t) { return this.handler.un(e, t), this }, c.prototype.trigger = function(e, t) { return this.handler.trigger(e, t), this }, c.prototype.clear = function() { return this.storage.delRoot(), this.painter.clear(), this }, c.prototype.dispose = function() { this.animation.stop(), this.clear(), this.storage.dispose(), this.painter.dispose(), this.handler.dispose(), this.animation = this.storage = this.painter = this.handler = null, d.delInstance(this.id) }, d }), define("zrender/config", [], function() { var e = { EVENT: { RESIZE: "resize", CLICK: "click", DBLCLICK: "dblclick", MOUSEWHEEL: "mousewheel", MOUSEMOVE: "mousemove", MOUSEOVER: "mouseover", MOUSEOUT: "mouseout", MOUSEDOWN: "mousedown", MOUSEUP: "mouseup", GLOBALOUT: "globalout", DRAGSTART: "dragstart", DRAGEND: "dragend", DRAGENTER: "dragenter", DRAGOVER: "dragover", DRAGLEAVE: "dragleave", DROP: "drop", touchClickDelay: 300 }, elementClassName: "zr-element", catchBrushException: !1, debugMode: 0, devicePixelRatio: Math.max(window.devicePixelRatio || 1, 1) }; return e }), define("echarts/chart/island", ["require", "./base", "zrender/shape/Circle", "../config", "../util/ecData", "zrender/tool/util", "zrender/tool/event", "zrender/tool/color", "../util/accMath", "../chart"], function(e) { function t(e, t, n, a, r) { i.call(this, e, t, n, a, r), this._nameConnector, this._valueConnector, this._zrHeight = this.zr.getHeight(), this._zrWidth = this.zr.getWidth(); var l = this; l.shapeHandler.onmousewheel = function(e) { var t = e.target, i = e.event, n = s.getDelta(i); n = n > 0 ? -1 : 1, t.style.r -= n, t.style.r = t.style.r < 5 ? 5 : t.style.r; var a = o.get(t, "value"), r = a * l.option.island.calculateStep; a = r > 1 ? Math.round(a - r * n) : +(a - r * n).toFixed(2); var h = o.get(t, "name"); t.style.text = h + ":" + a, o.set(t, "value", a), o.set(t, "name", h), l.zr.modShape(t.id), l.zr.refreshNextFrame(), s.stop(i) } } var i = e("./base"), n = e("zrender/shape/Circle"), a = e("../config"); a.island = { zlevel: 0, z: 5, r: 15, calculateStep: .1 }; var o = e("../util/ecData"), r = e("zrender/tool/util"), s = e("zrender/tool/event"); return t.prototype = { type: a.CHART_TYPE_ISLAND, _combine: function(t, i) { var n = e("zrender/tool/color"), a = e("../util/accMath"), r = a.accAdd(o.get(t, "value"), o.get(i, "value")), s = o.get(t, "name") + this._nameConnector + o.get(i, "name"); t.style.text = s + this._valueConnector + r, o.set(t, "value", r), o.set(t, "name", s), t.style.r = this.option.island.r, t.style.color = n.mix(t.style.color, i.style.color) }, refresh: function(e) { e && (e.island = this.reformOption(e.island), this.option = e, this._nameConnector = this.option.nameConnector, this._valueConnector = this.option.valueConnector) }, getOption: function() { return this.option }, resize: function() { var e = this.zr.getWidth(), t = this.zr.getHeight(), i = e / (this._zrWidth || e), n = t / (this._zrHeight || t); if (1 !== i || 1 !== n) { this._zrWidth = e, this._zrHeight = t; for (var a = 0, o = this.shapeList.length; o > a; a++) this.zr.modShape(this.shapeList[a].id, { style: { x: Math.round(this.shapeList[a].style.x * i), y: Math.round(this.shapeList[a].style.y * n) } }) } }, add: function(e) { var t = o.get(e, "name"), i = o.get(e, "value"), a = null != o.get(e, "series") ? o.get(e, "series").name : "", r = this.getFont(this.option.island.textStyle), s = this.option.island, l = { zlevel: s.zlevel, z: s.z, style: { x: e.style.x, y: e.style.y, r: this.option.island.r, color: e.style.color || e.style.strokeColor, text: t + this._valueConnector + i, textFont: r }, draggable: !0, hoverable: !0, onmousewheel: this.shapeHandler.onmousewheel, _type: "island" }; "#fff" === l.style.color && (l.style.color = e.style.strokeColor), this.setCalculable(l), l.dragEnableTime = 0, o.pack(l, { name: a }, -1, i, -1, t), l = new n(l), this.shapeList.push(l), this.zr.addShape(l) }, del: function(e) { this.zr.delShape(e.id); for (var t = [], i = 0, n = this.shapeList.length; n > i; i++) this.shapeList[i].id != e.id && t.push(this.shapeList[i]); this.shapeList = t }, ondrop: function(e, t) { if (this.isDrop && e.target) { var i = e.target, n = e.dragged; this._combine(i, n), this.zr.modShape(i.id), t.dragIn = !0, this.isDrop = !1 } }, ondragend: function(e, t) { var i = e.target; this.isDragend ? t.dragIn && (this.del(i), t.needRefresh = !0) : t.dragIn || (i.style.x = s.getX(e.event), i.style.y = s.getY(e.event), this.add(i), t.needRefresh = !0), this.isDragend = !1 } }, r.inherits(t, i), e("../chart").define("island", t), t }), define("echarts/component/toolbox", ["require", "./base", "zrender/shape/Line", "zrender/shape/Image", "zrender/shape/Rectangle", "../util/shape/Icon", "../config", "zrender/tool/util", "zrender/config", "zrender/tool/event", "./dataView", "../component"], function(e) { function t(e, t, n, a, o) { i.call(this, e, t, n, a, o), this.dom = o.dom, this._magicType = {}, this._magicMap = {}, this._isSilence = !1, this._iconList, this._iconShapeMap = {}, this._featureTitle = {}, this._featureIcon = {}, this._featureColor = {}, this._featureOption = {}, this._enableColor = "red", this._disableColor = "#ccc", this._markShapeList = []; var r = this; r._onMark = function(e) { r.__onMark(e) }, r._onMarkUndo = function(e) { r.__onMarkUndo(e) }, r._onMarkClear = function(e) { r.__onMarkClear(e) }, r._onDataZoom = function(e) { r.__onDataZoom(e) }, r._onDataZoomReset = function(e) { r.__onDataZoomReset(e) }, r._onDataView = function(e) { r.__onDataView(e) }, r._onRestore = function(e) { r.__onRestore(e) }, r._onSaveAsImage = function(e) { r.__onSaveAsImage(e) }, r._onMagicType = function(e) { r.__onMagicType(e) }, r._onCustomHandler = function(e) { r.__onCustomHandler(e) }, r._onmousemove = function(e) { return r.__onmousemove(e) }, r._onmousedown = function(e) { return r.__onmousedown(e) }, r._onmouseup = function(e) { return r.__onmouseup(e) }, r._onclick = function(e) { return r.__onclick(e) } } var i = e("./base"), n = e("zrender/shape/Line"), a = e("zrender/shape/Image"), o = e("zrender/shape/Rectangle"), r = e("../util/shape/Icon"), s = e("../config"); s.toolbox = { zlevel: 0, z: 6, show: !1, orient: "horizontal", x: "right", y: "top", color: ["#1e90ff", "#22bb22", "#4b0082", "#d2691e"], disableColor: "#ddd", effectiveColor: "red", backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, padding: 5, itemGap: 10, itemSize: 16, showTitle: !0, feature: { mark: { show: !1, title: { mark: "Place Marker", markUndo: "Undo Marker", markClear: "Clear Marker" }, lineStyle: { width: 1, color: "#1e90ff", type: "dashed" } }, dataZoom: { show: !1, title: { dataZoom: "Zoom", dataZoomReset: "Reset Zoom" } }, dataView: { show: !1, title: "View Data", readOnly: !1, lang: ["View Data", "Close", "Refresh"] }, magicType: { show: !1, title: { line: "Line Chart", bar: "Bar Chart", stack: "Stack Chart", tiled: "Tile Chart", force: "Force Chart", chord: "Chord Chart", pie: "Pie Chart", funnel: "Funnel Chart" }, type: [] }, restore: { show: !1, title: "Restore" }, saveAsImage: { show: !1, title: "Save Image", type: "png", lang: ["Save"] } } }; var l = e("zrender/tool/util"), h = e("zrender/config"), d = e("zrender/tool/event"), c = "stack", m = "tiled"; return t.prototype = { type: s.COMPONENT_TYPE_TOOLBOX, _buildShape: function() { this._iconList = []; var e = this.option.toolbox; this._enableColor = e.effectiveColor, this._disableColor = e.disableColor; var t = e.feature, i = []; for (var n in t) if (t[n].show) switch (n) { case "mark": i.push({ key: n, name: "mark" }), i.push({ key: n, name: "markUndo" }), i.push({ key: n, name: "markClear" }); break; case "magicType": for (var a = 0, o = t[n].type.length; o > a; a++) t[n].title[t[n].type[a] + "Chart"] = t[n].title[t[n].type[a]], t[n].option && (t[n].option[t[n].type[a] + "Chart"] = t[n].option[t[n].type[a]]), i.push({ key: n, name: t[n].type[a] + "Chart" }); break; case "dataZoom": i.push({ key: n, name: "dataZoom" }), i.push({ key: n, name: "dataZoomReset" }); break; case "saveAsImage": this.canvasSupported && i.push({ key: n, name: "saveAsImage" }); break; default: i.push({ key: n, name: n }) } if (i.length > 0) { for (var r, n, a = 0, o = i.length; o > a; a++) r = i[a].name, n = i[a].key, this._iconList.push(r), this._featureTitle[r] = t[n].title[r] || t[n].title, t[n].icon && (this._featureIcon[r] = t[n].icon[r] || t[n].icon), t[n].color && (this._featureColor[r] = t[n].color[r] || t[n].color), t[n].option && (this._featureOption[r] = t[n].option[r] || t[n].option); this._itemGroupLocation = this._getItemGroupLocation(), this._buildBackground(), this._buildItem(); for (var a = 0, o = this.shapeList.length; o > a; a++) this.zr.addShape(this.shapeList[a]); this._iconShapeMap.mark && (this._iconDisable(this._iconShapeMap.markUndo), this._iconDisable(this._iconShapeMap.markClear)), this._iconShapeMap.dataZoomReset && 0 === this._zoomQueue.length && this._iconDisable(this._iconShapeMap.dataZoomReset) } }, _buildItem: function() { var t, i, n, o, s = this.option.toolbox, l = this._iconList.length, h = this._itemGroupLocation.x, d = this._itemGroupLocation.y, c = s.itemSize, m = s.itemGap, p = s.color instanceof Array ? s.color : [s.color], u = this.getFont(s.textStyle); "horizontal" === s.orient ? (i = this._itemGroupLocation.y / this.zr.getHeight() < .5 ? "bottom" : "top", n = this._itemGroupLocation.x / this.zr.getWidth() < .5 ? "left" : "right", o = this._itemGroupLocation.y / this.zr.getHeight() < .5 ? "top" : "bottom") : i = this._itemGroupLocation.x / this.zr.getWidth() < .5 ? "right" : "left", this._iconShapeMap = {}; for (var V = this, U = 0; l > U; U++) { switch (t = { type: "icon", zlevel: this.getZlevelBase(), z: this.getZBase(), style: { x: h, y: d, width: c, height: c, iconType: this._iconList[U], lineWidth: 1, strokeColor: this._featureColor[this._iconList[U]] || p[U % p.length], brushType: "stroke" }, highlightStyle: { lineWidth: 1, text: s.showTitle ? this._featureTitle[this._iconList[U]] : void 0, textFont: u, textPosition: i, strokeColor: this._featureColor[this._iconList[U]] || p[U % p.length] }, hoverable: !0, clickable: !0 }, this._featureIcon[this._iconList[U]] && (t.style.image = this._featureIcon[this._iconList[U]].replace(new RegExp("^image:\\/\\/"), ""), t.style.opacity = .8, t.highlightStyle.opacity = 1, t.type = "image"), "horizontal" === s.orient && (0 === U && "left" === n && (t.highlightStyle.textPosition = "specific", t.highlightStyle.textAlign = n, t.highlightStyle.textBaseline = o, t.highlightStyle.textX = h, t.highlightStyle.textY = "top" === o ? d + c + 10 : d - 10), U === l - 1 && "right" === n && (t.highlightStyle.textPosition = "specific", t.highlightStyle.textAlign = n, t.highlightStyle.textBaseline = o, t.highlightStyle.textX = h + c, t.highlightStyle.textY = "top" === o ? d + c + 10 : d - 10)), this._iconList[U]) { case "mark": t.onclick = V._onMark; break; case "markUndo": t.onclick = V._onMarkUndo; break; case "markClear": t.onclick = V._onMarkClear; break; case "dataZoom": t.onclick = V._onDataZoom; break; case "dataZoomReset": t.onclick = V._onDataZoomReset; break; case "dataView": if (!this._dataView) { var g = e("./dataView"); this._dataView = new g(this.ecTheme, this.messageCenter, this.zr, this.option, this.myChart) } t.onclick = V._onDataView; break; case "restore": t.onclick = V._onRestore; break; case "saveAsImage": t.onclick = V._onSaveAsImage; break; default: this._iconList[U].match("Chart") ? (t._name = this._iconList[U].replace("Chart", ""), t.onclick = V._onMagicType) : t.onclick = V._onCustomHandler } "icon" === t.type ? t = new r(t) : "image" === t.type && (t = new a(t)), this.shapeList.push(t), this._iconShapeMap[this._iconList[U]] = t, "horizontal" === s.orient ? h += c + m : d += c + m } }, _buildBackground: function() { var e = this.option.toolbox, t = this.reformCssArray(this.option.toolbox.padding); this.shapeList.push(new o({ zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this._itemGroupLocation.x - t[3], y: this._itemGroupLocation.y - t[0], width: this._itemGroupLocation.width + t[3] + t[1], height: this._itemGroupLocation.height + t[0] + t[2], brushType: 0 === e.borderWidth ? "fill" : "both", color: e.backgroundColor, strokeColor: e.borderColor, lineWidth: e.borderWidth } })) }, _getItemGroupLocation: function() { var e = this.option.toolbox, t = this.reformCssArray(this.option.toolbox.padding), i = this._iconList.length, n = e.itemGap, a = e.itemSize, o = 0, r = 0; "horizontal" === e.orient ? (o = (a + n) * i - n, r = a) : (r = (a + n) * i - n, o = a); var s, l = this.zr.getWidth(); switch (e.x) { case "center": s = Math.floor((l - o) / 2); break; case "left": s = t[3] + e.borderWidth; break; case "right": s = l - o - t[1] - e.borderWidth; break; default: s = e.x - 0, s = isNaN(s) ? 0 : s } var h, d = this.zr.getHeight(); switch (e.y) { case "top": h = t[0] + e.borderWidth; break; case "bottom": h = d - r - t[2] - e.borderWidth; break; case "center": h = Math.floor((d - r) / 2); break; default: h = e.y - 0, h = isNaN(h) ? 0 : h } return { x: s, y: h, width: o, height: r } }, __onmousemove: function(e) { this._marking && (this._markShape.style.xEnd = d.getX(e.event), this._markShape.style.yEnd = d.getY(e.event), this.zr.addHoverShape(this._markShape)), this._zooming && (this._zoomShape.style.width = d.getX(e.event) - this._zoomShape.style.x, this._zoomShape.style.height = d.getY(e.event) - this._zoomShape.style.y, this.zr.addHoverShape(this._zoomShape), this.dom.style.cursor = "crosshair", d.stop(e.event)), this._zoomStart && "pointer" != this.dom.style.cursor && "move" != this.dom.style.cursor && (this.dom.style.cursor = "crosshair") }, __onmousedown: function(e) { if (!e.target) { this._zooming = !0; var t = d.getX(e.event), i = d.getY(e.event), n = this.option.dataZoom || {}; return this._zoomShape = new o({ zlevel: this.getZlevelBase(), z: this.getZBase(), style: { x: t, y: i, width: 1, height: 1, brushType: "both" }, highlightStyle: { lineWidth: 2, color: n.fillerColor || s.dataZoom.fillerColor, strokeColor: n.handleColor || s.dataZoom.handleColor, brushType: "both" } }), this.zr.addHoverShape(this._zoomShape), !0 } }, __onmouseup: function() { if (!this._zoomShape || Math.abs(this._zoomShape.style.width) < 10 || Math.abs(this._zoomShape.style.height) < 10) return this._zooming = !1, !0; if (this._zooming && this.component.dataZoom) { this._zooming = !1; var e = this.component.dataZoom.rectZoom(this._zoomShape.style); e && (this._zoomQueue.push({ start: e.start, end: e.end, start2: e.start2, end2: e.end2 }), this._iconEnable(this._iconShapeMap.dataZoomReset), this.zr.refreshNextFrame()) } return !0 }, __onclick: function(e) { if (!e.target) if (this._marking) this._marking = !1, this._markShapeList.push(this._markShape), this._iconEnable(this._iconShapeMap.markUndo), this._iconEnable(this._iconShapeMap.markClear), this.zr.addShape(this._markShape), this.zr.refreshNextFrame(); else if (this._markStart) { this._marking = !0; var t = d.getX(e.event), i = d.getY(e.event); this._markShape = new n({ zlevel: this.getZlevelBase(), z: this.getZBase(), style: { xStart: t, yStart: i, xEnd: t, yEnd: i, lineWidth: this.query(this.option, "toolbox.feature.mark.lineStyle.width"), strokeColor: this.query(this.option, "toolbox.feature.mark.lineStyle.color"), lineType: this.query(this.option, "toolbox.feature.mark.lineStyle.type") } }), this.zr.addHoverShape(this._markShape) } }, __onMark: function(e) { var t = e.target; if (this._marking || this._markStart) this._resetMark(), this.zr.refreshNextFrame(); else { this._resetZoom(), this.zr.modShape(t.id, { style: { strokeColor: this._enableColor } }), this.zr.refreshNextFrame(), this._markStart = !0; var i = this; setTimeout(function() { i.zr && i.zr.on(h.EVENT.CLICK, i._onclick) && i.zr.on(h.EVENT.MOUSEMOVE, i._onmousemove) }, 10) } return !0 }, __onMarkUndo: function() { if (this._marking) this._marking = !1; else { var e = this._markShapeList.length; if (e >= 1) { var t = this._markShapeList[e - 1]; this.zr.delShape(t.id), this.zr.refreshNextFrame(), this._markShapeList.pop(), 1 === e && (this._iconDisable(this._iconShapeMap.markUndo), this._iconDisable(this._iconShapeMap.markClear)) } } return !0 }, __onMarkClear: function() { this._marking && (this._marking = !1); var e = this._markShapeList.length; if (e > 0) { for (; e--;) this.zr.delShape(this._markShapeList.pop().id); this._iconDisable(this._iconShapeMap.markUndo), this._iconDisable(this._iconShapeMap.markClear), this.zr.refreshNextFrame() } return !0 }, __onDataZoom: function(e) { var t = e.target; if (this._zooming || this._zoomStart) this._resetZoom(), this.zr.refreshNextFrame(), this.dom.style.cursor = "default"; else { this._resetMark(), this.zr.modShape(t.id, { style: { strokeColor: this._enableColor } }), this.zr.refreshNextFrame(), this._zoomStart = !0; var i = this; setTimeout(function() { i.zr && i.zr.on(h.EVENT.MOUSEDOWN, i._onmousedown) && i.zr.on(h.EVENT.MOUSEUP, i._onmouseup) && i.zr.on(h.EVENT.MOUSEMOVE, i._onmousemove) }, 10), this.dom.style.cursor = "crosshair" } return !0 }, __onDataZoomReset: function() { return this._zooming && (this._zooming = !1), this._zoomQueue.pop(), this._zoomQueue.length > 0 ? this.component.dataZoom.absoluteZoom(this._zoomQueue[this._zoomQueue.length - 1]) : (this.component.dataZoom.rectZoom(), this._iconDisable(this._iconShapeMap.dataZoomReset), this.zr.refreshNextFrame()), !0 }, _resetMark: function() { this._marking = !1, this._markStart && (this._markStart = !1, this._iconShapeMap.mark && this.zr.modShape(this._iconShapeMap.mark.id, { style: { strokeColor: this._iconShapeMap.mark.highlightStyle.strokeColor } }), this.zr.un(h.EVENT.CLICK, this._onclick), this.zr.un(h.EVENT.MOUSEMOVE, this._onmousemove)) }, _resetZoom: function() { this._zooming = !1, this._zoomStart && (this._zoomStart = !1, this._iconShapeMap.dataZoom && this.zr.modShape(this._iconShapeMap.dataZoom.id, { style: { strokeColor: this._iconShapeMap.dataZoom.highlightStyle.strokeColor } }), this.zr.un(h.EVENT.MOUSEDOWN, this._onmousedown), this.zr.un(h.EVENT.MOUSEUP, this._onmouseup), this.zr.un(h.EVENT.MOUSEMOVE, this._onmousemove)) }, _iconDisable: function(e) { "image" != e.type ? this.zr.modShape(e.id, { hoverable: !1, clickable: !1, style: { strokeColor: this._disableColor } }) : this.zr.modShape(e.id, { hoverable: !1, clickable: !1, style: { opacity: .3 } }) }, _iconEnable: function(e) { "image" != e.type ? this.zr.modShape(e.id, { hoverable: !0, clickable: !0, style: { strokeColor: e.highlightStyle.strokeColor } }) : this.zr.modShape(e.id, { hoverable: !0, clickable: !0, style: { opacity: .8 } }) }, __onDataView: function() { return this._dataView.show(this.option), !0 }, __onRestore: function() { return this._resetMark(), this._resetZoom(), this.messageCenter.dispatch(s.EVENT.RESTORE, null, null, this.myChart), !0 }, __onSaveAsImage: function() { var e = this.option.toolbox.feature.saveAsImage, t = e.type || "png"; "png" != t && "jpeg" != t && (t = "png"); var i; i = this.myChart.isConnected() ? this.myChart.getConnectedDataURL(t) : this.zr.toDataURL("image/" + t, this.option.backgroundColor && "rgba(0,0,0,0)" === this.option.backgroundColor.replace(" ", "") ? "#fff" : this.option.backgroundColor); var n = document.createElement("div"); n.id = "__echarts_download_wrap__", n.style.cssText = "position:fixed;z-index:99999;display:block;top:0;left:0;background-color:rgba(33,33,33,0.5);text-align:center;width:100%;height:100%;line-height:" + document.documentElement.clientHeight + "px;"; var a = document.createElement("a"); a.href = i, a.setAttribute("download", (e.name ? e.name : this.option.title && (this.option.title.text || this.option.title.subtext) ? this.option.title.text || this.option.title.subtext : "ECharts") + "." + t), a.innerHTML = '<img style="vertical-align:middle" src="' + i + '" title="' + (window.ActiveXObject || "ActiveXObject" in window ? "右键->图片另存为" : e.lang ? e.lang[0] : "点击保存") + '"/>', n.appendChild(a), document.body.appendChild(n), a = null, n = null, setTimeout(function() { var e = document.getElementById("__echarts_download_wrap__"); e && (e.onclick = function() { var e = document.getElementById("__echarts_download_wrap__"); e.onclick = null, e.innerHTML = "", document.body.removeChild(e), e = null }, e = null) }, 500) }, __onMagicType: function(e) { this._resetMark(); var t = e.target._name; return this._magicType[t] || (this._magicType[t] = !0, t === s.CHART_TYPE_LINE ? this._magicType[s.CHART_TYPE_BAR] = !1 : t === s.CHART_TYPE_BAR && (this._magicType[s.CHART_TYPE_LINE] = !1), t === s.CHART_TYPE_PIE ? this._magicType[s.CHART_TYPE_FUNNEL] = !1 : t === s.CHART_TYPE_FUNNEL && (this._magicType[s.CHART_TYPE_PIE] = !1), t === s.CHART_TYPE_FORCE ? this._magicType[s.CHART_TYPE_CHORD] = !1 : t === s.CHART_TYPE_CHORD && (this._magicType[s.CHART_TYPE_FORCE] = !1), t === c ? this._magicType[m] = !1 : t === m && (this._magicType[c] = !1), this.messageCenter.dispatch(s.EVENT.MAGIC_TYPE_CHANGED, e.event, { magicType: this._magicType }, this.myChart)), !0 }, setMagicType: function(e) { this._resetMark(), this._magicType = e, !this._isSilence && this.messageCenter.dispatch(s.EVENT.MAGIC_TYPE_CHANGED, null, { magicType: this._magicType }, this.myChart) }, __onCustomHandler: function(e) { var t = e.target.style.iconType, i = this.option.toolbox.feature[t].onclick; "function" == typeof i && i.call(this, this.option) }, reset: function(e, t) { if (t && this.clear(), this.query(e, "toolbox.show") && this.query(e, "toolbox.feature.magicType.show")) { var i = e.toolbox.feature.magicType.type, n = i.length; for (this._magicMap = {}; n--;) this._magicMap[i[n]] = !0; n = e.series.length; for (var a, o; n--;) a = e.series[n].type, this._magicMap[a] && (o = e.xAxis instanceof Array ? e.xAxis[e.series[n].xAxisIndex || 0] : e.xAxis, o && "category" === (o.type || "category") && (o.__boundaryGap = null != o.boundaryGap ? o.boundaryGap : !0), o = e.yAxis instanceof Array ? e.yAxis[e.series[n].yAxisIndex || 0] : e.yAxis, o && "category" === o.type && (o.__boundaryGap = null != o.boundaryGap ? o.boundaryGap : !0), e.series[n].__type = a, e.series[n].__itemStyle = l.clone(e.series[n].itemStyle || {})), (this._magicMap[c] || this._magicMap[m]) && (e.series[n].__stack = e.series[n].stack) } this._magicType = t ? {} : this._magicType || {}; for (var r in this._magicType) if (this._magicType[r]) { this.option = e, this.getMagicOption(); break } var s = e.dataZoom; if (s && s.show) { var h = null != s.start && s.start >= 0 && s.start <= 100 ? s.start : 0, d = null != s.end && s.end >= 0 && s.end <= 100 ? s.end : 100; h > d && (h += d, d = h - d, h -= d), this._zoomQueue = [{ start: h, end: d, start2: 0, end2: 100 }] } else this._zoomQueue = [] }, getMagicOption: function() { var e, t; if (this._magicType[s.CHART_TYPE_LINE] || this._magicType[s.CHART_TYPE_BAR]) { for (var i = this._magicType[s.CHART_TYPE_LINE] ? !1 : !0, n = 0, a = this.option.series.length; a > n; n++) t = this.option.series[n].type, (t == s.CHART_TYPE_LINE || t == s.CHART_TYPE_BAR) && (e = this.option.xAxis instanceof Array ? this.option.xAxis[this.option.series[n].xAxisIndex || 0] : this.option.xAxis, e && "category" === (e.type || "category") && (e.boundaryGap = i ? !0 : e.__boundaryGap), e = this.option.yAxis instanceof Array ? this.option.yAxis[this.option.series[n].yAxisIndex || 0] : this.option.yAxis, e && "category" === e.type && (e.boundaryGap = i ? !0 : e.__boundaryGap)); this._defaultMagic(s.CHART_TYPE_LINE, s.CHART_TYPE_BAR) } if (this._defaultMagic(s.CHART_TYPE_CHORD, s.CHART_TYPE_FORCE), this._defaultMagic(s.CHART_TYPE_PIE, s.CHART_TYPE_FUNNEL), this._magicType[c] || this._magicType[m]) for (var n = 0, a = this.option.series.length; a > n; n++) this._magicType[c] ? (this.option.series[n].stack = "_ECHARTS_STACK_KENER_2014_", t = c) : this._magicType[m] && (this.option.series[n].stack = null, t = m), this._featureOption[t + "Chart"] && l.merge(this.option.series[n], this._featureOption[t + "Chart"] || {}, !0); return this.option }, _defaultMagic: function(e, t) { if (this._magicType[e] || this._magicType[t]) for (var i = 0, n = this.option.series.length; n > i; i++) { var a = this.option.series[i].type; (a == e || a == t) && (this.option.series[i].type = this._magicType[e] ? e : t, this.option.series[i].itemStyle = l.clone(this.option.series[i].__itemStyle), a = this.option.series[i].type, this._featureOption[a + "Chart"] && l.merge(this.option.series[i], this._featureOption[a + "Chart"] || {}, !0)) } }, silence: function(e) { this._isSilence = e }, resize: function() { this._resetMark(), this.clear(), this.option && this.option.toolbox && this.option.toolbox.show && this._buildShape(), this._dataView && this._dataView.resize() }, hideDataView: function() { this._dataView && this._dataView.hide() }, clear: function(e) { this.zr && (this.zr.delShape(this.shapeList), this.shapeList = [], e || (this.zr.delShape(this._markShapeList), this._markShapeList = [])) }, onbeforDispose: function() { this._dataView && (this._dataView.dispose(), this._dataView = null), this._markShapeList = null }, refresh: function(e) { e && (this._resetMark(), this._resetZoom(), e.toolbox = this.reformOption(e.toolbox), this.option = e, this.clear(!0), e.toolbox.show && this._buildShape(), this.hideDataView()) } }, l.inherits(t, i), e("../component").define("toolbox", t), t }), define("echarts/component", [], function() { var e = {}, t = {}; return e.define = function(i, n) { return t[i] = n, e }, e.get = function(e) { return t[e] }, e }), define("echarts/component/title", ["require", "./base", "zrender/shape/Text", "zrender/shape/Rectangle", "../config", "zrender/tool/util", "zrender/tool/area", "zrender/tool/color", "../component"], function(e) { function t(e, t, n, a, o) { i.call(this, e, t, n, a, o), this.refresh(a) } var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Rectangle"), o = e("../config"); o.title = { zlevel: 0, z: 6, show: !0, text: "", subtext: "", x: "left", y: "top", backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, padding: 5, itemGap: 5, textStyle: { fontSize: 18, fontWeight: "bolder", color: "#333" }, subtextStyle: { color: "#aaa" } }; var r = e("zrender/tool/util"), s = e("zrender/tool/area"), l = e("zrender/tool/color"); return t.prototype = { type: o.COMPONENT_TYPE_TITLE, _buildShape: function() { if (this.titleOption.show) { this._itemGroupLocation = this._getItemGroupLocation(), this._buildBackground(), this._buildItem(); for (var e = 0, t = this.shapeList.length; t > e; e++) this.zr.addShape(this.shapeList[e]) } }, _buildItem: function() { var e = this.titleOption.text, t = this.titleOption.link, i = this.titleOption.target, a = this.titleOption.subtext, o = this.titleOption.sublink, r = this.titleOption.subtarget, s = this.getFont(this.titleOption.textStyle), h = this.getFont(this.titleOption.subtextStyle), d = this._itemGroupLocation.x, c = this._itemGroupLocation.y, m = this._itemGroupLocation.width, p = this._itemGroupLocation.height, u = { zlevel: this.getZlevelBase(), z: this.getZBase(), style: { y: c, color: this.titleOption.textStyle.color, text: e, textFont: s, textBaseline: "top" }, highlightStyle: { color: l.lift(this.titleOption.textStyle.color, 1), brushType: "fill" }, hoverable: !1 }; t && (u.hoverable = !0, u.clickable = !0, u.onclick = function() { i && "self" == i ? window.location = t : window.open(t) }); var V = { zlevel: this.getZlevelBase(), z: this.getZBase(), style: { y: c + p, color: this.titleOption.subtextStyle.color, text: a, textFont: h, textBaseline: "bottom" }, highlightStyle: { color: l.lift(this.titleOption.subtextStyle.color, 1), brushType: "fill" }, hoverable: !1 }; switch (o && (V.hoverable = !0, V.clickable = !0, V.onclick = function() { r && "self" == r ? window.location = o : window.open(o) }), this.titleOption.x) { case "center": u.style.x = V.style.x = d + m / 2, u.style.textAlign = V.style.textAlign = "center"; break; case "left": u.style.x = V.style.x = d, u.style.textAlign = V.style.textAlign = "left"; break; case "right": u.style.x = V.style.x = d + m, u.style.textAlign = V.style.textAlign = "right"; break; default: d = this.titleOption.x - 0, d = isNaN(d) ? 0 : d, u.style.x = V.style.x = d } this.titleOption.textAlign && (u.style.textAlign = V.style.textAlign = this.titleOption.textAlign), this.shapeList.push(new n(u)), "" !== a && this.shapeList.push(new n(V)) }, _buildBackground: function() { var e = this.reformCssArray(this.titleOption.padding); this.shapeList.push(new a({ zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this._itemGroupLocation.x - e[3], y: this._itemGroupLocation.y - e[0], width: this._itemGroupLocation.width + e[3] + e[1], height: this._itemGroupLocation.height + e[0] + e[2], brushType: 0 === this.titleOption.borderWidth ? "fill" : "both", color: this.titleOption.backgroundColor, strokeColor: this.titleOption.borderColor, lineWidth: this.titleOption.borderWidth } })) }, _getItemGroupLocation: function() { var e, t = this.reformCssArray(this.titleOption.padding), i = this.titleOption.text, n = this.titleOption.subtext, a = this.getFont(this.titleOption.textStyle), o = this.getFont(this.titleOption.subtextStyle), r = Math.max(s.getTextWidth(i, a), s.getTextWidth(n, o)), l = s.getTextHeight(i, a) + ("" === n ? 0 : this.titleOption.itemGap + s.getTextHeight(n, o)), h = this.zr.getWidth(); switch (this.titleOption.x) { case "center": e = Math.floor((h - r) / 2); break; case "left": e = t[3] + this.titleOption.borderWidth; break; case "right": e = h - r - t[1] - this.titleOption.borderWidth; break; default: e = this.titleOption.x - 0, e = isNaN(e) ? 0 : e } var d, c = this.zr.getHeight(); switch (this.titleOption.y) { case "top": d = t[0] + this.titleOption.borderWidth; break; case "bottom": d = c - l - t[2] - this.titleOption.borderWidth; break; case "center": d = Math.floor((c - l) / 2); break; default: d = this.titleOption.y - 0, d = isNaN(d) ? 0 : d } return { x: e, y: d, width: r, height: l } }, refresh: function(e) { e && (this.option = e, this.option.title = this.reformOption(this.option.title), this.titleOption = this.option.title, this.titleOption.textStyle = this.getTextStyle(this.titleOption.textStyle), this.titleOption.subtextStyle = this.getTextStyle(this.titleOption.subtextStyle)), this.clear(), this._buildShape() } }, r.inherits(t, i), e("../component").define("title", t), t }), define("echarts/component/tooltip", ["require", "./base", "../util/shape/Cross", "zrender/shape/Line", "zrender/shape/Rectangle", "../config", "../util/ecData", "zrender/config", "zrender/tool/event", "zrender/tool/area", "zrender/tool/color", "zrender/tool/util", "zrender/shape/Base", "../component"], function(e) { function t(e, t, o, r, s) { i.call(this, e, t, o, r, s), this.dom = s.dom; var l = this; l._onmousemove = function(e) { return l.__onmousemove(e) }, l._onglobalout = function(e) { return l.__onglobalout(e) }, this.zr.on(h.EVENT.MOUSEMOVE, l._onmousemove), this.zr.on(h.EVENT.GLOBALOUT, l._onglobalout), l._hide = function(e) { return l.__hide(e) }, l._tryShow = function(e) { return l.__tryShow(e) }, l._refixed = function(e) { return l.__refixed(e) }, l._setContent = function(e, t) { return l.__setContent(e, t) }, this._tDom = this._tDom || document.createElement("div"), this._tDom.onselectstart = function() { return !1 }, this._tDom.onmouseover = function() { l._mousein = !0 }, this._tDom.onmouseout = function() { l._mousein = !1 }, this._tDom.className = "echarts-tooltip", this._tDom.style.position = "absolute", this.hasAppend = !1, this._axisLineShape && this.zr.delShape(this._axisLineShape.id), this._axisLineShape = new a({ zlevel: this.getZlevelBase(), z: this.getZBase(), invisible: !0, hoverable: !1 }), this.shapeList.push(this._axisLineShape), this.zr.addShape(this._axisLineShape), this._axisShadowShape && this.zr.delShape(this._axisShadowShape.id), this._axisShadowShape = new a({ zlevel: this.getZlevelBase(), z: 1, invisible: !0, hoverable: !1 }), this.shapeList.push(this._axisShadowShape), this.zr.addShape(this._axisShadowShape), this._axisCrossShape && this.zr.delShape(this._axisCrossShape.id), this._axisCrossShape = new n({ zlevel: this.getZlevelBase(), z: this.getZBase(), invisible: !0, hoverable: !1 }), this.shapeList.push(this._axisCrossShape), this.zr.addShape(this._axisCrossShape), this.showing = !1, this.refresh(r) } var i = e("./base"), n = e("../util/shape/Cross"), a = e("zrender/shape/Line"), o = e("zrender/shape/Rectangle"), r = new o({}), s = e("../config"); s.tooltip = { zlevel: 1, z: 8, show: !0, showContent: !0, trigger: "item", islandFormatter: "{a} <br/>{b} : {c}", showDelay: 20, hideDelay: 100, transitionDuration: .4, enterable: !1, backgroundColor: "rgba(0,0,0,0.7)", borderColor: "#333", borderRadius: 4, borderWidth: 0, padding: 5, axisPointer: { type: "line", lineStyle: { color: "#48b", width: 2, type: "solid" }, crossStyle: { color: "#1e90ff", width: 1, type: "dashed" }, shadowStyle: { color: "rgba(150,150,150,0.3)", width: "auto", type: "default" } }, textStyle: { color: "#fff" } }; var l = e("../util/ecData"), h = e("zrender/config"), d = e("zrender/tool/event"), c = e("zrender/tool/area"), m = e("zrender/tool/color"), p = e("zrender/tool/util"), u = e("zrender/shape/Base"); return t.prototype = { type: s.COMPONENT_TYPE_TOOLTIP, _gCssText: "position:absolute;display:block;border-style:solid;white-space:nowrap;", _style: function(e) { if (!e) return ""; var t = []; if (e.transitionDuration) { var i = "left " + e.transitionDuration + "s,top " + e.transitionDuration + "s"; t.push("transition:" + i), t.push("-moz-transition:" + i), t.push("-webkit-transition:" + i), t.push("-o-transition:" + i) } e.backgroundColor && (t.push("background-Color:" + m.toHex(e.backgroundColor)), t.push("filter:alpha(opacity=70)"), t.push("background-Color:" + e.backgroundColor)), null != e.borderWidth && t.push("border-width:" + e.borderWidth + "px"), null != e.borderColor && t.push("border-color:" + e.borderColor), null != e.borderRadius && (t.push("border-radius:" + e.borderRadius + "px"), t.push("-moz-border-radius:" + e.borderRadius + "px"), t.push("-webkit-border-radius:" + e.borderRadius + "px"), t.push("-o-border-radius:" + e.borderRadius + "px")); var n = e.textStyle; n && (n.color && t.push("color:" + n.color), n.decoration && t.push("text-decoration:" + n.decoration), n.align && t.push("text-align:" + n.align), n.fontFamily && t.push("font-family:" + n.fontFamily), n.fontSize && t.push("font-size:" + n.fontSize + "px"), n.fontSize && t.push("line-height:" + Math.round(3 * n.fontSize / 2) + "px"), n.fontStyle && t.push("font-style:" + n.fontStyle), n.fontWeight && t.push("font-weight:" + n.fontWeight)); var a = e.padding; return null != a && (a = this.reformCssArray(a), t.push("padding:" + a[0] + "px " + a[1] + "px " + a[2] + "px " + a[3] + "px")), t = t.join(";") + ";" }, __hide: function() { this._lastDataIndex = -1, this._lastSeriesIndex = -1, this._lastItemTriggerId = -1, this._tDom && (this._tDom.style.display = "none"); var e = !1; this._axisLineShape.invisible || (this._axisLineShape.invisible = !0, this.zr.modShape(this._axisLineShape.id), e = !0), this._axisShadowShape.invisible || (this._axisShadowShape.invisible = !0, this.zr.modShape(this._axisShadowShape.id), e = !0), this._axisCrossShape.invisible || (this._axisCrossShape.invisible = !0, this.zr.modShape(this._axisCrossShape.id), e = !0), this._lastTipShape && this._lastTipShape.tipShape.length > 0 && (this.zr.delShape(this._lastTipShape.tipShape), this._lastTipShape = !1, this.shapeList.length = 2), e && this.zr.refreshNextFrame(), this.showing = !1 }, _show: function(e, t, i, n) { var a = this._tDom.offsetHeight, o = this._tDom.offsetWidth; e && ("function" == typeof e && (e = e([t, i])), e instanceof Array && (t = e[0], i = e[1])), t + o > this._zrWidth && (t -= o + 40), i + a > this._zrHeight && (i -= a - 20), 20 > i && (i = 0), this._tDom.style.cssText = this._gCssText + this._defaultCssText + (n ? n : "") + "left:" + t + "px;top:" + i + "px;", (10 > a || 10 > o) && setTimeout(this._refixed, 20), this.showing = !0 }, __refixed: function() { if (this._tDom) { var e = "", t = this._tDom.offsetHeight, i = this._tDom.offsetWidth; this._tDom.offsetLeft + i > this._zrWidth && (e += "left:" + (this._zrWidth - i - 20) + "px;"), this._tDom.offsetTop + t > this._zrHeight && (e += "top:" + (this._zrHeight - t - 10) + "px;"), "" !== e && (this._tDom.style.cssText += e) } }, __tryShow: function() { var e, t; if (this._curTarget) { if ("island" === this._curTarget._type && this.option.tooltip.show) return void this._showItemTrigger(); var i = l.get(this._curTarget, "series"), n = l.get(this._curTarget, "data"); e = this.deepQuery([n, i, this.option], "tooltip.show"), null != i && null != n && e ? (t = this.deepQuery([n, i, this.option], "tooltip.trigger"), "axis" === t ? this._showAxisTrigger(i.xAxisIndex, i.yAxisIndex, l.get(this._curTarget, "dataIndex")) : this._showItemTrigger()) : (clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this._hidingTicket = setTimeout(this._hide, this._hideDelay)) } else this._findPolarTrigger() || this._findAxisTrigger() }, _findAxisTrigger: function() { if (!this.component.xAxis || !this.component.yAxis) return void(this._hidingTicket = setTimeout(this._hide, this._hideDelay)); for (var e, t, i = this.option.series, n = 0, a = i.length; a > n; n++) if ("axis" === this.deepQuery([i[n], this.option], "tooltip.trigger")) return e = i[n].xAxisIndex || 0, t = i[n].yAxisIndex || 0, this.component.xAxis.getAxis(e) && this.component.xAxis.getAxis(e).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? void this._showAxisTrigger(e, t, this._getNearestDataIndex("x", this.component.xAxis.getAxis(e))) : this.component.yAxis.getAxis(t) && this.component.yAxis.getAxis(t).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? void this._showAxisTrigger(e, t, this._getNearestDataIndex("y", this.component.yAxis.getAxis(t))) : void this._showAxisTrigger(e, t, -1); "cross" === this.option.tooltip.axisPointer.type && this._showAxisTrigger(-1, -1, -1) }, _findPolarTrigger: function() { if (!this.component.polar) return !1; var e, t = d.getX(this._event), i = d.getY(this._event), n = this.component.polar.getNearestIndex([t, i]); return n ? (e = n.valueIndex, n = n.polarIndex) : n = -1, -1 != n ? this._showPolarTrigger(n, e) : !1 }, _getNearestDataIndex: function(e, t) { var i = -1, n = d.getX(this._event), a = d.getY(this._event); if ("x" === e) { for (var o, r, s = this.component.grid.getXend(), l = t.getCoordByIndex(i); s > l && (r = l, n >= l);) o = l, l = t.getCoordByIndex(++i); return 0 >= i ? i = 0 : r - n >= n - o ? i -= 1 : null == t.getNameByIndex(i) && (i -= 1), i } for (var h, c, m = this.component.grid.getY(), l = t.getCoordByIndex(i); l > m && (h = l, l >= a);) c = l, l = t.getCoordByIndex(++i); return 0 >= i ? i = 0 : a - h >= c - a ? i -= 1 : null == t.getNameByIndex(i) && (i -= 1), i }, _showAxisTrigger: function(e, t, i) { if (!this._event.connectTrigger && this.messageCenter.dispatch(s.EVENT.TOOLTIP_IN_GRID, this._event, null, this.myChart), null == this.component.xAxis || null == this.component.yAxis || null == e || null == t) return clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), void(this._hidingTicket = setTimeout(this._hide, this._hideDelay)); var n, a, o, r, l = this.option.series, h = [], c = [], m = ""; if ("axis" === this.option.tooltip.trigger) { if (!this.option.tooltip.show) return; a = this.option.tooltip.formatter, o = this.option.tooltip.position } var p, u, V = -1 != e && this.component.xAxis.getAxis(e).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? "xAxis" : -1 != t && this.component.yAxis.getAxis(t).type === s.COMPONENT_TYPE_AXIS_CATEGORY ? "yAxis" : !1; if (V) { var U = "xAxis" == V ? e : t; n = this.component[V].getAxis(U); for (var g = 0, f = l.length; f > g; g++) this._isSelected(l[g].name) && l[g][V + "Index"] === U && "axis" === this.deepQuery([l[g], this.option], "tooltip.trigger") && (r = this.query(l[g], "tooltip.showContent") || r, a = this.query(l[g], "tooltip.formatter") || a, o = this.query(l[g], "tooltip.position") || o, m += this._style(this.query(l[g], "tooltip")), null != l[g].stack && "xAxis" == V ? (h.unshift(l[g]), c.unshift(g)) : (h.push(l[g]), c.push(g))); this.messageCenter.dispatch(s.EVENT.TOOLTIP_HOVER, this._event, { seriesIndex: c, dataIndex: i }, this.myChart); var y; "xAxis" == V ? (p = this.subPixelOptimize(n.getCoordByIndex(i), this._axisLineWidth), u = d.getY(this._event), y = [p, this.component.grid.getY(), p, this.component.grid.getYend()]) : (p = d.getX(this._event), u = this.subPixelOptimize(n.getCoordByIndex(i), this._axisLineWidth), y = [this.component.grid.getX(), u, this.component.grid.getXend(), u]), this._styleAxisPointer(h, y[0], y[1], y[2], y[3], n.getGap(), p, u) } else p = d.getX(this._event), u = d.getY(this._event), this._styleAxisPointer(l, this.component.grid.getX(), u, this.component.grid.getXend(), u, 0, p, u), i >= 0 ? this._showItemTrigger(!0) : (clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this._tDom.style.display = "none"); if (h.length > 0) { if (this._lastItemTriggerId = -1, this._lastDataIndex != i || this._lastSeriesIndex != c[0]) { this._lastDataIndex = i, this._lastSeriesIndex = c[0]; var b, _; if ("function" == typeof a) { for (var x = [], g = 0, f = h.length; f > g; g++) b = h[g].data[i], _ = this.getDataFromOption(b, "-"), x.push({ seriesIndex: c[g], seriesName: h[g].name || "", series: h[g], dataIndex: i, data: b, name: n.getNameByIndex(i), value: _, 0: h[g].name || "", 1: n.getNameByIndex(i), 2: _, 3: b }); this._curTicket = "axis:" + i, this._tDom.innerHTML = a.call(this.myChart, x, this._curTicket, this._setContent) } else if ("string" == typeof a) { this._curTicket = 0 / 0, a = a.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}"); for (var g = 0, f = h.length; f > g; g++) a = a.replace("{a" + g + "}", this._encodeHTML(h[g].name || "")), a = a.replace("{b" + g + "}", this._encodeHTML(n.getNameByIndex(i))), b = h[g].data[i], b = this.getDataFromOption(b, "-"), a = a.replace("{c" + g + "}", b instanceof Array ? b : this.numAddCommas(b)); this._tDom.innerHTML = a } else { this._curTicket = 0 / 0, a = this._encodeHTML(n.getNameByIndex(i)); for (var g = 0, f = h.length; f > g; g++) a += "<br/>" + this._encodeHTML(h[g].name || "") + " : ", b = h[g].data[i], b = this.getDataFromOption(b, "-"), a += b instanceof Array ? b : this.numAddCommas(b); this._tDom.innerHTML = a } } if (r === !1 || !this.option.tooltip.showContent) return; this.hasAppend || (this._tDom.style.left = this._zrWidth / 2 + "px", this._tDom.style.top = this._zrHeight / 2 + "px", this.dom.firstChild.appendChild(this._tDom), this.hasAppend = !0), this._show(o, p + 10, u + 10, m) } }, _showPolarTrigger: function(e, t) { if (null == this.component.polar || null == e || null == t || 0 > t) return !1; var i, n, a, o = this.option.series, r = [], s = [], l = ""; if ("axis" === this.option.tooltip.trigger) { if (!this.option.tooltip.show) return !1; i = this.option.tooltip.formatter, n = this.option.tooltip.position } for (var h = this.option.polar[e].indicator[t].text, c = 0, m = o.length; m > c; c++) this._isSelected(o[c].name) && o[c].polarIndex === e && "axis" === this.deepQuery([o[c], this.option], "tooltip.trigger") && (a = this.query(o[c], "tooltip.showContent") || a, i = this.query(o[c], "tooltip.formatter") || i, n = this.query(o[c], "tooltip.position") || n, l += this._style(this.query(o[c], "tooltip")), r.push(o[c]), s.push(c)); if (r.length > 0) { for (var p, u, V, U = [], c = 0, m = r.length; m > c; c++) { p = r[c].data; for (var g = 0, f = p.length; f > g; g++) u = p[g], this._isSelected(u.name) && (u = null != u ? u : { name: "", value: { dataIndex: "-" } }, V = this.getDataFromOption(u.value[t]), U.push({ seriesIndex: s[c], seriesName: r[c].name || "", series: r[c], dataIndex: t, data: u, name: u.name, indicator: h, value: V, 0: r[c].name || "", 1: u.name, 2: V, 3: h })) } if (U.length <= 0) return; if (this._lastItemTriggerId = -1, this._lastDataIndex != t || this._lastSeriesIndex != s[0]) if (this._lastDataIndex = t, this._lastSeriesIndex = s[0], "function" == typeof i) this._curTicket = "axis:" + t, this._tDom.innerHTML = i.call(this.myChart, U, this._curTicket, this._setContent); else if ("string" == typeof i) { i = i.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}").replace("{d}", "{d0}"); for (var c = 0, m = U.length; m > c; c++) i = i.replace("{a" + c + "}", this._encodeHTML(U[c].seriesName)), i = i.replace("{b" + c + "}", this._encodeHTML(U[c].name)), i = i.replace("{c" + c + "}", this.numAddCommas(U[c].value)), i = i.replace("{d" + c + "}", this._encodeHTML(U[c].indicator)); this._tDom.innerHTML = i } else { i = this._encodeHTML(U[0].name) + "<br/>" + this._encodeHTML(U[0].indicator) + " : " + this.numAddCommas(U[0].value); for (var c = 1, m = U.length; m > c; c++) i += "<br/>" + this._encodeHTML(U[c].name) + "<br/>", i += this._encodeHTML(U[c].indicator) + " : " + this.numAddCommas(U[c].value); this._tDom.innerHTML = i } if (a === !1 || !this.option.tooltip.showContent) return; return this.hasAppend || (this._tDom.style.left = this._zrWidth / 2 + "px", this._tDom.style.top = this._zrHeight / 2 + "px", this.dom.firstChild.appendChild(this._tDom), this.hasAppend = !0), this._show(n, d.getX(this._event), d.getY(this._event), l), !0 } }, _showItemTrigger: function(e) { if (this._curTarget) { var t, i, n, a = l.get(this._curTarget, "series"), o = l.get(this._curTarget, "seriesIndex"), r = l.get(this._curTarget, "data"), h = l.get(this._curTarget, "dataIndex"), c = l.get(this._curTarget, "name"), m = l.get(this._curTarget, "value"), p = l.get(this._curTarget, "special"), u = l.get(this._curTarget, "special2"), V = [r, a, this.option], U = ""; if ("island" != this._curTarget._type) { var g = e ? "axis" : "item"; this.option.tooltip.trigger === g && (t = this.option.tooltip.formatter, i = this.option.tooltip.position), this.query(a, "tooltip.trigger") === g && (n = this.query(a, "tooltip.showContent") || n, t = this.query(a, "tooltip.formatter") || t, i = this.query(a, "tooltip.position") || i, U += this._style(this.query(a, "tooltip"))), n = this.query(r, "tooltip.showContent") || n, t = this.query(r, "tooltip.formatter") || t, i = this.query(r, "tooltip.position") || i, U += this._style(this.query(r, "tooltip")) } else this._lastItemTriggerId = 0 / 0, n = this.deepQuery(V, "tooltip.showContent"), t = this.deepQuery(V, "tooltip.islandFormatter"), i = this.deepQuery(V, "tooltip.islandPosition"); this._lastDataIndex = -1, this._lastSeriesIndex = -1, this._lastItemTriggerId !== this._curTarget.id && (this._lastItemTriggerId = this._curTarget.id, "function" == typeof t ? (this._curTicket = (a.name || "") + ":" + h, this._tDom.innerHTML = t.call(this.myChart, { seriesIndex: o, seriesName: a.name || "", series: a, dataIndex: h, data: r, name: c, value: m, percent: p, indicator: p, value2: u, indicator2: u, 0: a.name || "", 1: c, 2: m, 3: p, 4: u, 5: r, 6: o, 7: h }, this._curTicket, this._setContent)) : "string" == typeof t ? (this._curTicket = 0 / 0, t = t.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}"), t = t.replace("{a0}", this._encodeHTML(a.name || "")).replace("{b0}", this._encodeHTML(c)).replace("{c0}", m instanceof Array ? m : this.numAddCommas(m)), t = t.replace("{d}", "{d0}").replace("{d0}", p || ""), t = t.replace("{e}", "{e0}").replace("{e0}", l.get(this._curTarget, "special2") || ""), this._tDom.innerHTML = t) : (this._curTicket = 0 / 0, this._tDom.innerHTML = a.type === s.CHART_TYPE_RADAR && p ? this._itemFormatter.radar.call(this, a, c, m, p) : a.type === s.CHART_TYPE_EVENTRIVER ? this._itemFormatter.eventRiver.call(this, a, c, m, r) : "" + (null != a.name ? this._encodeHTML(a.name) + "<br/>" : "") + ("" === c ? "" : this._encodeHTML(c) + " : ") + (m instanceof Array ? m : this.numAddCommas(m)))); var f = d.getX(this._event), y = d.getY(this._event); this.deepQuery(V, "tooltip.axisPointer.show") && this.component.grid ? this._styleAxisPointer([a], this.component.grid.getX(), y, this.component.grid.getXend(), y, 0, f, y) : this._hide(), n !== !1 && this.option.tooltip.showContent && (this.hasAppend || (this._tDom.style.left = this._zrWidth / 2 + "px", this._tDom.style.top = this._zrHeight / 2 + "px", this.dom.firstChild.appendChild(this._tDom), this.hasAppend = !0), this._show(i, f + 20, y - 20, U)) } }, _itemFormatter: { radar: function(e, t, i, n) { var a = ""; a += this._encodeHTML("" === t ? e.name || "" : t), a += "" === a ? "" : "<br />"; for (var o = 0; o < n.length; o++) a += this._encodeHTML(n[o].text) + " : " + this.numAddCommas(i[o]) + "<br />"; return a }, chord: function(e, t, i, n, a) { if (null == a) return this._encodeHTML(t) + " (" + this.numAddCommas(i) + ")"; var o = this._encodeHTML(t), r = this._encodeHTML(n); return "" + (null != e.name ? this._encodeHTML(e.name) + "<br/>" : "") + o + " -> " + r + " (" + this.numAddCommas(i) + ")<br />" + r + " -> " + o + " (" + this.numAddCommas(a) + ")" }, eventRiver: function(e, t, i, n) { var a = ""; a += this._encodeHTML("" === e.name ? "" : e.name + " : "), a += this._encodeHTML(t), a += "" === a ? "" : "<br />", n = n.evolution; for (var o = 0, r = n.length; r > o; o++) a += '<div style="padding-top:5px;">', n[o].detail && (n[o].detail.img && (a += '<img src="' + n[o].detail.img + '" style="float:left;width:40px;height:40px;">'), a += '<div style="margin-left:45px;">' + n[o].time + "<br/>", a += '<a href="' + n[o].detail.link + '" target="_blank">', a += n[o].detail.text + "</a></div>", a += "</div>"); return a } }, _styleAxisPointer: function(e, t, i, n, a, o, r, s) { if (e.length > 0) { var l, h, d = this.option.tooltip.axisPointer, c = d.type, m = { line: {}, cross: {}, shadow: {} }; for (var p in m) m[p].color = d[p + "Style"].color, m[p].width = d[p + "Style"].width, m[p].type = d[p + "Style"].type; for (var u = 0, V = e.length; V > u; u++) l = e[u], h = this.query(l, "tooltip.axisPointer.type"), c = h || c, h && (m[h].color = this.query(l, "tooltip.axisPointer." + h + "Style.color") || m[h].color, m[h].width = this.query(l, "tooltip.axisPointer." + h + "Style.width") || m[h].width, m[h].type = this.query(l, "tooltip.axisPointer." + h + "Style.type") || m[h].type); if ("line" === c) { var U = m.line.width, g = t == n; this._axisLineShape.style = { xStart: g ? this.subPixelOptimize(t, U) : t, yStart: g ? i : this.subPixelOptimize(i, U), xEnd: g ? this.subPixelOptimize(n, U) : n, yEnd: g ? a : this.subPixelOptimize(a, U), strokeColor: m.line.color, lineWidth: U, lineType: m.line.type }, this._axisLineShape.invisible = !1, this.zr.modShape(this._axisLineShape.id) } else if ("cross" === c) { var f = m.cross.width; this._axisCrossShape.style = { brushType: "stroke", rect: this.component.grid.getArea(), x: this.subPixelOptimize(r, f), y: this.subPixelOptimize(s, f), text: ("( " + this.component.xAxis.getAxis(0).getValueFromCoord(r) + " , " + this.component.yAxis.getAxis(0).getValueFromCoord(s) + " )").replace(" , ", " ").replace(" , ", " "), textPosition: "specific", strokeColor: m.cross.color, lineWidth: f, lineType: m.cross.type }, this.component.grid.getXend() - r > 100 ? (this._axisCrossShape.style.textAlign = "left", this._axisCrossShape.style.textX = r + 10) : (this._axisCrossShape.style.textAlign = "right", this._axisCrossShape.style.textX = r - 10), s - this.component.grid.getY() > 50 ? (this._axisCrossShape.style.textBaseline = "bottom", this._axisCrossShape.style.textY = s - 10) : (this._axisCrossShape.style.textBaseline = "top", this._axisCrossShape.style.textY = s + 10), this._axisCrossShape.invisible = !1, this.zr.modShape(this._axisCrossShape.id) } else "shadow" === c && ((null == m.shadow.width || "auto" === m.shadow.width || isNaN(m.shadow.width)) && (m.shadow.width = o), t === n ? Math.abs(this.component.grid.getX() - t) < 2 ? (m.shadow.width /= 2, t = n += m.shadow.width / 2) : Math.abs(this.component.grid.getXend() - t) < 2 && (m.shadow.width /= 2, t = n -= m.shadow.width / 2) : i === a && (Math.abs(this.component.grid.getY() - i) < 2 ? (m.shadow.width /= 2, i = a += m.shadow.width / 2) : Math.abs(this.component.grid.getYend() - i) < 2 && (m.shadow.width /= 2, i = a -= m.shadow.width / 2)), this._axisShadowShape.style = { xStart: t, yStart: i, xEnd: n, yEnd: a, strokeColor: m.shadow.color, lineWidth: m.shadow.width }, this._axisShadowShape.invisible = !1, this.zr.modShape(this._axisShadowShape.id)); this.zr.refreshNextFrame() } }, __onmousemove: function(e) { if (clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), !this._mousein || !this._enterable) { var t = e.target, i = d.getX(e.event), n = d.getY(e.event); if (t) { this._curTarget = t, this._event = e.event, this._event.zrenderX = i, this._event.zrenderY = n; var a; if (this._needAxisTrigger && this.component.polar && -1 != (a = this.component.polar.isInside([i, n]))) for (var o = this.option.series, l = 0, h = o.length; h > l; l++) if (o[l].polarIndex === a && "axis" === this.deepQuery([o[l], this.option], "tooltip.trigger")) { this._curTarget = null; break } this._showingTicket = setTimeout(this._tryShow, this._showDelay) } else this._curTarget = !1, this._event = e.event, this._event.zrenderX = i, this._event.zrenderY = n, this._needAxisTrigger && this.component.grid && c.isInside(r, this.component.grid.getArea(), i, n) ? this._showingTicket = setTimeout(this._tryShow, this._showDelay) : this._needAxisTrigger && this.component.polar && -1 != this.component.polar.isInside([i, n]) ? this._showingTicket = setTimeout(this._tryShow, this._showDelay) : (!this._event.connectTrigger && this.messageCenter.dispatch(s.EVENT.TOOLTIP_OUT_GRID, this._event, null, this.myChart), this._hidingTicket = setTimeout(this._hide, this._hideDelay)) } }, __onglobalout: function() { clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this._hidingTicket = setTimeout(this._hide, this._hideDelay) }, __setContent: function(e, t) { this._tDom && (e === this._curTicket && (this._tDom.innerHTML = t), setTimeout(this._refixed, 20)) }, ontooltipHover: function(e, t) { if (!this._lastTipShape || this._lastTipShape && this._lastTipShape.dataIndex != e.dataIndex) { this._lastTipShape && this._lastTipShape.tipShape.length > 0 && (this.zr.delShape(this._lastTipShape.tipShape), this.shapeList.length = 2); for (var i = 0, n = t.length; n > i; i++) t[i].zlevel = this.getZlevelBase(), t[i].z = this.getZBase(), t[i].style = u.prototype.getHighlightStyle(t[i].style, t[i].highlightStyle), t[i].draggable = !1, t[i].hoverable = !1, t[i].clickable = !1, t[i].ondragend = null, t[i].ondragover = null, t[i].ondrop = null, this.shapeList.push(t[i]), this.zr.addShape(t[i]); this._lastTipShape = { dataIndex: e.dataIndex, tipShape: t } } }, ondragend: function() { this._hide() }, onlegendSelected: function(e) { this._selectedMap = e.selected }, _setSelectedMap: function() { this._selectedMap = this.component.legend ? p.clone(this.component.legend.getSelectedMap()) : {} }, _isSelected: function(e) { return null != this._selectedMap[e] ? this._selectedMap[e] : !0 }, showTip: function(e) { if (e) { var t, i = this.option.series; if (null != e.seriesIndex) t = e.seriesIndex; else for (var n = e.seriesName, a = 0, o = i.length; o > a; a++) if (i[a].name === n) { t = a; break } var r = i[t]; if (null != r) { var d = this.myChart.chart[r.type], c = "axis" === this.deepQuery([r, this.option], "tooltip.trigger"); if (d) if (c) { var m = e.dataIndex; switch (d.type) { case s.CHART_TYPE_LINE: case s.CHART_TYPE_BAR: case s.CHART_TYPE_K: case s.CHART_TYPE_RADAR: if (null == this.component.polar || r.data[0].value.length <= m) return; var p = r.polarIndex || 0, u = this.component.polar.getVector(p, m, "max"); this._event = { zrenderX: u[0], zrenderY: u[1] }, this._showPolarTrigger(p, m) } } else { var V, U, g = d.shapeList; switch (d.type) { case s.CHART_TYPE_LINE: case s.CHART_TYPE_BAR: case s.CHART_TYPE_K: case s.CHART_TYPE_TREEMAP: case s.CHART_TYPE_SCATTER: for (var m = e.dataIndex, a = 0, o = g.length; o > a; a++) if (null == g[a]._mark && l.get(g[a], "seriesIndex") == t && l.get(g[a], "dataIndex") == m) { this._curTarget = g[a], V = g[a].style.x, U = d.type != s.CHART_TYPE_K ? g[a].style.y : g[a].style.y[0]; break } break; case s.CHART_TYPE_RADAR: for (var m = e.dataIndex, a = 0, o = g.length; o > a; a++) if ("polygon" === g[a].type && l.get(g[a], "seriesIndex") == t && l.get(g[a], "dataIndex") == m) { this._curTarget = g[a]; var u = this.component.polar.getCenter(r.polarIndex || 0); V = u[0], U = u[1]; break } break; case s.CHART_TYPE_PIE: for (var f = e.name, a = 0, o = g.length; o > a; a++) if ("sector" === g[a].type && l.get(g[a], "seriesIndex") == t && l.get(g[a], "name") == f) { this._curTarget = g[a]; var y = this._curTarget.style, b = (y.startAngle + y.endAngle) / 2 * Math.PI / 180; V = this._curTarget.style.x + Math.cos(b) * y.r / 1.5, U = this._curTarget.style.y - Math.sin(b) * y.r / 1.5; break } break; case s.CHART_TYPE_MAP: for (var f = e.name, _ = r.mapType, a = 0, o = g.length; o > a; a++) if ("text" === g[a].type && g[a]._mapType === _ && g[a].style._name === f) { this._curTarget = g[a], V = this._curTarget.style.x + this._curTarget.position[0], U = this._curTarget.style.y + this._curTarget.position[1]; break } break; case s.CHART_TYPE_CHORD: for (var f = e.name, a = 0, o = g.length; o > a; a++) if ("sector" === g[a].type && l.get(g[a], "name") == f) { this._curTarget = g[a]; var y = this._curTarget.style, b = (y.startAngle + y.endAngle) / 2 * Math.PI / 180; return V = this._curTarget.style.x + Math.cos(b) * (y.r - 2), U = this._curTarget.style.y - Math.sin(b) * (y.r - 2), void this.zr.trigger(h.EVENT.MOUSEMOVE, { zrenderX: V, zrenderY: U }) } break; case s.CHART_TYPE_FORCE: for (var f = e.name, a = 0, o = g.length; o > a; a++) if ("circle" === g[a].type && l.get(g[a], "name") == f) { this._curTarget = g[a], V = this._curTarget.position[0], U = this._curTarget.position[1]; break } } null != V && null != U && (this._event = { zrenderX: V, zrenderY: U }, this.zr.addHoverShape(this._curTarget), this.zr.refreshHover(), this._showItemTrigger()) } } } }, hideTip: function() { this._hide() }, refresh: function(e) { if (this._zrHeight = this.zr.getHeight(), this._zrWidth = this.zr.getWidth(), this._lastTipShape && this._lastTipShape.tipShape.length > 0 && this.zr.delShape(this._lastTipShape.tipShape), this._lastTipShape = !1, this.shapeList.length = 2, this._lastDataIndex = -1, this._lastSeriesIndex = -1, this._lastItemTriggerId = -1, e) { this.option = e, this.option.tooltip = this.reformOption(this.option.tooltip), this.option.tooltip.textStyle = p.merge(this.option.tooltip.textStyle, this.ecTheme.textStyle), this._needAxisTrigger = !1, "axis" === this.option.tooltip.trigger && (this._needAxisTrigger = !0); for (var t = this.option.series, i = 0, n = t.length; n > i; i++) if ("axis" === this.query(t[i], "tooltip.trigger")) { this._needAxisTrigger = !0; break } this._showDelay = this.option.tooltip.showDelay, this._hideDelay = this.option.tooltip.hideDelay, this._defaultCssText = this._style(this.option.tooltip), this._setSelectedMap(), this._axisLineWidth = this.option.tooltip.axisPointer.lineStyle.width, this._enterable = this.option.tooltip.enterable, !this._enterable && this._tDom.className.indexOf(h.elementClassName) < 0 && (this._tDom.className += " " + h.elementClassName) } if (this.showing) { var a = this; setTimeout(function() { a.zr.trigger(h.EVENT.MOUSEMOVE, a.zr.handler._event) }, 50) } }, onbeforDispose: function() { this._lastTipShape && this._lastTipShape.tipShape.length > 0 && this.zr.delShape(this._lastTipShape.tipShape), clearTimeout(this._hidingTicket), clearTimeout(this._showingTicket), this.zr.un(h.EVENT.MOUSEMOVE, this._onmousemove), this.zr.un(h.EVENT.GLOBALOUT, this._onglobalout), this.hasAppend && this.dom.firstChild && this.dom.firstChild.removeChild(this._tDom), this._tDom = null }, _encodeHTML: function(e) { return String(e).replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">").replace(/"/g, """).replace(/'/g, "'") } }, p.inherits(t, i), e("../component").define("tooltip", t), t }), define("echarts/component/legend", ["require", "./base", "zrender/shape/Text", "zrender/shape/Rectangle", "zrender/shape/Sector", "../util/shape/Icon", "../util/shape/Candle", "../config", "zrender/tool/util", "zrender/tool/area", "../component"], function(e) { function t(e, t, n, a, o) { if (!this.query(a, "legend.data")) return void console.error("option.legend.data has not been defined."); i.call(this, e, t, n, a, o); var r = this; r._legendSelected = function(e) { r.__legendSelected(e) }, r._dispatchHoverLink = function(e) { return r.__dispatchHoverLink(e) }, this._colorIndex = 0, this._colorMap = {}, this._selectedMap = {}, this._hasDataMap = {}, this.refresh(a) } var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Rectangle"), o = e("zrender/shape/Sector"), r = e("../util/shape/Icon"), s = e("../util/shape/Candle"), l = e("../config"); l.legend = { zlevel: 0, z: 4, show: !0, orient: "horizontal", x: "center", y: "top", backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, padding: 5, itemGap: 10, itemWidth: 20, itemHeight: 14, textStyle: { color: "#333" }, selectedMode: !0 }; var h = e("zrender/tool/util"), d = e("zrender/tool/area"); t.prototype = { type: l.COMPONENT_TYPE_LEGEND, _buildShape: function() { if (this.legendOption.show) { this._itemGroupLocation = this._getItemGroupLocation(), this._buildBackground(), this._buildItem(); for (var e = 0, t = this.shapeList.length; t > e; e++) this.zr.addShape(this.shapeList[e]) } }, _buildItem: function() { var e, t, i, a, o, s, l, c, m = this.legendOption.data, p = m.length, u = this.legendOption.textStyle, V = this.zr.getWidth(), U = this.zr.getHeight(), g = this._itemGroupLocation.x, f = this._itemGroupLocation.y, y = this.legendOption.itemWidth, b = this.legendOption.itemHeight, _ = this.legendOption.itemGap; "vertical" === this.legendOption.orient && "right" === this.legendOption.x && (g = this._itemGroupLocation.x + this._itemGroupLocation.width - y); for (var x = 0; p > x; x++) o = h.merge(m[x].textStyle || {}, u), s = this.getFont(o), e = this._getName(m[x]), l = this._getFormatterName(e), "" !== e ? (t = m[x].icon || this._getSomethingByName(e).type, c = this.getColor(e), "horizontal" === this.legendOption.orient ? 200 > V - g && y + 5 + d.getTextWidth(l, s) + (x === p - 1 || "" === m[x + 1] ? 0 : _) >= V - g && (g = this._itemGroupLocation.x, f += b + _) : 200 > U - f && b + (x === p - 1 || "" === m[x + 1] ? 0 : _) >= U - f && ("right" === this.legendOption.x ? g -= this._itemGroupLocation.maxWidth + _ : g += this._itemGroupLocation.maxWidth + _, f = this._itemGroupLocation.y), i = this._getItemShapeByType(g, f, y, b, this._selectedMap[e] && this._hasDataMap[e] ? c : "#ccc", t, c), i._name = e, i = new r(i), a = { zlevel: this.getZlevelBase(), z: this.getZBase(), style: { x: g + y + 5, y: f + b / 2, color: this._selectedMap[e] ? "auto" === o.color ? c : o.color : "#ccc", text: l, textFont: s, textBaseline: "middle" }, highlightStyle: { color: c, brushType: "fill" }, hoverable: !!this.legendOption.selectedMode, clickable: !!this.legendOption.selectedMode }, "vertical" === this.legendOption.orient && "right" === this.legendOption.x && (a.style.x -= y + 10, a.style.textAlign = "right"), a._name = e, a = new n(a), this.legendOption.selectedMode && (i.onclick = a.onclick = this._legendSelected, i.onmouseover = a.onmouseover = this._dispatchHoverLink, i.hoverConnect = a.id, a.hoverConnect = i.id), this.shapeList.push(i), this.shapeList.push(a), "horizontal" === this.legendOption.orient ? g += y + 5 + d.getTextWidth(l, s) + _ : f += b + _) : "horizontal" === this.legendOption.orient ? (g = this._itemGroupLocation.x, f += b + _) : ("right" === this.legendOption.x ? g -= this._itemGroupLocation.maxWidth + _ : g += this._itemGroupLocation.maxWidth + _, f = this._itemGroupLocation.y); "horizontal" === this.legendOption.orient && "center" === this.legendOption.x && f != this._itemGroupLocation.y && this._mLineOptimize() }, _getName: function(e) { return "undefined" != typeof e.name ? e.name : e }, _getFormatterName: function(e) { var t, i = this.legendOption.formatter; return t = "function" == typeof i ? i.call(this.myChart, e) : "string" == typeof i ? i.replace("{name}", e) : e }, _getFormatterNameFromData: function(e) { var t = this._getName(e); return this._getFormatterName(t) }, _mLineOptimize: function() { for (var e = [], t = this._itemGroupLocation.x, i = 2, n = this.shapeList.length; n > i; i++) this.shapeList[i].style.x === t ? e.push((this._itemGroupLocation.width - (this.shapeList[i - 1].style.x + d.getTextWidth(this.shapeList[i - 1].style.text, this.shapeList[i - 1].style.textFont) - t)) / 2) : i === n - 1 && e.push((this._itemGroupLocation.width - (this.shapeList[i].style.x + d.getTextWidth(this.shapeList[i].style.text, this.shapeList[i].style.textFont) - t)) / 2); for (var a = -1, i = 1, n = this.shapeList.length; n > i; i++) this.shapeList[i].style.x === t && a++, 0 !== e[a] && (this.shapeList[i].style.x += e[a]) }, _buildBackground: function() { var e = this.reformCssArray(this.legendOption.padding); this.shapeList.push(new a({ zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this._itemGroupLocation.x - e[3], y: this._itemGroupLocation.y - e[0], width: this._itemGroupLocation.width + e[3] + e[1], height: this._itemGroupLocation.height + e[0] + e[2], brushType: 0 === this.legendOption.borderWidth ? "fill" : "both", color: this.legendOption.backgroundColor, strokeColor: this.legendOption.borderColor, lineWidth: this.legendOption.borderWidth } })) }, _getItemGroupLocation: function() { var e = this.legendOption.data, t = e.length, i = this.legendOption.itemGap, n = this.legendOption.itemWidth + 5, a = this.legendOption.itemHeight, o = this.legendOption.textStyle, r = this.getFont(o), s = 0, l = 0, c = this.reformCssArray(this.legendOption.padding), m = this.zr.getWidth() - c[1] - c[3], p = this.zr.getHeight() - c[0] - c[2], u = 0, V = 0; if ("horizontal" === this.legendOption.orient) { l = a; for (var U = 0; t > U; U++) if ("" !== this._getName(e[U])) { var g = d.getTextWidth(this._getFormatterNameFromData(e[U]), e[U].textStyle ? this.getFont(h.merge(e[U].textStyle || {}, o)) : r); u + n + g + i > m ? (u -= i, s = Math.max(s, u), l += a + i, u = 0) : (u += n + g + i, s = Math.max(s, u - i)) } else u -= i, s = Math.max(s, u), l += a + i, u = 0 } else { for (var U = 0; t > U; U++) V = Math.max(V, d.getTextWidth(this._getFormatterNameFromData(e[U]), e[U].textStyle ? this.getFont(h.merge(e[U].textStyle || {}, o)) : r)); V += n, s = V; for (var U = 0; t > U; U++) "" !== this._getName(e[U]) ? u + a + i > p ? (s += V + i, u -= i, l = Math.max(l, u), u = 0) : (u += a + i, l = Math.max(l, u - i)) : (s += V + i, u -= i, l = Math.max(l, u), u = 0) } m = this.zr.getWidth(), p = this.zr.getHeight(); var f; switch (this.legendOption.x) { case "center": f = Math.floor((m - s) / 2); break; case "left": f = c[3] + this.legendOption.borderWidth; break; case "right": f = m - s - c[1] - c[3] - 2 * this.legendOption.borderWidth; break; default: f = this.parsePercent(this.legendOption.x, m) } var y; switch (this.legendOption.y) { case "top": y = c[0] + this.legendOption.borderWidth; break; case "bottom": y = p - l - c[0] - c[2] - 2 * this.legendOption.borderWidth; break; case "center": y = Math.floor((p - l) / 2); break; default: y = this.parsePercent(this.legendOption.y, p) } return { x: f, y: y, width: s, height: l, maxWidth: V } }, _getSomethingByName: function(e) { for (var t, i = this.option.series, n = 0, a = i.length; a > n; n++) { if (i[n].name === e) return { type: i[n].type, series: i[n], seriesIndex: n, data: null, dataIndex: -1 }; if (i[n].type === l.CHART_TYPE_PIE || i[n].type === l.CHART_TYPE_RADAR || i[n].type === l.CHART_TYPE_CHORD || i[n].type === l.CHART_TYPE_FORCE || i[n].type === l.CHART_TYPE_FUNNEL || i[n].type === l.CHART_TYPE_TREEMAP) { t = i[n].categories || i[n].data || i[n].nodes; for (var o = 0, r = t.length; r > o; o++) if (t[o].name === e) return { type: i[n].type, series: i[n], seriesIndex: n, data: t[o], dataIndex: o } } } return { type: "bar", series: null, seriesIndex: -1, data: null, dataIndex: -1 } }, _getItemShapeByType: function(e, t, i, n, a, o, r) { var s, h = "#ccc" === a ? r : a, d = { zlevel: this.getZlevelBase(), z: this.getZBase(), style: { iconType: "legendicon" + o, x: e, y: t, width: i, height: n, color: a, strokeColor: a, lineWidth: 2 }, highlightStyle: { color: h, strokeColor: h, lineWidth: 1 }, hoverable: this.legendOption.selectedMode, clickable: this.legendOption.selectedMode }; if (o.match("image")) { var s = o.replace(new RegExp("^image:\\/\\/"), ""); o = "image" } switch (o) { case "line": d.style.brushType = "stroke", d.highlightStyle.lineWidth = 3; break; case "radar": case "venn": case "tree": case "treemap": case "scatter": d.highlightStyle.lineWidth = 3; break; case "k": d.style.brushType = "both", d.highlightStyle.lineWidth = 3, d.highlightStyle.color = d.style.color = this.deepQuery([this.ecTheme, l], "k.itemStyle.normal.color") || "#fff", d.style.strokeColor = "#ccc" != a ? this.deepQuery([this.ecTheme, l], "k.itemStyle.normal.lineStyle.color") || "#ff3200" : a; break; case "image": d.style.iconType = "image", d.style.image = s, "#ccc" === a && (d.style.opacity = .5) } return d }, __legendSelected: function(e) { var t = e.target._name; if ("single" === this.legendOption.selectedMode) for (var i in this._selectedMap) this._selectedMap[i] = !1; this._selectedMap[t] = !this._selectedMap[t], this.messageCenter.dispatch(l.EVENT.LEGEND_SELECTED, e.event, { selected: this._selectedMap, target: t }, this.myChart) }, __dispatchHoverLink: function(e) { this.messageCenter.dispatch(l.EVENT.LEGEND_HOVERLINK, e.event, { target: e.target._name }, this.myChart) }, refresh: function(e) { if (e) { this.option = e || this.option, this.option.legend = this.reformOption(this.option.legend), this.legendOption = this.option.legend; var t, i, n, a, o = this.legendOption.data || []; if (this.legendOption.selected) for (var r in this.legendOption.selected) this._selectedMap[r] = "undefined" != typeof this._selectedMap[r] ? this._selectedMap[r] : this.legendOption.selected[r]; for (var s = 0, h = o.length; h > s; s++) t = this._getName(o[s]), "" !== t && (i = this._getSomethingByName(t), i.series ? (this._hasDataMap[t] = !0, a = !i.data || i.type !== l.CHART_TYPE_PIE && i.type !== l.CHART_TYPE_FORCE && i.type !== l.CHART_TYPE_FUNNEL ? [i.series] : [i.data, i.series], n = this.getItemStyleColor(this.deepQuery(a, "itemStyle.normal.color"), i.seriesIndex, i.dataIndex, i.data), n && i.type != l.CHART_TYPE_K && this.setColor(t, n), this._selectedMap[t] = null != this._selectedMap[t] ? this._selectedMap[t] : !0) : this._hasDataMap[t] = !1) } this.clear(), this._buildShape() }, getRelatedAmount: function(e) { for (var t, i = 0, n = this.option.series, a = 0, o = n.length; o > a; a++) if (n[a].name === e && i++, n[a].type === l.CHART_TYPE_PIE || n[a].type === l.CHART_TYPE_RADAR || n[a].type === l.CHART_TYPE_CHORD || n[a].type === l.CHART_TYPE_FORCE || n[a].type === l.CHART_TYPE_FUNNEL) { t = n[a].type != l.CHART_TYPE_FORCE ? n[a].data : n[a].categories; for (var r = 0, s = t.length; s > r; r++) t[r].name === e && "-" != t[r].value && i++ } return i }, setColor: function(e, t) { this._colorMap[e] = t }, getColor: function(e) { return this._colorMap[e] || (this._colorMap[e] = this.zr.getColor(this._colorIndex++)), this._colorMap[e] }, hasColor: function(e) { return this._colorMap[e] ? this._colorMap[e] : !1 }, add: function(e, t) { for (var i = this.legendOption.data, n = 0, a = i.length; a > n; n++) if (this._getName(i[n]) === e) return; this.legendOption.data.push(e), this.setColor(e, t), this._selectedMap[e] = !0, this._hasDataMap[e] = !0 }, del: function(e) { for (var t = this.legendOption.data, i = 0, n = t.length; n > i; i++) if (this._getName(t[i]) === e) return this.legendOption.data.splice(i, 1) }, getItemShape: function(e) { if (null != e) for (var t, i = 0, n = this.shapeList.length; n > i; i++) if (t = this.shapeList[i], t._name === e && "text" != t.type) return t }, setItemShape: function(e, t) { for (var i, n = 0, a = this.shapeList.length; a > n; n++) i = this.shapeList[n], i._name === e && "text" != i.type && (this._selectedMap[e] || (t.style.color = "#ccc", t.style.strokeColor = "#ccc"), this.zr.modShape(i.id, t)) }, isSelected: function(e) { return "undefined" != typeof this._selectedMap[e] ? this._selectedMap[e] : !0 }, getSelectedMap: function() { return this._selectedMap }, setSelected: function(e, t) { if ("single" === this.legendOption.selectedMode) for (var i in this._selectedMap) this._selectedMap[i] = !1; this._selectedMap[e] = t, this.messageCenter.dispatch(l.EVENT.LEGEND_SELECTED, null, { selected: this._selectedMap, target: e }, this.myChart) }, onlegendSelected: function(e, t) { var i = e.selected; for (var n in i) this._selectedMap[n] != i[n] && (t.needRefresh = !0), this._selectedMap[n] = i[n] } }; var c = { line: function(e, t) { var i = t.height / 2; e.moveTo(t.x, t.y + i), e.lineTo(t.x + t.width, t.y + i) }, pie: function(e, t) { var i = t.x, n = t.y, a = t.width, r = t.height; o.prototype.buildPath(e, { x: i + a / 2, y: n + r + 2, r: r, r0: 6, startAngle: 45, endAngle: 135 }) }, eventRiver: function(e, t) { var i = t.x, n = t.y, a = t.width, o = t.height; e.moveTo(i, n + o), e.bezierCurveTo(i + a, n + o, i, n + 4, i + a, n + 4), e.lineTo(i + a, n), e.bezierCurveTo(i, n, i + a, n + o - 4, i, n + o - 4), e.lineTo(i, n + o) }, k: function(e, t) { var i = t.x, n = t.y, a = t.width, o = t.height; s.prototype.buildPath(e, { x: i + a / 2, y: [n + 1, n + 1, n + o - 6, n + o], width: a - 6 }) }, bar: function(e, t) { var i = t.x, n = t.y + 1, a = t.width, o = t.height - 2, r = 3; e.moveTo(i + r, n), e.lineTo(i + a - r, n), e.quadraticCurveTo(i + a, n, i + a, n + r), e.lineTo(i + a, n + o - r), e.quadraticCurveTo(i + a, n + o, i + a - r, n + o), e.lineTo(i + r, n + o), e.quadraticCurveTo(i, n + o, i, n + o - r), e.lineTo(i, n + r), e.quadraticCurveTo(i, n, i + r, n) }, force: function(e, t) { r.prototype.iconLibrary.circle(e, t) }, radar: function(e, t) { var i = 6, n = t.x + t.width / 2, a = t.y + t.height / 2, o = t.height / 2, r = 2 * Math.PI / i, s = -Math.PI / 2, l = n + o * Math.cos(s), h = a + o * Math.sin(s); e.moveTo(l, h), s += r; for (var d = 0, c = i - 1; c > d; d++) e.lineTo(n + o * Math.cos(s), a + o * Math.sin(s)), s += r; e.lineTo(l, h) } }; c.chord = c.pie, c.map = c.bar; for (var m in c) r.prototype.iconLibrary["legendicon" + m] = c[m]; return h.inherits(t, i), e("../component").define("legend", t), t }), define("echarts/util/ecData", [], function() { function e(e, t, i, n, a, o, r, s) { var l; return "undefined" != typeof n && (l = null == n.value ? n : n.value), e._echartsData = { _series: t, _seriesIndex: i, _data: n, _dataIndex: a, _name: o, _value: l, _special: r, _special2: s }, e._echartsData } function t(e, t) { var i = e._echartsData; if (!t) return i; switch (t) { case "series": case "seriesIndex": case "data": case "dataIndex": case "name": case "value": case "special": case "special2": return i && i["_" + t] } return null } function i(e, t, i) { switch (e._echartsData = e._echartsData || {}, t) { case "series": case "seriesIndex": case "data": case "dataIndex": case "name": case "value": case "special": case "special2": e._echartsData["_" + t] = i } } function n(e, t) { t._echartsData = { _series: e._echartsData._series, _seriesIndex: e._echartsData._seriesIndex, _data: e._echartsData._data, _dataIndex: e._echartsData._dataIndex, _name: e._echartsData._name, _value: e._echartsData._value, _special: e._echartsData._special, _special2: e._echartsData._special2 } } return { pack: e, set: i, get: t, clone: n } }), define("echarts/chart", [], function() { var e = {}, t = {}; return e.define = function(i, n) { return t[i] = n, e }, e.get = function(e) { return t[e] }, e }), define("zrender/tool/color", ["require", "../tool/util"], function(e) { function t(e) { D = e } function i() { D = N } function n(e, t) { return e = 0 | e, t = t || D, t[e % t.length] } function a(e) { B = e } function o() { H = B } function r() { return B } function s(e, t, i, n, a, o, r) { O || (O = P.getContext()); for (var s = O.createRadialGradient(e, t, i, n, a, o), l = 0, h = r.length; h > l; l++) s.addColorStop(r[l][0], r[l][1]); return s.__nonRecursion = !0, s } function l(e, t, i, n, a) { O || (O = P.getContext()); for (var o = O.createLinearGradient(e, t, i, n), r = 0, s = a.length; s > r; r++) o.addColorStop(a[r][0], a[r][1]); return o.__nonRecursion = !0, o } function h(e, t, i) { e = u(e), t = u(t), e = S(e), t = S(t); for (var n = [], a = (t[0] - e[0]) / i, o = (t[1] - e[1]) / i, r = (t[2] - e[2]) / i, s = (t[3] - e[3]) / i, l = 0, h = e[0], d = e[1], m = e[2], p = e[3]; i > l; l++) n[l] = c([T(Math.floor(h), [0, 255]), T(Math.floor(d), [0, 255]), T(Math.floor(m), [0, 255]), p.toFixed(4) - 0], "rgba"), h += a, d += o, m += r, p += s; return h = t[0], d = t[1], m = t[2], p = t[3], n[l] = c([h, d, m, p], "rgba"), n } function d(e, t) { var i = [], n = e.length; if (void 0 === t && (t = 20), 1 === n) i = h(e[0], e[0], t); else if (n > 1) for (var a = 0, o = n - 1; o > a; a++) { var r = h(e[a], e[a + 1], t); o - 1 > a && r.pop(), i = i.concat(r) } return i } function c(e, t) { if (t = t || "rgb", e && (3 === e.length || 4 === e.length)) { if (e = C(e, function(e) { return e > 1 ? Math.ceil(e) : e }), t.indexOf("hex") > -1) return "#" + ((1 << 24) + (e[0] << 16) + (e[1] << 8) + +e[2]).toString(16).slice(1); if (t.indexOf("hs") > -1) { var i = C(e.slice(1, 3), function(e) { return e + "%" }); e[1] = i[0], e[2] = i[1] } return t.indexOf("a") > -1 ? (3 === e.length && e.push(1), e[3] = T(e[3], [0, 1]), t + "(" + e.slice(0, 4).join(",") + ")") : t + "(" + e.slice(0, 3).join(",") + ")" } } function m(e) { e = v(e), e.indexOf("rgba") < 0 && (e = u(e)); var t = [], i = 0; return e.replace(/[\d.]+/g, function(e) { e = 3 > i ? 0 | e : +e, t[i++] = e }), t } function p(e, t) { if (!E(e)) return e; var i = S(e), n = i[3]; return "undefined" == typeof n && (n = 1), e.indexOf("hsb") > -1 ? i = z(i) : e.indexOf("hsl") > -1 && (i = A(i)), t.indexOf("hsb") > -1 || t.indexOf("hsv") > -1 ? i = F(i) : t.indexOf("hsl") > -1 && (i = J(i)), i[3] = n, c(i, t) } function u(e) { return p(e, "rgba") } function V(e) { return p(e, "rgb") } function U(e) { return p(e, "hex") } function g(e) { return p(e, "hsva") } function f(e) { return p(e, "hsv") } function y(e) { return p(e, "hsba") } function b(e) { return p(e, "hsb") } function _(e) { return p(e, "hsla") } function x(e) { return p(e, "hsl") } function k(e) { for (var t in G) if (U(G[t]) === U(e)) return t; return null } function v(e) { return String(e).replace(/\s+/g, "") } function L(e) { if (G[e] && (e = G[e]), e = v(e), e = e.replace(/hsv/i, "hsb"), /^#[\da-f]{3}$/i.test(e)) { e = parseInt(e.slice(1), 16); var t = (3840 & e) << 8, i = (240 & e) << 4, n = 15 & e; e = "#" + ((1 << 24) + (t << 4) + t + (i << 4) + i + (n << 4) + n).toString(16).slice(1) } return e } function w(e, t) { if (!E(e)) return e; var i = t > 0 ? 1 : -1; "undefined" == typeof t && (t = 0), t = Math.abs(t) > 1 ? 1 : Math.abs(t), e = V(e); for (var n = S(e), a = 0; 3 > a; a++) n[a] = 1 === i ? n[a] * (1 - t) | 0 : (255 - n[a]) * t + n[a] | 0; return "rgb(" + n.join(",") + ")" } function W(e) { if (!E(e)) return e; var t = S(u(e)); return t = C(t, function(e) { return 255 - e }), c(t, "rgb") } function X(e, t, i) { if (!E(e) || !E(t)) return e; "undefined" == typeof i && (i = .5), i = 1 - T(i, [0, 1]); for (var n = 2 * i - 1, a = S(u(e)), o = S(u(t)), r = a[3] - o[3], s = ((n * r === -1 ? n : (n + r) / (1 + n * r)) + 1) / 2, l = 1 - s, h = [], d = 0; 3 > d; d++) h[d] = a[d] * s + o[d] * l; var m = a[3] * i + o[3] * (1 - i); return m = Math.max(0, Math.min(1, m)), 1 === a[3] && 1 === o[3] ? c(h, "rgb") : (h[3] = m, c(h, "rgba")) } function I() { return "#" + (Math.random().toString(16) + "0000").slice(2, 8) } function S(e) { e = L(e); var t = e.match(R); if (null === t) throw new Error("The color format error"); var i, n, a, o = []; if (t[2]) i = t[2].replace("#", "").split(""), a = [i[0] + i[1], i[2] + i[3], i[4] + i[5]], o = C(a, function(e) { return T(parseInt(e, 16), [0, 255]) }); else if (t[4]) { var r = t[4].split(","); n = r[3], a = r.slice(0, 3), o = C(a, function(e) { return e = Math.floor(e.indexOf("%") > 0 ? 2.55 * parseInt(e, 0) : e), T(e, [0, 255]) }), "undefined" != typeof n && o.push(T(parseFloat(n), [0, 1])) } else if (t[5] || t[6]) { var s = (t[5] || t[6]).split(","), l = parseInt(s[0], 0) / 360, h = s[1], d = s[2]; n = s[3], o = C([h, d], function(e) { return T(parseFloat(e) / 100, [0, 1]) }), o.unshift(l), "undefined" != typeof n && o.push(T(parseFloat(n), [0, 1])) } return o } function K(e, t) { if (!E(e)) return e; null === t && (t = 1); var i = S(u(e)); return i[3] = T(Number(t).toFixed(4), [0, 1]), c(i, "rgba") } function C(e, t) { if ("function" != typeof t) throw new TypeError; for (var i = e ? e.length : 0, n = 0; i > n; n++) e[n] = t(e[n]); return e } function T(e, t) { return e <= t[0] ? e = t[0] : e >= t[1] && (e = t[1]), e } function E(e) { return e instanceof Array || "string" == typeof e } function z(e) { var t, i, n, a = e[0], o = e[1], r = e[2]; if (0 === o) t = 255 * r, i = 255 * r, n = 255 * r; else { var s = 6 * a; 6 === s && (s = 0); var l = 0 | s, h = r * (1 - o), d = r * (1 - o * (s - l)), c = r * (1 - o * (1 - (s - l))), m = 0, p = 0, u = 0; 0 === l ? (m = r, p = c, u = h) : 1 === l ? (m = d, p = r, u = h) : 2 === l ? (m = h, p = r, u = c) : 3 === l ? (m = h, p = d, u = r) : 4 === l ? (m = c, p = h, u = r) : (m = r, p = h, u = d), t = 255 * m, i = 255 * p, n = 255 * u } return [t, i, n] } function A(e) { var t, i, n, a = e[0], o = e[1], r = e[2]; if (0 === o) t = 255 * r, i = 255 * r, n = 255 * r; else { var s; s = .5 > r ? r * (1 + o) : r + o - o * r; var l = 2 * r - s; t = 255 * M(l, s, a + 1 / 3), i = 255 * M(l, s, a), n = 255 * M(l, s, a - 1 / 3) } return [t, i, n] } function M(e, t, i) { return 0 > i && (i += 1), i > 1 && (i -= 1), 1 > 6 * i ? e + 6 * (t - e) * i : 1 > 2 * i ? t : 2 > 3 * i ? e + (t - e) * (2 / 3 - i) * 6 : e } function F(e) { var t, i, n = e[0] / 255, a = e[1] / 255, o = e[2] / 255, r = Math.min(n, a, o), s = Math.max(n, a, o), l = s - r, h = s; if (0 === l) t = 0, i = 0; else { i = l / s; var d = ((s - n) / 6 + l / 2) / l, c = ((s - a) / 6 + l / 2) / l, m = ((s - o) / 6 + l / 2) / l; n === s ? t = m - c : a === s ? t = 1 / 3 + d - m : o === s && (t = 2 / 3 + c - d), 0 > t && (t += 1), t > 1 && (t -= 1) } return t = 360 * t, i = 100 * i, h = 100 * h, [t, i, h] } function J(e) { var t, i, n = e[0] / 255, a = e[1] / 255, o = e[2] / 255, r = Math.min(n, a, o), s = Math.max(n, a, o), l = s - r, h = (s + r) / 2; if (0 === l) t = 0, i = 0; else { i = .5 > h ? l / (s + r) : l / (2 - s - r); var d = ((s - n) / 6 + l / 2) / l, c = ((s - a) / 6 + l / 2) / l, m = ((s - o) / 6 + l / 2) / l; n === s ? t = m - c : a === s ? t = 1 / 3 + d - m : o === s && (t = 2 / 3 + c - d), 0 > t && (t += 1), t > 1 && (t -= 1) } return t = 360 * t, i = 100 * i, h = 100 * h, [t, i, h] } var O, P = e("../tool/util"), D = ["#ff9277", " #dddd00", " #ffc877", " #bbe3ff", " #d5ffbb", "#bbbbff", " #ddb000", " #b0dd00", " #e2bbff", " #ffbbe3", "#ff7777", " #ff9900", " #83dd00", " #77e3ff", " #778fff", "#c877ff", " #ff77ab", " #ff6600", " #aa8800", " #77c7ff", "#ad77ff", " #ff77ff", " #dd0083", " #777700", " #00aa00", "#0088aa", " #8400dd", " #aa0088", " #dd0000", " #772e00"], N = D, B = "rgba(255,255,0,0.5)", H = B, R = /^\s*((#[a-f\d]{6})|(#[a-f\d]{3})|rgba?\(\s*([\d\.]+%?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+%?)?)\s*\)|hsba?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+)?)%?\s*\)|hsla?\(\s*([\d\.]+(?:deg|\xb0|%)?\s*,\s*[\d\.]+%?\s*,\s*[\d\.]+%?(?:\s*,\s*[\d\.]+)?)%?\s*\))\s*$/i, G = { aliceblue: "#f0f8ff", antiquewhite: "#faebd7", aqua: "#0ff", aquamarine: "#7fffd4", azure: "#f0ffff", beige: "#f5f5dc", bisque: "#ffe4c4", black: "#000", blanchedalmond: "#ffebcd", blue: "#00f", blueviolet: "#8a2be2", brown: "#a52a2a", burlywood: "#deb887", cadetblue: "#5f9ea0", chartreuse: "#7fff00", chocolate: "#d2691e", coral: "#ff7f50", cornflowerblue: "#6495ed", cornsilk: "#fff8dc", crimson: "#dc143c", cyan: "#0ff", darkblue: "#00008b", darkcyan: "#008b8b", darkgoldenrod: "#b8860b", darkgray: "#a9a9a9", darkgrey: "#a9a9a9", darkgreen: "#006400", darkkhaki: "#bdb76b", darkmagenta: "#8b008b", darkolivegreen: "#556b2f", darkorange: "#ff8c00", darkorchid: "#9932cc", darkred: "#8b0000", darksalmon: "#e9967a", darkseagreen: "#8fbc8f", darkslateblue: "#483d8b", darkslategray: "#2f4f4f", darkslategrey: "#2f4f4f", darkturquoise: "#00ced1", darkviolet: "#9400d3", deeppink: "#ff1493", deepskyblue: "#00bfff", dimgray: "#696969", dimgrey: "#696969", dodgerblue: "#1e90ff", firebrick: "#b22222", floralwhite: "#fffaf0", forestgreen: "#228b22", fuchsia: "#f0f", gainsboro: "#dcdcdc", ghostwhite: "#f8f8ff", gold: "#ffd700", goldenrod: "#daa520", gray: "#808080", grey: "#808080", green: "#008000", greenyellow: "#adff2f", honeydew: "#f0fff0", hotpink: "#ff69b4", indianred: "#cd5c5c", indigo: "#4b0082", ivory: "#fffff0", khaki: "#f0e68c", lavender: "#e6e6fa", lavenderblush: "#fff0f5", lawngreen: "#7cfc00", lemonchiffon: "#fffacd", lightblue: "#add8e6", lightcoral: "#f08080", lightcyan: "#e0ffff", lightgoldenrodyellow: "#fafad2", lightgray: "#d3d3d3", lightgrey: "#d3d3d3", lightgreen: "#90ee90", lightpink: "#ffb6c1", lightsalmon: "#ffa07a", lightseagreen: "#20b2aa", lightskyblue: "#87cefa", lightslategray: "#789", lightslategrey: "#789", lightsteelblue: "#b0c4de", lightyellow: "#ffffe0", lime: "#0f0", limegreen: "#32cd32", linen: "#faf0e6", magenta: "#f0f", maroon: "#800000", mediumaquamarine: "#66cdaa", mediumblue: "#0000cd", mediumorchid: "#ba55d3", mediumpurple: "#9370d8", mediumseagreen: "#3cb371", mediumslateblue: "#7b68ee", mediumspringgreen: "#00fa9a", mediumturquoise: "#48d1cc", mediumvioletred: "#c71585", midnightblue: "#191970", mintcream: "#f5fffa", mistyrose: "#ffe4e1", moccasin: "#ffe4b5", navajowhite: "#ffdead", navy: "#000080", oldlace: "#fdf5e6", olive: "#808000", olivedrab: "#6b8e23", orange: "#ffa500", orangered: "#ff4500", orchid: "#da70d6", palegoldenrod: "#eee8aa", palegreen: "#98fb98", paleturquoise: "#afeeee", palevioletred: "#d87093", papayawhip: "#ffefd5", peachpuff: "#ffdab9", peru: "#cd853f", pink: "#ffc0cb", plum: "#dda0dd", powderblue: "#b0e0e6", purple: "#800080", red: "#f00", rosybrown: "#bc8f8f", royalblue: "#4169e1", saddlebrown: "#8b4513", salmon: "#fa8072", sandybrown: "#f4a460", seagreen: "#2e8b57", seashell: "#fff5ee", sienna: "#a0522d", silver: "#c0c0c0", skyblue: "#87ceeb", slateblue: "#6a5acd", slategray: "#708090", slategrey: "#708090", snow: "#fffafa", springgreen: "#00ff7f", steelblue: "#4682b4", tan: "#d2b48c", teal: "#008080", thistle: "#d8bfd8", tomato: "#ff6347", turquoise: "#40e0d0", violet: "#ee82ee", wheat: "#f5deb3", white: "#fff", whitesmoke: "#f5f5f5", yellow: "#ff0", yellowgreen: "#9acd32" }; return { customPalette: t, resetPalette: i, getColor: n, getHighlightColor: r, customHighlight: a, resetHighlight: o, getRadialGradient: s, getLinearGradient: l, getGradientColors: d, getStepColors: h, reverse: W, mix: X, lift: w, trim: v, random: I, toRGB: V, toRGBA: u, toHex: U, toHSL: x, toHSLA: _, toHSB: b, toHSBA: y, toHSV: f, toHSVA: g, toName: k, toColor: c, toArray: m, alpha: K, getData: S } }), define("echarts/component/timeline", ["require", "./base", "zrender/shape/Rectangle", "../util/shape/Icon", "../util/shape/Chain", "../config", "zrender/tool/util", "zrender/tool/area", "zrender/tool/event", "../component"], function(e) { function t(e, t, i, a, o) { n.call(this, e, t, i, a, o); var r = this; if (r._onclick = function(e) { return r.__onclick(e) }, r._ondrift = function(e, t) { return r.__ondrift(this, e, t) }, r._ondragend = function() { return r.__ondragend() }, r._setCurrentOption = function() { var e = r.timelineOption; r.currentIndex %= e.data.length; var t = r.options[r.currentIndex] || {}; r.myChart._setOption(t, e.notMerge, !0), r.messageCenter.dispatch(s.EVENT.TIMELINE_CHANGED, null, { currentIndex: r.currentIndex, data: null != e.data[r.currentIndex].name ? e.data[r.currentIndex].name : e.data[r.currentIndex] }, r.myChart) }, r._onFrame = function() { r._setCurrentOption(), r._syncHandleShape(), r.timelineOption.autoPlay && (r.playTicket = setTimeout(function() { return r.currentIndex += 1, !r.timelineOption.loop && r.currentIndex >= r.timelineOption.data.length ? (r.currentIndex = r.timelineOption.data.length - 1, void r.stop()) : void r._onFrame() }, r.timelineOption.playInterval)) }, this.setTheme(!1), this.options = this.option.options, this.currentIndex = this.timelineOption.currentIndex % this.timelineOption.data.length, this.timelineOption.notMerge || 0 === this.currentIndex || (this.options[this.currentIndex] = l.merge(this.options[this.currentIndex], this.options[0])), this.timelineOption.show && (this._buildShape(), this._syncHandleShape()), this._setCurrentOption(), this.timelineOption.autoPlay) { var r = this; this.playTicket = setTimeout(function() { r.play() }, null != this.ecTheme.animationDuration ? this.ecTheme.animationDuration : s.animationDuration) } } function i(e, t) { var i = 2, n = t.x + i, a = t.y + i + 2, r = t.width - i, s = t.height - i, l = t.symbol; if ("last" === l) e.moveTo(n + r - 2, a + s / 3), e.lineTo(n + r - 2, a), e.lineTo(n + 2, a + s / 2), e.lineTo(n + r - 2, a + s), e.lineTo(n + r - 2, a + s / 3 * 2), e.moveTo(n, a), e.lineTo(n, a); else if ("next" === l) e.moveTo(n + 2, a + s / 3), e.lineTo(n + 2, a), e.lineTo(n + r - 2, a + s / 2), e.lineTo(n + 2, a + s), e.lineTo(n + 2, a + s / 3 * 2), e.moveTo(n, a), e.lineTo(n, a); else if ("play" === l) if ("stop" === t.status) e.moveTo(n + 2, a), e.lineTo(n + r - 2, a + s / 2), e.lineTo(n + 2, a + s), e.lineTo(n + 2, a); else { var h = "both" === t.brushType ? 2 : 3; e.rect(n + 2, a, h, s), e.rect(n + r - h - 2, a, h, s) } else if (l.match("image")) { var d = ""; d = l.replace(new RegExp("^image:\\/\\/"), ""), l = o.prototype.iconLibrary.image, l(e, { x: n, y: a, width: r, height: s, image: d }) } } var n = e("./base"), a = e("zrender/shape/Rectangle"), o = e("../util/shape/Icon"), r = e("../util/shape/Chain"), s = e("../config"); s.timeline = { zlevel: 0, z: 4, show: !0, type: "time", notMerge: !1, realtime: !0, x: 80, x2: 80, y2: 0, height: 50, backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, padding: 5, controlPosition: "left", autoPlay: !1, loop: !0, playInterval: 2e3, lineStyle: { width: 1, color: "#666", type: "dashed" }, label: { show: !0, interval: "auto", rotate: 0, textStyle: { color: "#333" } }, checkpointStyle: { symbol: "auto", symbolSize: "auto", color: "auto", borderColor: "auto", borderWidth: "auto", label: { show: !1, textStyle: { color: "auto" } } }, controlStyle: { itemSize: 15, itemGap: 5, normal: { color: "#333" }, emphasis: { color: "#1e90ff" } }, symbol: "emptyDiamond", symbolSize: 4, currentIndex: 0 }; var l = e("zrender/tool/util"), h = e("zrender/tool/area"), d = e("zrender/tool/event"); return t.prototype = { type: s.COMPONENT_TYPE_TIMELINE, _buildShape: function() { if (this._location = this._getLocation(), this._buildBackground(), this._buildControl(), this._chainPoint = this._getChainPoint(), this.timelineOption.label.show) for (var e = this._getInterval(), t = 0, i = this._chainPoint.length; i > t; t += e) this._chainPoint[t].showLabel = !0; this._buildChain(), this._buildHandle(); for (var t = 0, n = this.shapeList.length; n > t; t++) this.zr.addShape(this.shapeList[t]) }, _getLocation: function() { var e, t = this.timelineOption, i = this.reformCssArray(this.timelineOption.padding), n = this.zr.getWidth(), a = this.parsePercent(t.x, n), o = this.parsePercent(t.x2, n); null == t.width ? (e = n - a - o, o = n - o) : (e = this.parsePercent(t.width, n), o = a + e); var r, s, l = this.zr.getHeight(), h = this.parsePercent(t.height, l); return null != t.y ? (r = this.parsePercent(t.y, l), s = r + h) : (s = l - this.parsePercent(t.y2, l), r = s - h), { x: a + i[3], y: r + i[0], x2: o - i[1], y2: s - i[2], width: e - i[1] - i[3], height: h - i[0] - i[2] } }, _getReformedLabel: function(e) { var t = this.timelineOption, i = null != t.data[e].name ? t.data[e].name : t.data[e], n = t.data[e].formatter || t.label.formatter; return n && ("function" == typeof n ? i = n.call(this.myChart, i) : "string" == typeof n && (i = n.replace("{value}", i))), i }, _getInterval: function() { var e = this._chainPoint, t = this.timelineOption, i = t.label.interval; if ("auto" === i) { var n = t.label.textStyle.fontSize, a = t.data, o = t.data.length; if (o > 3) { var r, s, l = !1; for (i = 0; !l && o > i;) { i++, l = !0; for (var d = i; o > d; d += i) { if (r = e[d].x - e[d - i].x, 0 !== t.label.rotate) s = n; else if (a[d].textStyle) s = h.getTextWidth(e[d].name, e[d].textFont); else { var c = e[d].name + "", m = (c.match(/\w/g) || "").length, p = c.length - m; s = m * n * 2 / 3 + p * n } if (s > r) { l = !1; break } } } } else i = 1 } else i = i - 0 + 1; return i }, _getChainPoint: function() { function e(e) { return null != h[e].name ? h[e].name : h[e] + "" } var t, i = this.timelineOption, n = i.symbol.toLowerCase(), a = i.symbolSize, o = i.label.rotate, r = i.label.textStyle, s = this.getFont(r), h = i.data, d = this._location.x, c = this._location.y + this._location.height / 4 * 3, m = this._location.x2 - this._location.x, p = h.length, u = []; if (p > 1) { var V = m / p; if (V = V > 50 ? 50 : 20 > V ? 5 : V, m -= 2 * V, "number" === i.type) for (var U = 0; p > U; U++) u.push(d + V + m / (p - 1) * U); else { u[0] = new Date(e(0).replace(/-/g, "/")), u[p - 1] = new Date(e(p - 1).replace(/-/g, "/")) - u[0]; for (var U = 1; p > U; U++) u[U] = d + V + m * (new Date(e(U).replace(/-/g, "/")) - u[0]) / u[p - 1]; u[0] = d + V } } else u.push(d + m / 2); for (var g, f, y, b, _, x = [], U = 0; p > U; U++) d = u[U], g = h[U].symbol && h[U].symbol.toLowerCase() || n, g.match("empty") ? (g = g.replace("empty", ""), y = !0) : y = !1, g.match("star") && (f = g.replace("star", "") - 0 || 5, g = "star"), t = h[U].textStyle ? l.merge(h[U].textStyle || {}, r) : r, b = t.align || "center", o ? (b = o > 0 ? "right" : "left", _ = [o * Math.PI / 180, d, c - 5]) : _ = !1, x.push({ x: d, n: f, isEmpty: y, symbol: g, symbolSize: h[U].symbolSize || a, color: h[U].color, borderColor: h[U].borderColor, borderWidth: h[U].borderWidth, name: this._getReformedLabel(U), textColor: t.color, textAlign: b, textBaseline: t.baseline || "middle", textX: d, textY: c - (o ? 5 : 0), textFont: h[U].textStyle ? this.getFont(t) : s, rotation: _, showLabel: !1 }); return x }, _buildBackground: function() { var e = this.timelineOption, t = this.reformCssArray(this.timelineOption.padding), i = this._location.width, n = this._location.height; (0 !== e.borderWidth || "rgba(0,0,0,0)" != e.backgroundColor.replace(/\s/g, "")) && this.shapeList.push(new a({ zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this._location.x - t[3], y: this._location.y - t[0], width: i + t[1] + t[3], height: n + t[0] + t[2], brushType: 0 === e.borderWidth ? "fill" : "both", color: e.backgroundColor, strokeColor: e.borderColor, lineWidth: e.borderWidth } })) }, _buildControl: function() { var e = this, t = this.timelineOption, i = t.lineStyle, n = t.controlStyle; if ("none" !== t.controlPosition) { var a, r = n.itemSize, s = n.itemGap; "left" === t.controlPosition ? (a = this._location.x, this._location.x += 3 * (r + s)) : (a = this._location.x2 - (3 * (r + s) - s), this._location.x2 -= 3 * (r + s)); var h = this._location.y, d = { zlevel: this.getZlevelBase(), z: this.getZBase() + 1, style: { iconType: "timelineControl", symbol: "last", x: a, y: h, width: r, height: r, brushType: "stroke", color: n.normal.color, strokeColor: n.normal.color, lineWidth: i.width }, highlightStyle: { color: n.emphasis.color, strokeColor: n.emphasis.color, lineWidth: i.width + 1 }, clickable: !0 }; this._ctrLastShape = new o(d), this._ctrLastShape.onclick = function() { e.last() }, this.shapeList.push(this._ctrLastShape), a += r + s, this._ctrPlayShape = new o(l.clone(d)), this._ctrPlayShape.style.brushType = "fill", this._ctrPlayShape.style.symbol = "play", this._ctrPlayShape.style.status = this.timelineOption.autoPlay ? "playing" : "stop", this._ctrPlayShape.style.x = a, this._ctrPlayShape.onclick = function() { "stop" === e._ctrPlayShape.style.status ? e.play() : e.stop() }, this.shapeList.push(this._ctrPlayShape), a += r + s, this._ctrNextShape = new o(l.clone(d)), this._ctrNextShape.style.symbol = "next", this._ctrNextShape.style.x = a, this._ctrNextShape.onclick = function() { e.next() }, this.shapeList.push(this._ctrNextShape) } }, _buildChain: function() { var e = this.timelineOption, t = e.lineStyle; this._timelineShae = { zlevel: this.getZlevelBase(), z: this.getZBase(), style: { x: this._location.x, y: this.subPixelOptimize(this._location.y, t.width), width: this._location.x2 - this._location.x, height: this._location.height, chainPoint: this._chainPoint, brushType: "both", strokeColor: t.color, lineWidth: t.width, lineType: t.type }, hoverable: !1, clickable: !0, onclick: this._onclick }, this._timelineShae = new r(this._timelineShae), this.shapeList.push(this._timelineShae) }, _buildHandle: function() { var e = this._chainPoint[this.currentIndex], t = e.symbolSize + 1; t = 5 > t ? 5 : t, this._handleShape = { zlevel: this.getZlevelBase(), z: this.getZBase() + 1, hoverable: !1, draggable: !0, style: { iconType: "diamond", n: e.n, x: e.x - t, y: this._location.y + this._location.height / 4 - t, width: 2 * t, height: 2 * t, brushType: "both", textPosition: "specific", textX: e.x, textY: this._location.y - this._location.height / 4, textAlign: "center", textBaseline: "middle" }, highlightStyle: {}, ondrift: this._ondrift, ondragend: this._ondragend }, this._handleShape = new o(this._handleShape), this.shapeList.push(this._handleShape) }, _syncHandleShape: function() { if (this.timelineOption.show) { var e = this.timelineOption, t = e.checkpointStyle, i = this._chainPoint[this.currentIndex]; this._handleShape.style.text = t.label.show ? i.name : "", this._handleShape.style.textFont = i.textFont, this._handleShape.style.n = i.n, "auto" === t.symbol ? this._handleShape.style.iconType = "none" != i.symbol ? i.symbol : "diamond" : (this._handleShape.style.iconType = t.symbol, t.symbol.match("star") && (this._handleShape.style.n = t.symbol.replace("star", "") - 0 || 5, this._handleShape.style.iconType = "star")); var n; "auto" === t.symbolSize ? (n = i.symbolSize + 2, n = 5 > n ? 5 : n) : n = t.symbolSize - 0, this._handleShape.style.color = "auto" === t.color ? i.color ? i.color : e.controlStyle.emphasis.color : t.color, this._handleShape.style.textColor = "auto" === t.label.textStyle.color ? this._handleShape.style.color : t.label.textStyle.color, this._handleShape.highlightStyle.strokeColor = this._handleShape.style.strokeColor = "auto" === t.borderColor ? i.borderColor ? i.borderColor : "#fff" : t.borderColor, this._handleShape.style.lineWidth = "auto" === t.borderWidth ? i.borderWidth ? i.borderWidth : 0 : t.borderWidth - 0, this._handleShape.highlightStyle.lineWidth = this._handleShape.style.lineWidth + 1, this.zr.animate(this._handleShape.id, "style").when(500, { x: i.x - n, textX: i.x, y: this._location.y + this._location.height / 4 - n, width: 2 * n, height: 2 * n }).start("ExponentialOut") } }, _findChainIndex: function(e) { var t = this._chainPoint, i = t.length; if (e <= t[0].x) return 0; if (e >= t[i - 1].x) return i - 1; for (var n = 0; i - 1 > n; n++) if (e >= t[n].x && e <= t[n + 1].x) return Math.abs(e - t[n].x) < Math.abs(e - t[n + 1].x) ? n : n + 1 }, __onclick: function(e) { var t = d.getX(e.event), i = this._findChainIndex(t); return i === this.currentIndex ? !0 : (this.currentIndex = i, this.timelineOption.autoPlay && this.stop(), clearTimeout(this.playTicket), void this._onFrame()) }, __ondrift: function(e, t) { this.timelineOption.autoPlay && this.stop(); var i, n = this._chainPoint, a = n.length; e.style.x + t <= n[0].x - n[0].symbolSize ? (e.style.x = n[0].x - n[0].symbolSize, i = 0) : e.style.x + t >= n[a - 1].x - n[a - 1].symbolSize ? (e.style.x = n[a - 1].x - n[a - 1].symbolSize, i = a - 1) : (e.style.x += t, i = this._findChainIndex(e.style.x)); var o = n[i], r = o.symbolSize + 2; if (e.style.iconType = o.symbol, e.style.n = o.n, e.style.textX = e.style.x + r / 2, e.style.y = this._location.y + this._location.height / 4 - r, e.style.width = 2 * r, e.style.height = 2 * r, e.style.text = o.name, i === this.currentIndex) return !0; if (this.currentIndex = i, this.timelineOption.realtime) { clearTimeout(this.playTicket); var s = this; this.playTicket = setTimeout(function() { s._setCurrentOption() }, 200) } return !0 }, __ondragend: function() { this.isDragend = !0 }, ondragend: function(e, t) { this.isDragend && e.target && (!this.timelineOption.realtime && this._setCurrentOption(), t.dragOut = !0, t.dragIn = !0, t.needRefresh = !1, this.isDragend = !1, this._syncHandleShape()) }, last: function() { return this.timelineOption.autoPlay && this.stop(), this.currentIndex -= 1, this.currentIndex < 0 && (this.currentIndex = this.timelineOption.data.length - 1), this._onFrame(), this.currentIndex }, next: function() { return this.timelineOption.autoPlay && this.stop(), this.currentIndex += 1, this.currentIndex >= this.timelineOption.data.length && (this.currentIndex = 0), this._onFrame(), this.currentIndex }, play: function(e, t) { return this._ctrPlayShape && "playing" != this._ctrPlayShape.style.status && (this._ctrPlayShape.style.status = "playing", this.zr.modShape(this._ctrPlayShape.id), this.zr.refreshNextFrame()), this.timelineOption.autoPlay = null != t ? t : !0, this.timelineOption.autoPlay || clearTimeout(this.playTicket), this.currentIndex = null != e ? e : this.currentIndex + 1, this.currentIndex >= this.timelineOption.data.length && (this.currentIndex = 0), this._onFrame(), this.currentIndex }, stop: function() { return this._ctrPlayShape && "stop" != this._ctrPlayShape.style.status && (this._ctrPlayShape.style.status = "stop", this.zr.modShape(this._ctrPlayShape.id), this.zr.refreshNextFrame()), this.timelineOption.autoPlay = !1, clearTimeout(this.playTicket), this.currentIndex }, resize: function() { this.timelineOption.show && (this.clear(), this._buildShape(), this._syncHandleShape()) }, setTheme: function(e) { this.timelineOption = this.reformOption(l.clone(this.option.timeline)), this.timelineOption.label.textStyle = this.getTextStyle(this.timelineOption.label.textStyle), this.timelineOption.checkpointStyle.label.textStyle = this.getTextStyle(this.timelineOption.checkpointStyle.label.textStyle), this.myChart.canvasSupported || (this.timelineOption.realtime = !1), this.timelineOption.show && e && (this.clear(), this._buildShape(), this._syncHandleShape()) }, onbeforDispose: function() { clearTimeout(this.playTicket) } }, o.prototype.iconLibrary.timelineControl = i, l.inherits(t, n), e("../component").define("timeline", t), t }), define("zrender/shape/Image", ["require", "./Base", "../tool/util"], function(e) { var t = e("./Base"), i = function(e) { t.call(this, e) }; return i.prototype = { type: "image", brush: function(e, t, i) { var n = this.style || {}; t && (n = this.getHighlightStyle(n, this.highlightStyle || {})); var a = n.image, o = this; if (this._imageCache || (this._imageCache = {}), "string" == typeof a) { var r = a; this._imageCache[r] ? a = this._imageCache[r] : (a = new Image, a.onload = function() { a.onload = null, o.modSelf(), i() }, a.src = r, this._imageCache[r] = a) } if (a) { if ("IMG" == a.nodeName.toUpperCase()) if (window.ActiveXObject) { if ("complete" != a.readyState) return } else if (!a.complete) return; var s = n.width || a.width, l = n.height || a.height, h = n.x, d = n.y; if (!a.width || !a.height) return; if (e.save(), this.doClip(e), this.setContext(e, n), this.setTransform(e), n.sWidth && n.sHeight) { var c = n.sx || 0, m = n.sy || 0; e.drawImage(a, c, m, n.sWidth, n.sHeight, h, d, s, l) } else if (n.sx && n.sy) { var c = n.sx, m = n.sy, p = s - c, u = l - m; e.drawImage(a, c, m, p, u, h, d, s, l) } else e.drawImage(a, h, d, s, l); n.width || (n.width = s), n.height || (n.height = l), this.style.width || (this.style.width = s), this.style.height || (this.style.height = l), this.drawText(e, n, this.style), e.restore() } }, getRect: function(e) { return { x: e.x, y: e.y, width: e.width, height: e.height } }, clearCache: function() { this._imageCache = {} } }, e("../tool/util").inherits(i, t), i }), define("zrender/loadingEffect/Bar", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Rectangle"], function(e) { function t(e) { i.call(this, e) } var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Rectangle"); return n.inherits(t, i), t.prototype._start = function(e, t) { var i = n.merge(this.options, { textStyle: { color: "#888" }, backgroundColor: "rgba(250, 250, 250, 0.8)", effectOption: { x: 0, y: this.canvasHeight / 2 - 30, width: this.canvasWidth, height: 5, brushType: "fill", timeInterval: 100 } }), r = this.createTextShape(i.textStyle), s = this.createBackgroundShape(i.backgroundColor), l = i.effectOption, h = new o({ highlightStyle: n.clone(l) }); return h.highlightStyle.color = l.color || a.getLinearGradient(l.x, l.y, l.x + l.width, l.y + l.height, [ [0, "#ff6400"], [.5, "#ffe100"], [1, "#b1ff00"] ]), null != i.progress ? (e(s), h.highlightStyle.width = this.adjust(i.progress, [0, 1]) * i.effectOption.width, e(h), e(r), void t()) : (h.highlightStyle.width = 0, setInterval(function() { e(s), h.highlightStyle.width < l.width ? h.highlightStyle.width += 8 : h.highlightStyle.width = 0, e(h), e(r), t() }, l.timeInterval)) }, t }), define("zrender/loadingEffect/Bubble", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Circle"], function(e) { function t(e) { i.call(this, e) } var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Circle"); return n.inherits(t, i), t.prototype._start = function(e, t) { for (var i = n.merge(this.options, { textStyle: { color: "#888" }, backgroundColor: "rgba(250, 250, 250, 0.8)", effect: { n: 50, lineWidth: 2, brushType: "stroke", color: "random", timeInterval: 100 } }), r = this.createTextShape(i.textStyle), s = this.createBackgroundShape(i.backgroundColor), l = i.effect, h = l.n, d = l.brushType, c = l.lineWidth, m = [], p = this.canvasWidth, u = this.canvasHeight, V = 0; h > V; V++) { var U = "random" == l.color ? a.alpha(a.random(), .3) : l.color; m[V] = new o({ highlightStyle: { x: Math.ceil(Math.random() * p), y: Math.ceil(Math.random() * u), r: Math.ceil(40 * Math.random()), brushType: d, color: U, strokeColor: U, lineWidth: c }, animationY: Math.ceil(20 * Math.random()) }) } return setInterval(function() { e(s); for (var i = 0; h > i; i++) { var n = m[i].highlightStyle; n.y - m[i].animationY + n.r <= 0 && (m[i].highlightStyle.y = u + n.r, m[i].highlightStyle.x = Math.ceil(Math.random() * p)), m[i].highlightStyle.y -= m[i].animationY, e(m[i]) } e(r), t() }, l.timeInterval) }, t }), define("zrender/loadingEffect/DynamicLine", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Line"], function(e) { function t(e) { i.call(this, e) } var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Line"); return n.inherits(t, i), t.prototype._start = function(e, t) { for (var i = n.merge(this.options, { textStyle: { color: "#fff" }, backgroundColor: "rgba(0, 0, 0, 0.8)", effectOption: { n: 30, lineWidth: 1, color: "random", timeInterval: 100 } }), r = this.createTextShape(i.textStyle), s = this.createBackgroundShape(i.backgroundColor), l = i.effectOption, h = l.n, d = l.lineWidth, c = [], m = this.canvasWidth, p = this.canvasHeight, u = 0; h > u; u++) { var V = -Math.ceil(1e3 * Math.random()), U = Math.ceil(400 * Math.random()), g = Math.ceil(Math.random() * p), f = "random" == l.color ? a.random() : l.color; c[u] = new o({ highlightStyle: { xStart: V, yStart: g, xEnd: V + U, yEnd: g, strokeColor: f, lineWidth: d }, animationX: Math.ceil(100 * Math.random()), len: U }) } return setInterval(function() { e(s); for (var i = 0; h > i; i++) { var n = c[i].highlightStyle; n.xStart >= m && (c[i].len = Math.ceil(400 * Math.random()), n.xStart = -400, n.xEnd = -400 + c[i].len, n.yStart = Math.ceil(Math.random() * p), n.yEnd = n.yStart), n.xStart += c[i].animationX, n.xEnd += c[i].animationX, e(c[i]) } e(r), t() }, l.timeInterval) }, t }), define("zrender/loadingEffect/Ring", ["require", "./Base", "../tool/util", "../tool/color", "../shape/Ring", "../shape/Sector"], function(e) { function t(e) { i.call(this, e) } var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../shape/Ring"), r = e("../shape/Sector"); return n.inherits(t, i), t.prototype._start = function(e, t) { var i = n.merge(this.options, { textStyle: { color: "#07a" }, backgroundColor: "rgba(250, 250, 250, 0.8)", effect: { x: this.canvasWidth / 2, y: this.canvasHeight / 2, r0: 60, r: 100, color: "#bbdcff", brushType: "fill", textPosition: "inside", textFont: "normal 30px verdana", textColor: "rgba(30, 144, 255, 0.6)", timeInterval: 100 } }), s = i.effect, l = i.textStyle; null == l.x && (l.x = s.x), null == l.y && (l.y = s.y + (s.r0 + s.r) / 2 - 5); for (var h = this.createTextShape(i.textStyle), d = this.createBackgroundShape(i.backgroundColor), c = s.x, m = s.y, p = s.r0 + 6, u = s.r - 6, V = s.color, U = a.lift(V, .1), g = new o({ highlightStyle: n.clone(s) }), f = [], y = a.getGradientColors(["#ff6400", "#ffe100", "#97ff00"], 25), b = 15, _ = 240, x = 0; 16 > x; x++) f.push(new r({ highlightStyle: { x: c, y: m, r0: p, r: u, startAngle: _ - b, endAngle: _, brushType: "fill", color: U }, _color: a.getLinearGradient(c + p * Math.cos(_, !0), m - p * Math.sin(_, !0), c + p * Math.cos(_ - b, !0), m - p * Math.sin(_ - b, !0), [ [0, y[2 * x]], [1, y[2 * x + 1]] ]) })), _ -= b; _ = 360; for (var x = 0; 4 > x; x++) f.push(new r({ highlightStyle: { x: c, y: m, r0: p, r: u, startAngle: _ - b, endAngle: _, brushType: "fill", color: U }, _color: a.getLinearGradient(c + p * Math.cos(_, !0), m - p * Math.sin(_, !0), c + p * Math.cos(_ - b, !0), m - p * Math.sin(_ - b, !0), [ [0, y[2 * x + 32]], [1, y[2 * x + 33]] ]) })), _ -= b; var k = 0; if (null != i.progress) { e(d), k = 100 * this.adjust(i.progress, [0, 1]).toFixed(2) / 5, g.highlightStyle.text = 5 * k + "%", e(g); for (var x = 0; 20 > x; x++) f[x].highlightStyle.color = k > x ? f[x]._color : U, e(f[x]); return e(h), void t() } return setInterval(function() { e(d), k += k >= 20 ? -20 : 1, e(g); for (var i = 0; 20 > i; i++) f[i].highlightStyle.color = k > i ? f[i]._color : U, e(f[i]); e(h), t() }, s.timeInterval) }, t }), define("zrender/loadingEffect/Spin", ["require", "./Base", "../tool/util", "../tool/color", "../tool/area", "../shape/Sector"], function(e) { function t(e) { i.call(this, e) } var i = e("./Base"), n = e("../tool/util"), a = e("../tool/color"), o = e("../tool/area"), r = e("../shape/Sector"); return n.inherits(t, i), t.prototype._start = function(e, t) { var i = n.merge(this.options, { textStyle: { color: "#fff", textAlign: "start" }, backgroundColor: "rgba(0, 0, 0, 0.8)" }), s = this.createTextShape(i.textStyle), l = 10, h = o.getTextWidth(s.highlightStyle.text, s.highlightStyle.textFont), d = o.getTextHeight(s.highlightStyle.text, s.highlightStyle.textFont), c = n.merge(this.options.effect || {}, { r0: 9, r: 15, n: 18, color: "#fff", timeInterval: 100 }), m = this.getLocation(this.options.textStyle, h + l + 2 * c.r, Math.max(2 * c.r, d)); c.x = m.x + c.r, c.y = s.highlightStyle.y = m.y + m.height / 2, s.highlightStyle.x = c.x + c.r + l; for (var p = this.createBackgroundShape(i.backgroundColor), u = c.n, V = c.x, U = c.y, g = c.r0, f = c.r, y = c.color, b = [], _ = Math.round(180 / u), x = 0; u > x; x++) b[x] = new r({ highlightStyle: { x: V, y: U, r0: g, r: f, startAngle: _ * x * 2, endAngle: _ * x * 2 + _, color: a.alpha(y, (x + 1) / u), brushType: "fill" } }); var k = [0, V, U]; return setInterval(function() { e(p), k[0] -= .3; for (var i = 0; u > i; i++) b[i].rotation = k, e(b[i]); e(s), t() }, c.timeInterval) }, t }), define("zrender/loadingEffect/Whirling", ["require", "./Base", "../tool/util", "../tool/area", "../shape/Ring", "../shape/Droplet", "../shape/Circle"], function(e) { function t(e) { i.call(this, e) } var i = e("./Base"), n = e("../tool/util"), a = e("../tool/area"), o = e("../shape/Ring"), r = e("../shape/Droplet"), s = e("../shape/Circle"); return n.inherits(t, i), t.prototype._start = function(e, t) { var i = n.merge(this.options, { textStyle: { color: "#888", textAlign: "start" }, backgroundColor: "rgba(250, 250, 250, 0.8)" }), l = this.createTextShape(i.textStyle), h = 10, d = a.getTextWidth(l.highlightStyle.text, l.highlightStyle.textFont), c = a.getTextHeight(l.highlightStyle.text, l.highlightStyle.textFont), m = n.merge(this.options.effect || {}, { r: 18, colorIn: "#fff", colorOut: "#555", colorWhirl: "#6cf", timeInterval: 50 }), p = this.getLocation(this.options.textStyle, d + h + 2 * m.r, Math.max(2 * m.r, c)); m.x = p.x + m.r, m.y = l.highlightStyle.y = p.y + p.height / 2, l.highlightStyle.x = m.x + m.r + h; var u = this.createBackgroundShape(i.backgroundColor), V = new r({ highlightStyle: { a: Math.round(m.r / 2), b: Math.round(m.r - m.r / 6), brushType: "fill", color: m.colorWhirl } }), U = new s({ highlightStyle: { r: Math.round(m.r / 6), brushType: "fill", color: m.colorIn } }), g = new o({ highlightStyle: { r0: Math.round(m.r - m.r / 3), r: m.r, brushType: "fill", color: m.colorOut } }), f = [0, m.x, m.y]; return V.highlightStyle.x = U.highlightStyle.x = g.highlightStyle.x = f[1], V.highlightStyle.y = U.highlightStyle.y = g.highlightStyle.y = f[2], setInterval(function() { e(u), e(g), f[0] -= .3, V.rotation = f, e(V), e(U), e(l), t() }, m.timeInterval) }, t }), define("echarts/theme/macarons", [], function() { var e = { color: ["#2ec7c9", "#b6a2de", "#5ab1ef", "#ffb980", "#d87a80", "#8d98b3", "#e5cf0d", "#97b552", "#95706d", "#dc69aa", "#07a2a4", "#9a7fd1", "#588dd5", "#f5994e", "#c05050", "#59678c", "#c9ab00", "#7eb00a", "#6f5553", "#c14089"], title: { textStyle: { fontWeight: "normal", color: "#008acd" } }, dataRange: { itemWidth: 15, color: ["#5ab1ef", "#e0ffff"] }, toolbox: { color: ["#1e90ff", "#1e90ff", "#1e90ff", "#1e90ff"], effectiveColor: "#ff4500" }, tooltip: { backgroundColor: "rgba(50,50,50,0.5)", axisPointer: { type: "line", lineStyle: { color: "#008acd" }, crossStyle: { color: "#008acd" }, shadowStyle: { color: "rgba(200,200,200,0.2)" } } }, dataZoom: { dataBackgroundColor: "#efefff", fillerColor: "rgba(182,162,222,0.2)", handleColor: "#008acd" }, grid: { borderColor: "#eee" }, categoryAxis: { axisLine: { lineStyle: { color: "#008acd" } }, splitLine: { lineStyle: { color: ["#eee"] } } }, valueAxis: { axisLine: { lineStyle: { color: "#008acd" } }, splitArea: { show: !0, areaStyle: { color: ["rgba(250,250,250,0.1)", "rgba(200,200,200,0.1)"] } }, splitLine: { lineStyle: { color: ["#eee"] } } }, polar: { axisLine: { lineStyle: { color: "#ddd" } }, splitArea: { show: !0, areaStyle: { color: ["rgba(250,250,250,0.2)", "rgba(200,200,200,0.2)"] } }, splitLine: { lineStyle: { color: "#ddd" } } }, timeline: { lineStyle: { color: "#008acd" }, controlStyle: { normal: { color: "#008acd" }, emphasis: { color: "#008acd" } }, symbol: "emptyCircle", symbolSize: 3 }, bar: { itemStyle: { normal: { barBorderRadius: 5 }, emphasis: { barBorderRadius: 5 } } }, line: { smooth: !0, symbol: "emptyCircle", symbolSize: 3 }, k: { itemStyle: { normal: { color: "#d87a80", color0: "#2ec7c9", lineStyle: { color: "#d87a80", color0: "#2ec7c9" } } } }, scatter: { symbol: "circle", symbolSize: 4 }, radar: { symbol: "emptyCircle", symbolSize: 3 }, map: { itemStyle: { normal: { areaStyle: { color: "#ddd" }, label: { textStyle: { color: "#d87a80" } } }, emphasis: { areaStyle: { color: "#fe994e" } } } }, force: { itemStyle: { normal: { linkStyle: { color: "#1e90ff" } } } }, chord: { itemStyle: { normal: { borderWidth: 1, borderColor: "rgba(128, 128, 128, 0.5)", chordStyle: { lineStyle: { color: "rgba(128, 128, 128, 0.5)" } } }, emphasis: { borderWidth: 1, borderColor: "rgba(128, 128, 128, 0.5)", chordStyle: { lineStyle: { color: "rgba(128, 128, 128, 0.5)" } } } } }, gauge: { axisLine: { lineStyle: { color: [ [.2, "#2ec7c9"], [.8, "#5ab1ef"], [1, "#d87a80"] ], width: 10 } }, axisTick: { splitNumber: 10, length: 15, lineStyle: { color: "auto" } }, splitLine: { length: 22, lineStyle: { color: "auto" } }, pointer: { width: 5 } }, textStyle: { fontFamily: "微软雅黑, Arial, Verdana, sans-serif" } }; return e }), define("echarts/theme/infographic", [], function() { var e = { color: ["#C1232B", "#B5C334", "#FCCE10", "#E87C25", "#27727B", "#FE8463", "#9BCA63", "#FAD860", "#F3A43B", "#60C0DD", "#D7504B", "#C6E579", "#F4E001", "#F0805A", "#26C0C0"], title: { textStyle: { fontWeight: "normal", color: "#27727B" } }, dataRange: { x: "right", y: "center", itemWidth: 5, itemHeight: 25, color: ["#C1232B", "#FCCE10"] }, toolbox: { color: ["#C1232B", "#B5C334", "#FCCE10", "#E87C25", "#27727B", "#FE8463", "#9BCA63", "#FAD860", "#F3A43B", "#60C0DD"], effectiveColor: "#ff4500" }, tooltip: { backgroundColor: "rgba(50,50,50,0.5)", axisPointer: { type: "line", lineStyle: { color: "#27727B", type: "dashed" }, crossStyle: { color: "#27727B" }, shadowStyle: { color: "rgba(200,200,200,0.3)" } } }, dataZoom: { dataBackgroundColor: "rgba(181,195,52,0.3)", fillerColor: "rgba(181,195,52,0.2)", handleColor: "#27727B" }, grid: { borderWidth: 0 }, categoryAxis: { axisLine: { lineStyle: { color: "#27727B" } }, splitLine: { show: !1 } }, valueAxis: { axisLine: { show: !1 }, splitArea: { show: !1 }, splitLine: { lineStyle: { color: ["#ccc"], type: "dashed" } } }, polar: { axisLine: { lineStyle: { color: "#ddd" } }, splitArea: { show: !0, areaStyle: { color: ["rgba(250,250,250,0.2)", "rgba(200,200,200,0.2)"] } }, splitLine: { lineStyle: { color: "#ddd" } } }, timeline: { lineStyle: { color: "#27727B" }, controlStyle: { normal: { color: "#27727B" }, emphasis: { color: "#27727B" } }, symbol: "emptyCircle", symbolSize: 3 }, line: { itemStyle: { normal: { borderWidth: 2, borderColor: "#fff", lineStyle: { width: 3 } }, emphasis: { borderWidth: 0 } }, symbol: "circle", symbolSize: 3.5 }, k: { itemStyle: { normal: { color: "#C1232B", color0: "#B5C334", lineStyle: { width: 1, color: "#C1232B", color0: "#B5C334" } } } }, scatter: { itemStyle: { normal: { borderWidth: 1, borderColor: "rgba(200,200,200,0.5)" }, emphasis: { borderWidth: 0 } }, symbol: "star4", symbolSize: 4 }, radar: { symbol: "emptyCircle", symbolSize: 3 }, map: { itemStyle: { normal: { areaStyle: { color: "#ddd" }, label: { textStyle: { color: "#C1232B" } } }, emphasis: { areaStyle: { color: "#fe994e" }, label: { textStyle: { color: "rgb(100,0,0)" } } } } }, force: { itemStyle: { normal: { linkStyle: { color: "#27727B" } } } }, chord: { itemStyle: { normal: { borderWidth: 1, borderColor: "rgba(128, 128, 128, 0.5)", chordStyle: { lineStyle: { color: "rgba(128, 128, 128, 0.5)" } } }, emphasis: { borderWidth: 1, borderColor: "rgba(128, 128, 128, 0.5)", chordStyle: { lineStyle: { color: "rgba(128, 128, 128, 0.5)" } } } } }, gauge: { center: ["50%", "80%"], radius: "100%", startAngle: 180, endAngle: 0, axisLine: { show: !0, lineStyle: { color: [ [.2, "#B5C334"], [.8, "#27727B"], [1, "#C1232B"] ], width: "40%" } }, axisTick: { splitNumber: 2, length: 5, lineStyle: { color: "#fff" } }, axisLabel: { textStyle: { color: "#fff", fontWeight: "bolder" } }, splitLine: { length: "5%", lineStyle: { color: "#fff" } }, pointer: { width: "40%", length: "80%", color: "#fff" }, title: { offsetCenter: [0, -20], textStyle: { color: "auto", fontSize: 20 } }, detail: { offsetCenter: [0, 0], textStyle: { color: "auto", fontSize: 40 } } }, textStyle: { fontFamily: "微软雅黑, Arial, Verdana, sans-serif" } }; return e }), define("zrender/dep/excanvas", ["require"], function() { return document.createElement("canvas").getContext ? G_vmlCanvasManager = !1 : ! function() { function e() { return this.context_ || (this.context_ = new b(this)) } function t(e, t) { var i = O.call(arguments, 2); return function() { return e.apply(t, i.concat(O.call(arguments))) } } function i(e) { return String(e).replace(/&/g, "&").replace(/"/g, """) } function n(e, t, i) { e.namespaces[t] || e.namespaces.add(t, i, "#default#VML") } function a(e) { if (n(e, "g_vml_", "urn:schemas-microsoft-com:vml"), n(e, "g_o_", "urn:schemas-microsoft-com:office:office"), !e.styleSheets.ex_canvas_) { var t = e.createStyleSheet(); t.owningElement.id = "ex_canvas_", t.cssText = "canvas{display:inline-block;overflow:hidden;text-align:left;width:300px;height:150px}" } } function o(e) { var t = e.srcElement; switch (e.propertyName) { case "width": t.getContext().clearRect(), t.style.width = t.attributes.width.nodeValue + "px", t.firstChild.style.width = t.clientWidth + "px"; break; case "height": t.getContext().clearRect(), t.style.height = t.attributes.height.nodeValue + "px", t.firstChild.style.height = t.clientHeight + "px" } } function r(e) { var t = e.srcElement; t.firstChild && (t.firstChild.style.width = t.clientWidth + "px", t.firstChild.style.height = t.clientHeight + "px") } function s() { return [ [1, 0, 0], [0, 1, 0], [0, 0, 1] ] } function l(e, t) { for (var i = s(), n = 0; 3 > n; n++) for (var a = 0; 3 > a; a++) { for (var o = 0, r = 0; 3 > r; r++) o += e[n][r] * t[r][a]; i[n][a] = o } return i } function h(e, t) { t.fillStyle = e.fillStyle, t.lineCap = e.lineCap, t.lineJoin = e.lineJoin, t.lineWidth = e.lineWidth, t.miterLimit = e.miterLimit, t.shadowBlur = e.shadowBlur, t.shadowColor = e.shadowColor, t.shadowOffsetX = e.shadowOffsetX, t.shadowOffsetY = e.shadowOffsetY, t.strokeStyle = e.strokeStyle, t.globalAlpha = e.globalAlpha, t.font = e.font, t.textAlign = e.textAlign, t.textBaseline = e.textBaseline, t.scaleX_ = e.scaleX_, t.scaleY_ = e.scaleY_, t.lineScale_ = e.lineScale_ } function d(e) { var t = e.indexOf("(", 3), i = e.indexOf(")", t + 1), n = e.substring(t + 1, i).split(","); return (4 != n.length || "a" != e.charAt(3)) && (n[3] = 1), n } function c(e) { return parseFloat(e) / 100 } function m(e, t, i) { return Math.min(i, Math.max(t, e)) } function p(e) { var t, i, n, a, o, r; if (a = parseFloat(e[0]) / 360 % 360, 0 > a && a++, o = m(c(e[1]), 0, 1), r = m(c(e[2]), 0, 1), 0 == o) t = i = n = r; else { var s = .5 > r ? r * (1 + o) : r + o - r * o, l = 2 * r - s; t = u(l, s, a + 1 / 3), i = u(l, s, a), n = u(l, s, a - 1 / 3) } return "#" + D[Math.floor(255 * t)] + D[Math.floor(255 * i)] + D[Math.floor(255 * n)] } function u(e, t, i) { return 0 > i && i++, i > 1 && i--, 1 > 6 * i ? e + 6 * (t - e) * i : 1 > 2 * i ? t : 2 > 3 * i ? e + (t - e) * (2 / 3 - i) * 6 : e } function V(e) { if (e in R) return R[e]; var t, i = 1; if (e = String(e), "#" == e.charAt(0)) t = e; else if (/^rgb/.test(e)) { for (var n, a = d(e), t = "#", o = 0; 3 > o; o++) n = -1 != a[o].indexOf("%") ? Math.floor(255 * c(a[o])) : +a[o], t += D[m(n, 0, 255)]; i = +a[3] } else if (/^hsl/.test(e)) { var a = d(e); t = p(a), i = a[3] } else t = H[e] || e; return R[e] = { color: t, alpha: i } } function U(e) { if (Y[e]) return Y[e]; var t, i = document.createElement("div"), n = i.style; try { n.font = e, t = n.fontFamily.split(",")[0] } catch (a) {} return Y[e] = { style: n.fontStyle || G.style, variant: n.fontVariant || G.variant, weight: n.fontWeight || G.weight, size: n.fontSize || G.size, family: t || G.family } } function g(e, t) { var i = {}; for (var n in e) i[n] = e[n]; var a = parseFloat(t.currentStyle.fontSize), o = parseFloat(e.size); return i.size = "number" == typeof e.size ? e.size : -1 != e.size.indexOf("px") ? o : -1 != e.size.indexOf("em") ? a * o : -1 != e.size.indexOf("%") ? a / 100 * o : -1 != e.size.indexOf("pt") ? o / .75 : a, i } function f(e) { return e.style + " " + e.variant + " " + e.weight + " " + e.size + "px '" + e.family + "'" } function y(e) { return Z[e] || "square" } function b(e) { this.m_ = s(), this.mStack_ = [], this.aStack_ = [], this.currentPath_ = [], this.strokeStyle = "#000", this.fillStyle = "#000", this.lineWidth = 1, this.lineJoin = "miter", this.lineCap = "butt", this.miterLimit = 1 * F, this.globalAlpha = 1, this.font = "12px 微软雅黑", this.textAlign = "left", this.textBaseline = "alphabetic", this.canvas = e; var t = "width:" + e.clientWidth + "px;height:" + e.clientHeight + "px;overflow:hidden;position:absolute", i = e.ownerDocument.createElement("div"); i.style.cssText = t, e.appendChild(i); var n = i.cloneNode(!1); n.style.backgroundColor = "#fff", n.style.filter = "alpha(opacity=0)", e.appendChild(n), this.element_ = i, this.scaleX_ = 1, this.scaleY_ = 1, this.lineScale_ = 1 } function _(e, t, i, n) { e.currentPath_.push({ type: "bezierCurveTo", cp1x: t.x, cp1y: t.y, cp2x: i.x, cp2y: i.y, x: n.x, y: n.y }), e.currentX_ = n.x, e.currentY_ = n.y } function x(e, t) { var i = V(e.strokeStyle), n = i.color, a = i.alpha * e.globalAlpha, o = e.lineScale_ * e.lineWidth; 1 > o && (a *= o), t.push("<g_vml_:stroke", ' opacity="', a, '"', ' joinstyle="', e.lineJoin, '"', ' miterlimit="', e.miterLimit, '"', ' endcap="', y(e.lineCap), '"', ' weight="', o, 'px"', ' color="', n, '" />') } function k(e, t, i, n) { var a = e.fillStyle, o = e.scaleX_, r = e.scaleY_, s = n.x - i.x, l = n.y - i.y; if (a instanceof W) { var h = 0, d = { x: 0, y: 0 }, c = 0, m = 1; if ("gradient" == a.type_) { var p = a.x0_ / o, u = a.y0_ / r, U = a.x1_ / o, g = a.y1_ / r, f = v(e, p, u), y = v(e, U, g), b = y.x - f.x, _ = y.y - f.y; h = 180 * Math.atan2(b, _) / Math.PI, 0 > h && (h += 360), 1e-6 > h && (h = 0) } else { var f = v(e, a.x0_, a.y0_); d = { x: (f.x - i.x) / s, y: (f.y - i.y) / l }, s /= o * F, l /= r * F; var x = C.max(s, l); c = 2 * a.r0_ / x, m = 2 * a.r1_ / x - c } var k = a.colors_; k.sort(function(e, t) { return e.offset - t.offset }); for (var L = k.length, w = k[0].color, I = k[L - 1].color, S = k[0].alpha * e.globalAlpha, K = k[L - 1].alpha * e.globalAlpha, T = [], E = 0; L > E; E++) { var z = k[E]; T.push(z.offset * m + c + " " + z.color) } t.push('<g_vml_:fill type="', a.type_, '"', ' method="none" focus="100%"', ' color="', w, '"', ' color2="', I, '"', ' colors="', T.join(","), '"', ' opacity="', K, '"', ' g_o_:opacity2="', S, '"', ' angle="', h, '"', ' focusposition="', d.x, ",", d.y, '" />') } else if (a instanceof X) { if (s && l) { var A = -i.x, M = -i.y; t.push("<g_vml_:fill", ' position="', A / s * o * o, ",", M / l * r * r, '"', ' type="tile"', ' src="', a.src_, '" />') } } else { var J = V(e.fillStyle), O = J.color, P = J.alpha * e.globalAlpha; t.push('<g_vml_:fill color="', O, '" opacity="', P, '" />') } } function v(e, t, i) { var n = e.m_; return { x: F * (t * n[0][0] + i * n[1][0] + n[2][0]) - J, y: F * (t * n[0][1] + i * n[1][1] + n[2][1]) - J } } function L(e) { return isFinite(e[0][0]) && isFinite(e[0][1]) && isFinite(e[1][0]) && isFinite(e[1][1]) && isFinite(e[2][0]) && isFinite(e[2][1]) } function w(e, t, i) { if (L(t) && (e.m_ = t, e.scaleX_ = Math.sqrt(t[0][0] * t[0][0] + t[0][1] * t[0][1]), e.scaleY_ = Math.sqrt(t[1][0] * t[1][0] + t[1][1] * t[1][1]), i)) { var n = t[0][0] * t[1][1] - t[0][1] * t[1][0]; e.lineScale_ = M(A(n)) } } function W(e) { this.type_ = e, this.x0_ = 0, this.y0_ = 0, this.r0_ = 0, this.x1_ = 0, this.y1_ = 0, this.r1_ = 0, this.colors_ = [] } function X(e, t) { switch (S(e), t) { case "repeat": case null: case "": this.repetition_ = "repeat"; break; case "repeat-x": case "repeat-y": case "no-repeat": this.repetition_ = t; break; default: I("SYNTAX_ERR") } this.src_ = e.src, this.width_ = e.width, this.height_ = e.height } function I(e) { throw new K(e) } function S(e) { e && 1 == e.nodeType && "IMG" == e.tagName || I("TYPE_MISMATCH_ERR"), "complete" != e.readyState && I("INVALID_STATE_ERR") } function K(e) { this.code = this[e], this.message = e + ": DOM Exception " + this.code } var C = Math, T = C.round, E = C.sin, z = C.cos, A = C.abs, M = C.sqrt, F = 10, J = F / 2, O = (+navigator.userAgent.match(/MSIE ([\d.]+)?/)[1], Array.prototype.slice); a(document); var P = { init: function(e) { var i = e || document; i.createElement("canvas"), i.attachEvent("onreadystatechange", t(this.init_, this, i)) }, init_: function(e) { for (var t = e.getElementsByTagName("canvas"), i = 0; i < t.length; i++) this.initElement(t[i]) }, initElement: function(t) { if (!t.getContext) { t.getContext = e, a(t.ownerDocument), t.innerHTML = "", t.attachEvent("onpropertychange", o), t.attachEvent("onresize", r); var i = t.attributes; i.width && i.width.specified ? t.style.width = i.width.nodeValue + "px" : t.width = t.clientWidth, i.height && i.height.specified ? t.style.height = i.height.nodeValue + "px" : t.height = t.clientHeight } return t } }; P.init(); for (var D = [], N = 0; 16 > N; N++) for (var B = 0; 16 > B; B++) D[16 * N + B] = N.toString(16) + B.toString(16); var H = { aliceblue: "#F0F8FF", antiquewhite: "#FAEBD7", aquamarine: "#7FFFD4", azure: "#F0FFFF", beige: "#F5F5DC", bisque: "#FFE4C4", black: "#000000", blanchedalmond: "#FFEBCD", blueviolet: "#8A2BE2", brown: "#A52A2A", burlywood: "#DEB887", cadetblue: "#5F9EA0", chartreuse: "#7FFF00", chocolate: "#D2691E", coral: "#FF7F50", cornflowerblue: "#6495ED", cornsilk: "#FFF8DC", crimson: "#DC143C", cyan: "#00FFFF", darkblue: "#00008B", darkcyan: "#008B8B", darkgoldenrod: "#B8860B", darkgray: "#A9A9A9", darkgreen: "#006400", darkgrey: "#A9A9A9", darkkhaki: "#BDB76B", darkmagenta: "#8B008B", darkolivegreen: "#556B2F", darkorange: "#FF8C00", darkorchid: "#9932CC", darkred: "#8B0000", darksalmon: "#E9967A", darkseagreen: "#8FBC8F", darkslateblue: "#483D8B", darkslategray: "#2F4F4F", darkslategrey: "#2F4F4F", darkturquoise: "#00CED1", darkviolet: "#9400D3", deeppink: "#FF1493", deepskyblue: "#00BFFF", dimgray: "#696969", dimgrey: "#696969", dodgerblue: "#1E90FF", firebrick: "#B22222", floralwhite: "#FFFAF0", forestgreen: "#228B22", gainsboro: "#DCDCDC", ghostwhite: "#F8F8FF", gold: "#FFD700", goldenrod: "#DAA520", grey: "#808080", greenyellow: "#ADFF2F", honeydew: "#F0FFF0", hotpink: "#FF69B4", indianred: "#CD5C5C", indigo: "#4B0082", ivory: "#FFFFF0", khaki: "#F0E68C", lavender: "#E6E6FA", lavenderblush: "#FFF0F5", lawngreen: "#7CFC00", lemonchiffon: "#FFFACD", lightblue: "#ADD8E6", lightcoral: "#F08080", lightcyan: "#E0FFFF", lightgoldenrodyellow: "#FAFAD2", lightgreen: "#90EE90", lightgrey: "#D3D3D3", lightpink: "#FFB6C1", lightsalmon: "#FFA07A", lightseagreen: "#20B2AA", lightskyblue: "#87CEFA", lightslategray: "#778899", lightslategrey: "#778899", lightsteelblue: "#B0C4DE", lightyellow: "#FFFFE0", limegreen: "#32CD32", linen: "#FAF0E6", magenta: "#FF00FF", mediumaquamarine: "#66CDAA", mediumblue: "#0000CD", mediumorchid: "#BA55D3", mediumpurple: "#9370DB", mediumseagreen: "#3CB371", mediumslateblue: "#7B68EE", mediumspringgreen: "#00FA9A", mediumturquoise: "#48D1CC", mediumvioletred: "#C71585", midnightblue: "#191970", mintcream: "#F5FFFA", mistyrose: "#FFE4E1", moccasin: "#FFE4B5", navajowhite: "#FFDEAD", oldlace: "#FDF5E6", olivedrab: "#6B8E23", orange: "#FFA500", orangered: "#FF4500", orchid: "#DA70D6", palegoldenrod: "#EEE8AA", palegreen: "#98FB98", paleturquoise: "#AFEEEE", palevioletred: "#DB7093", papayawhip: "#FFEFD5", peachpuff: "#FFDAB9", peru: "#CD853F", pink: "#FFC0CB", plum: "#DDA0DD", powderblue: "#B0E0E6", rosybrown: "#BC8F8F", royalblue: "#4169E1", saddlebrown: "#8B4513", salmon: "#FA8072", sandybrown: "#F4A460", seagreen: "#2E8B57", seashell: "#FFF5EE", sienna: "#A0522D", skyblue: "#87CEEB", slateblue: "#6A5ACD", slategray: "#708090", slategrey: "#708090", snow: "#FFFAFA", springgreen: "#00FF7F", steelblue: "#4682B4", tan: "#D2B48C", thistle: "#D8BFD8", tomato: "#FF6347", turquoise: "#40E0D0", violet: "#EE82EE", wheat: "#F5DEB3", whitesmoke: "#F5F5F5", yellowgreen: "#9ACD32" }, R = {}, G = { style: "normal", variant: "normal", weight: "normal", size: 12, family: "微软雅黑" }, Y = {}, Z = { butt: "flat", round: "round" }, Q = b.prototype; Q.clearRect = function() { this.textMeasureEl_ && (this.textMeasureEl_.removeNode(!0), this.textMeasureEl_ = null), this.element_.innerHTML = "" }, Q.beginPath = function() { this.currentPath_ = [] }, Q.moveTo = function(e, t) { var i = v(this, e, t); this.currentPath_.push({ type: "moveTo", x: i.x, y: i.y }), this.currentX_ = i.x, this.currentY_ = i.y }, Q.lineTo = function(e, t) { var i = v(this, e, t); this.currentPath_.push({ type: "lineTo", x: i.x, y: i.y }), this.currentX_ = i.x, this.currentY_ = i.y }, Q.bezierCurveTo = function(e, t, i, n, a, o) { var r = v(this, a, o), s = v(this, e, t), l = v(this, i, n); _(this, s, l, r) }, Q.quadraticCurveTo = function(e, t, i, n) { var a = v(this, e, t), o = v(this, i, n), r = { x: this.currentX_ + 2 / 3 * (a.x - this.currentX_), y: this.currentY_ + 2 / 3 * (a.y - this.currentY_) }, s = { x: r.x + (o.x - this.currentX_) / 3, y: r.y + (o.y - this.currentY_) / 3 }; _(this, r, s, o) }, Q.arc = function(e, t, i, n, a, o) { i *= F; var r = o ? "at" : "wa", s = e + z(n) * i - J, l = t + E(n) * i - J, h = e + z(a) * i - J, d = t + E(a) * i - J; s != h || o || (s += .125); var c = v(this, e, t), m = v(this, s, l), p = v(this, h, d); this.currentPath_.push({ type: r, x: c.x, y: c.y, radius: i, xStart: m.x, yStart: m.y, xEnd: p.x, yEnd: p.y }) }, Q.rect = function(e, t, i, n) { this.moveTo(e, t), this.lineTo(e + i, t), this.lineTo(e + i, t + n), this.lineTo(e, t + n), this.closePath() }, Q.strokeRect = function(e, t, i, n) { var a = this.currentPath_; this.beginPath(), this.moveTo(e, t), this.lineTo(e + i, t), this.lineTo(e + i, t + n), this.lineTo(e, t + n), this.closePath(), this.stroke(), this.currentPath_ = a }, Q.fillRect = function(e, t, i, n) { var a = this.currentPath_; this.beginPath(), this.moveTo(e, t), this.lineTo(e + i, t), this.lineTo(e + i, t + n), this.lineTo(e, t + n), this.closePath(), this.fill(), this.currentPath_ = a }, Q.createLinearGradient = function(e, t, i, n) { var a = new W("gradient"); return a.x0_ = e, a.y0_ = t, a.x1_ = i, a.y1_ = n, a }, Q.createRadialGradient = function(e, t, i, n, a, o) { var r = new W("gradientradial"); return r.x0_ = e, r.y0_ = t, r.r0_ = i, r.x1_ = n, r.y1_ = a, r.r1_ = o, r }, Q.drawImage = function(e) { var t, i, n, a, o, r, s, l, h = e.runtimeStyle.width, d = e.runtimeStyle.height; e.runtimeStyle.width = "auto", e.runtimeStyle.height = "auto"; var c = e.width, m = e.height; if (e.runtimeStyle.width = h, e.runtimeStyle.height = d, 3 == arguments.length) t = arguments[1], i = arguments[2], o = r = 0, s = n = c, l = a = m; else if (5 == arguments.length) t = arguments[1], i = arguments[2], n = arguments[3], a = arguments[4], o = r = 0, s = c, l = m; else { if (9 != arguments.length) throw Error("Invalid number of arguments"); o = arguments[1], r = arguments[2], s = arguments[3], l = arguments[4], t = arguments[5], i = arguments[6], n = arguments[7], a = arguments[8] } var p = v(this, t, i), u = [], V = 10, U = 10, g = y = 1; if (u.push(" <g_vml_:group", ' coordsize="', F * V, ",", F * U, '"', ' coordorigin="0,0"', ' style="width:', V, "px;height:", U, "px;position:absolute;"), 1 != this.m_[0][0] || this.m_[0][1] || 1 != this.m_[1][1] || this.m_[1][0]) { var f = [], g = this.scaleX_, y = this.scaleY_; f.push("M11=", this.m_[0][0] / g, ",", "M12=", this.m_[1][0] / y, ",", "M21=", this.m_[0][1] / g, ",", "M22=", this.m_[1][1] / y, ",", "Dx=", T(p.x / F), ",", "Dy=", T(p.y / F), ""); var b = p, _ = v(this, t + n, i), x = v(this, t, i + a), k = v(this, t + n, i + a); b.x = C.max(b.x, _.x, x.x, k.x), b.y = C.max(b.y, _.y, x.y, k.y), u.push("padding:0 ", T(b.x / F), "px ", T(b.y / F), "px 0;filter:progid:DXImageTransform.Microsoft.Matrix(", f.join(""), ", SizingMethod='clip');") } else u.push("top:", T(p.y / F), "px;left:", T(p.x / F), "px;"); u.push(' ">'), (o || r) && u.push('<div style="overflow: hidden; width:', Math.ceil((n + o * n / s) * g), "px;", " height:", Math.ceil((a + r * a / l) * y), "px;", " filter:progid:DxImageTransform.Microsoft.Matrix(Dx=", -o * n / s * g, ",Dy=", -r * a / l * y, ');">'), u.push('<div style="width:', Math.round(g * c * n / s), "px;", " height:", Math.round(y * m * a / l), "px;", " filter:"), this.globalAlpha < 1 && u.push(" progid:DXImageTransform.Microsoft.Alpha(opacity=" + 100 * this.globalAlpha + ")"), u.push(" progid:DXImageTransform.Microsoft.AlphaImageLoader(src=", e.src, ',sizingMethod=scale)">'), (o || r) && u.push("</div>"), u.push("</div></div>"), this.element_.insertAdjacentHTML("BeforeEnd", u.join("")) }, Q.stroke = function(e) { var t = [], i = 10, n = 10; t.push("<g_vml_:shape", ' filled="', !!e, '"', ' style="position:absolute;width:', i, "px;height:", n, 'px;"', ' coordorigin="0,0"', ' coordsize="', F * i, ",", F * n, '"', ' stroked="', !e, '"', ' path="'); for (var a = { x: null, y: null }, o = { x: null, y: null }, r = 0; r < this.currentPath_.length; r++) { var s, l = this.currentPath_[r]; switch (l.type) { case "moveTo": s = l, t.push(" m ", T(l.x), ",", T(l.y)); break; case "lineTo": t.push(" l ", T(l.x), ",", T(l.y)); break; case "close": t.push(" x "), l = null; break; case "bezierCurveTo": t.push(" c ", T(l.cp1x), ",", T(l.cp1y), ",", T(l.cp2x), ",", T(l.cp2y), ",", T(l.x), ",", T(l.y)); break; case "at": case "wa": t.push(" ", l.type, " ", T(l.x - this.scaleX_ * l.radius), ",", T(l.y - this.scaleY_ * l.radius), " ", T(l.x + this.scaleX_ * l.radius), ",", T(l.y + this.scaleY_ * l.radius), " ", T(l.xStart), ",", T(l.yStart), " ", T(l.xEnd), ",", T(l.yEnd)) } l && ((null == a.x || l.x < a.x) && (a.x = l.x), (null == o.x || l.x > o.x) && (o.x = l.x), (null == a.y || l.y < a.y) && (a.y = l.y), (null == o.y || l.y > o.y) && (o.y = l.y)) } t.push(' ">'), e ? k(this, t, a, o) : x(this, t), t.push("</g_vml_:shape>"), this.element_.insertAdjacentHTML("beforeEnd", t.join("")) }, Q.fill = function() { this.stroke(!0) }, Q.closePath = function() { this.currentPath_.push({ type: "close" }) }, Q.save = function() { var e = {}; h(this, e), this.aStack_.push(e), this.mStack_.push(this.m_), this.m_ = l(s(), this.m_) }, Q.restore = function() { this.aStack_.length && (h(this.aStack_.pop(), this), this.m_ = this.mStack_.pop()) }, Q.translate = function(e, t) { var i = [ [1, 0, 0], [0, 1, 0], [e, t, 1] ]; w(this, l(i, this.m_), !1) }, Q.rotate = function(e) { var t = z(e), i = E(e), n = [ [t, i, 0], [-i, t, 0], [0, 0, 1] ]; w(this, l(n, this.m_), !1) }, Q.scale = function(e, t) { var i = [ [e, 0, 0], [0, t, 0], [0, 0, 1] ]; w(this, l(i, this.m_), !0) }, Q.transform = function(e, t, i, n, a, o) { var r = [ [e, t, 0], [i, n, 0], [a, o, 1] ]; w(this, l(r, this.m_), !0) }, Q.setTransform = function(e, t, i, n, a, o) { var r = [ [e, t, 0], [i, n, 0], [a, o, 1] ]; w(this, r, !0) }, Q.drawText_ = function(e, t, n, a, o) { var r = this.m_, s = 1e3, l = 0, h = s, d = { x: 0, y: 0 }, c = [], m = g(U(this.font), this.element_), p = f(m), u = this.element_.currentStyle, V = this.textAlign.toLowerCase(); switch (V) { case "left": case "center": case "right": break; case "end": V = "ltr" == u.direction ? "right" : "left"; break; case "start": V = "rtl" == u.direction ? "right" : "left"; break; default: V = "left" } switch (this.textBaseline) { case "hanging": case "top": d.y = m.size / 1.75; break; case "middle": break; default: case null: case "alphabetic": case "ideographic": case "bottom": d.y = -m.size / 2.25 } switch (V) { case "right": l = s, h = .05; break; case "center": l = h = s / 2 } var y = v(this, t + d.x, n + d.y); c.push('<g_vml_:line from="', -l, ' 0" to="', h, ' 0.05" ', ' coordsize="100 100" coordorigin="0 0"', ' filled="', !o, '" stroked="', !!o, '" style="position:absolute;width:1px;height:1px;">'), o ? x(this, c) : k(this, c, { x: -l, y: 0 }, { x: h, y: m.size }); var b = r[0][0].toFixed(3) + "," + r[1][0].toFixed(3) + "," + r[0][1].toFixed(3) + "," + r[1][1].toFixed(3) + ",0,0", _ = T(y.x / F) + "," + T(y.y / F); c.push('<g_vml_:skew on="t" matrix="', b, '" ', ' offset="', _, '" origin="', l, ' 0" />', '<g_vml_:path textpathok="true" />', '<g_vml_:textpath on="true" string="', i(e), '" style="v-text-align:', V, ";font:", i(p), '" /></g_vml_:line>'), this.element_.insertAdjacentHTML("beforeEnd", c.join("")) }, Q.fillText = function(e, t, i, n) { this.drawText_(e, t, i, n, !1) }, Q.strokeText = function(e, t, i, n) { this.drawText_(e, t, i, n, !0) }, Q.measureText = function(e) { if (!this.textMeasureEl_) { var t = '<span style="position:absolute;top:-20000px;left:0;padding:0;margin:0;border:none;white-space:pre;"></span>'; this.element_.insertAdjacentHTML("beforeEnd", t), this.textMeasureEl_ = this.element_.lastChild } var i = this.element_.ownerDocument; this.textMeasureEl_.innerHTML = ""; try { this.textMeasureEl_.style.font = this.font } catch (n) {} return this.textMeasureEl_.appendChild(i.createTextNode(e)), { width: this.textMeasureEl_.offsetWidth } }, Q.clip = function() {}, Q.arcTo = function() {}, Q.createPattern = function(e, t) { return new X(e, t) }, W.prototype.addColorStop = function(e, t) { t = V(t), this.colors_.push({ offset: e, color: t.color, alpha: t.alpha }) }; var q = K.prototype = new Error; q.INDEX_SIZE_ERR = 1, q.DOMSTRING_SIZE_ERR = 2, q.HIERARCHY_REQUEST_ERR = 3, q.WRONG_DOCUMENT_ERR = 4, q.INVALID_CHARACTER_ERR = 5, q.NO_DATA_ALLOWED_ERR = 6, q.NO_MODIFICATION_ALLOWED_ERR = 7, q.NOT_FOUND_ERR = 8, q.NOT_SUPPORTED_ERR = 9, q.INUSE_ATTRIBUTE_ERR = 10, q.INVALID_STATE_ERR = 11, q.SYNTAX_ERR = 12, q.INVALID_MODIFICATION_ERR = 13, q.NAMESPACE_ERR = 14, q.INVALID_ACCESS_ERR = 15, q.VALIDATION_ERR = 16, q.TYPE_MISMATCH_ERR = 17, G_vmlCanvasManager = P, CanvasRenderingContext2D = b, CanvasGradient = W, CanvasPattern = X, DOMException = K }(), G_vmlCanvasManager }), define("zrender/mixin/Eventful", ["require"], function() { var e = function() { this._handlers = {} }; return e.prototype.one = function(e, t, i) { var n = this._handlers; return t && e ? (n[e] || (n[e] = []), n[e].push({ h: t, one: !0, ctx: i || this }), this) : this }, e.prototype.bind = function(e, t, i) { var n = this._handlers; return t && e ? (n[e] || (n[e] = []), n[e].push({ h: t, one: !1, ctx: i || this }), this) : this }, e.prototype.unbind = function(e, t) { var i = this._handlers; if (!e) return this._handlers = {}, this; if (t) { if (i[e]) { for (var n = [], a = 0, o = i[e].length; o > a; a++) i[e][a].h != t && n.push(i[e][a]); i[e] = n } i[e] && 0 === i[e].length && delete i[e] } else delete i[e]; return this }, e.prototype.dispatch = function(e) { if (this._handlers[e]) { var t = arguments, i = t.length; i > 3 && (t = Array.prototype.slice.call(t, 1)); for (var n = this._handlers[e], a = n.length, o = 0; a > o;) { switch (i) { case 1: n[o].h.call(n[o].ctx); break; case 2: n[o].h.call(n[o].ctx, t[1]); break; case 3: n[o].h.call(n[o].ctx, t[1], t[2]); break; default: n[o].h.apply(n[o].ctx, t) } n[o].one ? (n.splice(o, 1), a--) : o++ } } return this }, e.prototype.dispatchWithContext = function(e) { if (this._handlers[e]) { var t = arguments, i = t.length; i > 4 && (t = Array.prototype.slice.call(t, 1, t.length - 1)); for (var n = t[t.length - 1], a = this._handlers[e], o = a.length, r = 0; o > r;) { switch (i) { case 1: a[r].h.call(n); break; case 2: a[r].h.call(n, t[1]); break; case 3: a[r].h.call(n, t[1], t[2]); break; default: a[r].h.apply(n, t) } a[r].one ? (a.splice(r, 1), o--) : r++ } } return this }, e }), define("zrender/tool/log", ["require", "../config"], function(e) { var t = e("../config"); return function() { if (0 !== t.debugMode) if (1 == t.debugMode) for (var e in arguments) throw new Error(arguments[e]); else if (t.debugMode > 1) for (var e in arguments) console.log(arguments[e]) } }), define("zrender/tool/guid", [], function() { var e = 2311; return function() { return "zrender__" + e++ } }), define("zrender/Handler", ["require", "./config", "./tool/env", "./tool/event", "./tool/util", "./tool/vector", "./tool/matrix", "./mixin/Eventful"], function(e) { "use strict"; function t(e, t) { return function(i, n) { return e.call(t, i, n) } } function i(e, t) { return function(i, n, a) { return e.call(t, i, n, a) } } function n(e) { for (var i = p.length; i--;) { var n = p[i]; e["_" + n + "Handler"] = t(V[n], e) } } function a(e, t, i) { if (this._draggingTarget && this._draggingTarget.id == e.id || e.isSilent()) return !1; var n = this._event; if (e.isCover(t, i)) { e.hoverable && this.storage.addHover(e); for (var a = e.parent; a;) { if (a.clipShape && !a.clipShape.isCover(this._mouseX, this._mouseY)) return !1; a = a.parent } return this._lastHover != e && (this._processOutShape(n), this._processDragLeave(n), this._lastHover = e, this._processDragEnter(n)), this._processOverShape(n), this._processDragOver(n), this._hasfound = 1, !0 } return !1 } var o = e("./config"), r = e("./tool/env"), s = e("./tool/event"), l = e("./tool/util"), h = e("./tool/vector"), d = e("./tool/matrix"), c = o.EVENT, m = e("./mixin/Eventful"), p = ["resize", "click", "dblclick", "mousewheel", "mousemove", "mouseout", "mouseup", "mousedown", "touchstart", "touchend", "touchmove"], u = function(e) { if (window.G_vmlCanvasManager) return !0; e = e || window.event; var t = e.toElement || e.relatedTarget || e.srcElement || e.target; return t && t.className.match(o.elementClassName) }, V = { resize: function(e) { e = e || window.event, this._lastHover = null, this._isMouseDown = 0, this.dispatch(c.RESIZE, e) }, click: function(e, t) { if (u(e) || t) { e = this._zrenderEventFixed(e); var i = this._lastHover; (i && i.clickable || !i) && this._clickThreshold < 5 && this._dispatchAgency(i, c.CLICK, e), this._mousemoveHandler(e) } }, dblclick: function(e, t) { if (u(e) || t) { e = e || window.event, e = this._zrenderEventFixed(e); var i = this._lastHover; (i && i.clickable || !i) && this._clickThreshold < 5 && this._dispatchAgency(i, c.DBLCLICK, e), this._mousemoveHandler(e) } }, mousewheel: function(e, t) { if (u(e) || t) { e = this._zrenderEventFixed(e); var i = e.wheelDelta || -e.detail, n = i > 0 ? 1.1 : 1 / 1.1, a = !1, o = this._mouseX, r = this._mouseY; this.painter.eachBuildinLayer(function(t) { var i = t.position; if (t.zoomable) { t.__zoom = t.__zoom || 1; var l = t.__zoom; l *= n, l = Math.max(Math.min(t.maxZoom, l), t.minZoom), n = l / t.__zoom, t.__zoom = l, i[0] -= (o - i[0]) * (n - 1), i[1] -= (r - i[1]) * (n - 1), t.scale[0] *= n, t.scale[1] *= n, t.dirty = !0, a = !0, s.stop(e) } }), a && this.painter.refresh(), this._dispatchAgency(this._lastHover, c.MOUSEWHEEL, e), this._mousemoveHandler(e) } }, mousemove: function(e, t) { if ((u(e) || t) && !this.painter.isLoading()) { e = this._zrenderEventFixed(e), this._lastX = this._mouseX, this._lastY = this._mouseY, this._mouseX = s.getX(e), this._mouseY = s.getY(e); var i = this._mouseX - this._lastX, n = this._mouseY - this._lastY; this._processDragStart(e), this._hasfound = 0, this._event = e, this._iterateAndFindHover(), this._hasfound || ((!this._draggingTarget || this._lastHover && this._lastHover != this._draggingTarget) && (this._processOutShape(e), this._processDragLeave(e)), this._lastHover = null, this.storage.delHover(), this.painter.clearHover()); var a = "default"; if (this._draggingTarget) this.storage.drift(this._draggingTarget.id, i, n), this._draggingTarget.modSelf(), this.storage.addHover(this._draggingTarget), this._clickThreshold++; else if (this._isMouseDown) { var o = !1; this.painter.eachBuildinLayer(function(e) { e.panable && (a = "move", e.position[0] += i, e.position[1] += n, o = !0, e.dirty = !0) }), o && this.painter.refresh() } this._draggingTarget || this._hasfound && this._lastHover.draggable ? a = "move" : this._hasfound && this._lastHover.clickable && (a = "pointer"), this.root.style.cursor = a, this._dispatchAgency(this._lastHover, c.MOUSEMOVE, e), (this._draggingTarget || this._hasfound || this.storage.hasHoverShape()) && this.painter.refreshHover() } }, mouseout: function(e, t) { if (u(e) || t) { e = this._zrenderEventFixed(e); var i = e.toElement || e.relatedTarget; if (i != this.root) for (; i && 9 != i.nodeType;) { if (i == this.root) return void this._mousemoveHandler(e); i = i.parentNode } e.zrenderX = this._lastX, e.zrenderY = this._lastY, this.root.style.cursor = "default", this._isMouseDown = 0, this._processOutShape(e), this._processDrop(e), this._processDragEnd(e), this.painter.isLoading() || this.painter.refreshHover(), this.dispatch(c.GLOBALOUT, e) } }, mousedown: function(e, t) { if (u(e) || t) { if (this._clickThreshold = 0, 2 == this._lastDownButton) return this._lastDownButton = e.button, void(this._mouseDownTarget = null); this._lastMouseDownMoment = new Date, e = this._zrenderEventFixed(e), this._isMouseDown = 1, this._mouseDownTarget = this._lastHover, this._dispatchAgency(this._lastHover, c.MOUSEDOWN, e), this._lastDownButton = e.button } }, mouseup: function(e, t) { (u(e) || t) && (e = this._zrenderEventFixed(e), this.root.style.cursor = "default", this._isMouseDown = 0, this._mouseDownTarget = null, this._dispatchAgency(this._lastHover, c.MOUSEUP, e), this._processDrop(e), this._processDragEnd(e)) }, touchstart: function(e, t) { (u(e) || t) && (e = this._zrenderEventFixed(e, !0), this._lastTouchMoment = new Date, this._mobileFindFixed(e), this._mousedownHandler(e)) }, touchmove: function(e, t) { (u(e) || t) && (e = this._zrenderEventFixed(e, !0), this._mousemoveHandler(e), this._isDragging && s.stop(e)) }, touchend: function(e, t) { if (u(e) || t) { e = this._zrenderEventFixed(e, !0), this._mouseupHandler(e); var i = new Date; i - this._lastTouchMoment < c.touchClickDelay && (this._mobileFindFixed(e), this._clickHandler(e), i - this._lastClickMoment < c.touchClickDelay / 2 && (this._dblclickHandler(e), this._lastHover && this._lastHover.clickable && s.stop(e)), this._lastClickMoment = i), this.painter.clearHover() } } }, U = function(e, t, o) { m.call(this), this.root = e, this.storage = t, this.painter = o, this._lastX = this._lastY = this._mouseX = this._mouseY = 0, this._findHover = i(a, this), this._domHover = o.getDomHover(), n(this), window.addEventListener ? (window.addEventListener("resize", this._resizeHandler), r.os.tablet || r.os.phone ? (e.addEventListener("touchstart", this._touchstartHandler), e.addEventListener("touchmove", this._touchmoveHandler), e.addEventListener("touchend", this._touchendHandler)) : (e.addEventListener("click", this._clickHandler), e.addEventListener("dblclick", this._dblclickHandler), e.addEventListener("mousewheel", this._mousewheelHandler), e.addEventListener("mousemove", this._mousemoveHandler), e.addEventListener("mousedown", this._mousedownHandler), e.addEventListener("mouseup", this._mouseupHandler)), e.addEventListener("DOMMouseScroll", this._mousewheelHandler), e.addEventListener("mouseout", this._mouseoutHandler)) : (window.attachEvent("onresize", this._resizeHandler), e.attachEvent("onclick", this._clickHandler), e.ondblclick = this._dblclickHandler, e.attachEvent("onmousewheel", this._mousewheelHandler), e.attachEvent("onmousemove", this._mousemoveHandler), e.attachEvent("onmouseout", this._mouseoutHandler), e.attachEvent("onmousedown", this._mousedownHandler), e.attachEvent("onmouseup", this._mouseupHandler)) }; U.prototype.on = function(e, t, i) { return this.bind(e, t, i), this }, U.prototype.un = function(e, t) { return this.unbind(e, t), this }, U.prototype.trigger = function(e, t) { switch (e) { case c.RESIZE: case c.CLICK: case c.DBLCLICK: case c.MOUSEWHEEL: case c.MOUSEMOVE: case c.MOUSEDOWN: case c.MOUSEUP: case c.MOUSEOUT: this["_" + e + "Handler"](t, !0) } }, U.prototype.dispose = function() { var e = this.root; window.removeEventListener ? (window.removeEventListener("resize", this._resizeHandler), r.os.tablet || r.os.phone ? (e.removeEventListener("touchstart", this._touchstartHandler), e.removeEventListener("touchmove", this._touchmoveHandler), e.removeEventListener("touchend", this._touchendHandler)) : (e.removeEventListener("click", this._clickHandler), e.removeEventListener("dblclick", this._dblclickHandler), e.removeEventListener("mousewheel", this._mousewheelHandler), e.removeEventListener("mousemove", this._mousemoveHandler), e.removeEventListener("mousedown", this._mousedownHandler), e.removeEventListener("mouseup", this._mouseupHandler)), e.removeEventListener("DOMMouseScroll", this._mousewheelHandler), e.removeEventListener("mouseout", this._mouseoutHandler)) : (window.detachEvent("onresize", this._resizeHandler), e.detachEvent("onclick", this._clickHandler), e.detachEvent("dblclick", this._dblclickHandler), e.detachEvent("onmousewheel", this._mousewheelHandler), e.detachEvent("onmousemove", this._mousemoveHandler), e.detachEvent("onmouseout", this._mouseoutHandler), e.detachEvent("onmousedown", this._mousedownHandler), e.detachEvent("onmouseup", this._mouseupHandler)), this.root = this._domHover = this.storage = this.painter = null, this.un() }, U.prototype._processDragStart = function(e) { var t = this._lastHover; if (this._isMouseDown && t && t.draggable && !this._draggingTarget && this._mouseDownTarget == t) { if (t.dragEnableTime && new Date - this._lastMouseDownMoment < t.dragEnableTime) return; var i = t; this._draggingTarget = i, this._isDragging = 1, i.invisible = !0, this.storage.mod(i.id), this._dispatchAgency(i, c.DRAGSTART, e), this.painter.refresh() } }, U.prototype._processDragEnter = function(e) { this._draggingTarget && this._dispatchAgency(this._lastHover, c.DRAGENTER, e, this._draggingTarget) }, U.prototype._processDragOver = function(e) { this._draggingTarget && this._dispatchAgency(this._lastHover, c.DRAGOVER, e, this._draggingTarget) }, U.prototype._processDragLeave = function(e) { this._draggingTarget && this._dispatchAgency(this._lastHover, c.DRAGLEAVE, e, this._draggingTarget) }, U.prototype._processDrop = function(e) { this._draggingTarget && (this._draggingTarget.invisible = !1, this.storage.mod(this._draggingTarget.id), this.painter.refresh(), this._dispatchAgency(this._lastHover, c.DROP, e, this._draggingTarget)) }, U.prototype._processDragEnd = function(e) { this._draggingTarget && (this._dispatchAgency(this._draggingTarget, c.DRAGEND, e), this._lastHover = null), this._isDragging = 0, this._draggingTarget = null }, U.prototype._processOverShape = function(e) { this._dispatchAgency(this._lastHover, c.MOUSEOVER, e) }, U.prototype._processOutShape = function(e) { this._dispatchAgency(this._lastHover, c.MOUSEOUT, e) }, U.prototype._dispatchAgency = function(e, t, i, n) { var a = "on" + t, o = { type: t, event: i, target: e, cancelBubble: !1 }, r = e; for (n && (o.dragged = n); r && (r[a] && (o.cancelBubble = r[a](o)), r.dispatch(t, o), r = r.parent, !o.cancelBubble);); if (e) o.cancelBubble || this.dispatch(t, o); else if (!n) { var s = { type: t, event: i }; this.dispatch(t, s), this.painter.eachOtherLayer(function(e) { "function" == typeof e[a] && e[a](s), e.dispatch && e.dispatch(t, s) }) } }, U.prototype._iterateAndFindHover = function() { var e = d.create(); return function() { for (var t, i, n = this.storage.getShapeList(), a = [0, 0], o = n.length - 1; o >= 0; o--) { var r = n[o]; if (t !== r.zlevel && (i = this.painter.getLayer(r.zlevel, i), a[0] = this._mouseX, a[1] = this._mouseY, i.needTransform && (d.invert(e, i.transform), h.applyTransform(a, a, e))), this._findHover(r, a[0], a[1])) break } } }(); var g = [{ x: 10 }, { x: -20 }, { x: 10, y: 10 }, { y: -20 }]; return U.prototype._mobileFindFixed = function(e) { this._lastHover = null, this._mouseX = e.zrenderX, this._mouseY = e.zrenderY, this._event = e, this._iterateAndFindHover(); for (var t = 0; !this._lastHover && t < g.length; t++) { var i = g[t]; i.x && (this._mouseX += i.x), i.y && (this._mouseY += i.y), this._iterateAndFindHover() } this._lastHover && (e.zrenderX = this._mouseX, e.zrenderY = this._mouseY) }, U.prototype._zrenderEventFixed = function(e, t) { if (e.zrenderFixed) return e; if (t) { var i = "touchend" != e.type ? e.targetTouches[0] : e.changedTouches[0]; if (i) { var n = this.painter._domRoot.getBoundingClientRect(); e.zrenderX = i.clientX - n.left, e.zrenderY = i.clientY - n.top } } else { e = e || window.event; var a = e.toElement || e.relatedTarget || e.srcElement || e.target; a && a != this._domHover && (e.zrenderX = ("undefined" != typeof e.offsetX ? e.offsetX : e.layerX) + a.offsetLeft, e.zrenderY = ("undefined" != typeof e.offsetY ? e.offsetY : e.layerY) + a.offsetTop) } return e.zrenderFixed = 1, e }, l.merge(U.prototype, m.prototype, !0), U }), define("zrender/Painter", ["require", "./config", "./tool/util", "./tool/log", "./loadingEffect/Base", "./Layer", "./shape/Image"], function(e) { "use strict"; function t() { return !1 } function i() {} function n(e) { return e ? e.isBuildin ? !0 : "function" != typeof e.resize || "function" != typeof e.refresh ? !1 : !0 : !1 } var a = e("./config"), o = e("./tool/util"), r = e("./tool/log"), s = e("./loadingEffect/Base"), l = e("./Layer"), h = function(e, i) { this.root = e, e.style["-webkit-tap-highlight-color"] = "transparent", e.style["-webkit-user-select"] = "none", e.style["user-select"] = "none", e.style["-webkit-touch-callout"] = "none", this.storage = i, e.innerHTML = "", this._width = this._getWidth(), this._height = this._getHeight(); var n = document.createElement("div"); this._domRoot = n, n.style.position = "relative", n.style.overflow = "hidden", n.style.width = this._width + "px", n.style.height = this._height + "px", e.appendChild(n), this._layers = {}, this._zlevelList = [], this._layerConfig = {}, this._loadingEffect = new s({}), this.shapeToImage = this._createShapeToImageProcessor(), this._bgDom = document.createElement("div"), this._bgDom.style.cssText = ["position:absolute;left:0px;top:0px;width:", this._width, "px;height:", this._height + "px;", "-webkit-user-select:none;user-select;none;", "-webkit-touch-callout:none;"].join(""), this._bgDom.setAttribute("data-zr-dom-id", "bg"), this._bgDom.className = a.elementClassName, n.appendChild(this._bgDom), this._bgDom.onselectstart = t; var o = new l("_zrender_hover_", this); this._layers.hover = o, n.appendChild(o.dom), o.initContext(), o.dom.onselectstart = t, o.dom.style["-webkit-user-select"] = "none", o.dom.style["user-select"] = "none", o.dom.style["-webkit-touch-callout"] = "none", this.refreshNextFrame = null }; return h.prototype.render = function(e) { return this.isLoading() && this.hideLoading(), this.refresh(e, !0), this }, h.prototype.refresh = function(e, t) { var i = this.storage.getShapeList(!0); this._paintList(i, t); for (var n = 0; n < this._zlevelList.length; n++) { var a = this._zlevelList[n], o = this._layers[a]; !o.isBuildin && o.refresh && o.refresh() } return "function" == typeof e && e(), this }, h.prototype._preProcessLayer = function(e) { e.unusedCount++, e.updateTransform() }, h.prototype._postProcessLayer = function(e) { e.dirty = !1, 1 == e.unusedCount && e.clear() }, h.prototype._paintList = function(e, t) { "undefined" == typeof t && (t = !1), this._updateLayerStatus(e); var i, n, o; this.eachBuildinLayer(this._preProcessLayer); for (var s = 0, l = e.length; l > s; s++) { var h = e[s]; if (n !== h.zlevel && (i && (i.needTransform && o.restore(), o.flush && o.flush()), n = h.zlevel, i = this.getLayer(n), i.isBuildin || r("ZLevel " + n + " has been used by unkown layer " + i.id), o = i.ctx, i.unusedCount = 0, (i.dirty || t) && i.clear(), i.needTransform && (o.save(), i.setTransform(o))), (i.dirty || t) && !h.invisible && (!h.onbrush || h.onbrush && !h.onbrush(o, !1))) if (a.catchBrushException) try { h.brush(o, !1, this.refreshNextFrame) } catch (d) { r(d, "brush error of " + h.type, h) } else h.brush(o, !1, this.refreshNextFrame); h.__dirty = !1 } i && (i.needTransform && o.restore(), o.flush && o.flush()), this.eachBuildinLayer(this._postProcessLayer) }, h.prototype.getLayer = function(e) { var t = this._layers[e]; return t || (t = new l(e, this), t.isBuildin = !0, this._layerConfig[e] && o.merge(t, this._layerConfig[e], !0), t.updateTransform(), this.insertLayer(e, t), t.initContext()), t }, h.prototype.insertLayer = function(e, t) { if (this._layers[e]) return void r("ZLevel " + e + " has been used already"); if (!n(t)) return void r("Layer of zlevel " + e + " is not valid"); var i = this._zlevelList.length, a = null, o = -1; if (i > 0 && e > this._zlevelList[0]) { for (o = 0; i - 1 > o && !(this._zlevelList[o] < e && this._zlevelList[o + 1] > e); o++); a = this._layers[this._zlevelList[o]] } this._zlevelList.splice(o + 1, 0, e); var s = a ? a.dom : this._bgDom; s.nextSibling ? s.parentNode.insertBefore(t.dom, s.nextSibling) : s.parentNode.appendChild(t.dom), this._layers[e] = t }, h.prototype.eachLayer = function(e, t) { for (var i = 0; i < this._zlevelList.length; i++) { var n = this._zlevelList[i]; e.call(t, this._layers[n], n) } }, h.prototype.eachBuildinLayer = function(e, t) { for (var i = 0; i < this._zlevelList.length; i++) { var n = this._zlevelList[i], a = this._layers[n]; a.isBuildin && e.call(t, a, n) } }, h.prototype.eachOtherLayer = function(e, t) { for (var i = 0; i < this._zlevelList.length; i++) { var n = this._zlevelList[i], a = this._layers[n]; a.isBuildin || e.call(t, a, n) } }, h.prototype.getLayers = function() { return this._layers }, h.prototype._updateLayerStatus = function(e) { var t = this._layers, i = {}; this.eachBuildinLayer(function(e, t) { i[t] = e.elCount, e.elCount = 0 }); for (var n = 0, a = e.length; a > n; n++) { var o = e[n], r = o.zlevel, s = t[r]; if (s) { if (s.elCount++, s.dirty) continue; s.dirty = o.__dirty } } this.eachBuildinLayer(function(e, t) { i[t] !== e.elCount && (e.dirty = !0) }) }, h.prototype.refreshShapes = function(e, t) { for (var i = 0, n = e.length; n > i; i++) { var a = e[i]; a.modSelf() } return this.refresh(t), this }, h.prototype.setLoadingEffect = function(e) { return this._loadingEffect = e, this }, h.prototype.clear = function() { return this.eachBuildinLayer(this._clearLayer), this }, h.prototype._clearLayer = function(e) { e.clear() }, h.prototype.modLayer = function(e, t) { if (t) { this._layerConfig[e] ? o.merge(this._layerConfig[e], t, !0) : this._layerConfig[e] = t; var i = this._layers[e]; i && o.merge(i, this._layerConfig[e], !0) } }, h.prototype.delLayer = function(e) { var t = this._layers[e]; t && (this.modLayer(e, { position: t.position, rotation: t.rotation, scale: t.scale }), t.dom.parentNode.removeChild(t.dom), delete this._layers[e], this._zlevelList.splice(o.indexOf(this._zlevelList, e), 1)) }, h.prototype.refreshHover = function() { this.clearHover(); for (var e = this.storage.getHoverShapes(!0), t = 0, i = e.length; i > t; t++) this._brushHover(e[t]); var n = this._layers.hover.ctx; return n.flush && n.flush(), this.storage.delHover(), this }, h.prototype.clearHover = function() { var e = this._layers.hover; return e && e.clear(), this }, h.prototype.showLoading = function(e) { return this._loadingEffect && this._loadingEffect.stop(), e && this.setLoadingEffect(e), this._loadingEffect.start(this), this.loading = !0, this }, h.prototype.hideLoading = function() { return this._loadingEffect.stop(), this.clearHover(), this.loading = !1, this }, h.prototype.isLoading = function() { return this.loading }, h.prototype.resize = function() { var e = this._domRoot; e.style.display = "none"; var t = this._getWidth(), i = this._getHeight(); if (e.style.display = "", this._width != t || i != this._height) { this._width = t, this._height = i, e.style.width = t + "px", e.style.height = i + "px"; for (var n in this._layers) this._layers[n].resize(t, i); this.refresh(null, !0) } return this }, h.prototype.clearLayer = function(e) { var t = this._layers[e]; t && t.clear() }, h.prototype.dispose = function() { this.isLoading() && this.hideLoading(), this.root.innerHTML = "", this.root = this.storage = this._domRoot = this._layers = null }, h.prototype.getDomHover = function() { return this._layers.hover.dom }, h.prototype.toDataURL = function(e, t, i) { if (window.G_vmlCanvasManager) return null; var n = new l("image", this); this._bgDom.appendChild(n.dom), n.initContext(); var o = n.ctx; n.clearColor = t || "#fff", n.clear(); var s = this; this.storage.iterShape(function(e) { if (!e.invisible && (!e.onbrush || e.onbrush && !e.onbrush(o, !1))) if (a.catchBrushException) try { e.brush(o, !1, s.refreshNextFrame) } catch (t) { r(t, "brush error of " + e.type, e) } else e.brush(o, !1, s.refreshNextFrame) }, { normal: "up", update: !0 }); var h = n.dom.toDataURL(e, i); return o = null, this._bgDom.removeChild(n.dom), h }, h.prototype.getWidth = function() { return this._width }, h.prototype.getHeight = function() { return this._height }, h.prototype._getWidth = function() { var e = this.root, t = e.currentStyle || document.defaultView.getComputedStyle(e); return ((e.clientWidth || parseInt(t.width, 10)) - parseInt(t.paddingLeft, 10) - parseInt(t.paddingRight, 10)).toFixed(0) - 0 }, h.prototype._getHeight = function() { var e = this.root, t = e.currentStyle || document.defaultView.getComputedStyle(e); return ((e.clientHeight || parseInt(t.height, 10)) - parseInt(t.paddingTop, 10) - parseInt(t.paddingBottom, 10)).toFixed(0) - 0 }, h.prototype._brushHover = function(e) { var t = this._layers.hover.ctx; if (!e.onbrush || e.onbrush && !e.onbrush(t, !0)) { var i = this.getLayer(e.zlevel); if (i.needTransform && (t.save(), i.setTransform(t)), a.catchBrushException) try { e.brush(t, !0, this.refreshNextFrame) } catch (n) { r(n, "hoverBrush error of " + e.type, e) } else e.brush(t, !0, this.refreshNextFrame); i.needTransform && t.restore() } }, h.prototype._shapeToImage = function(t, i, n, a, o) { var r = document.createElement("canvas"), s = r.getContext("2d"); r.style.width = n + "px", r.style.height = a + "px", r.setAttribute("width", n * o), r.setAttribute("height", a * o), s.clearRect(0, 0, n * o, a * o); var l = { position: i.position, rotation: i.rotation, scale: i.scale }; i.position = [0, 0, 0], i.rotation = 0, i.scale = [1, 1], i && i.brush(s, !1); var h = e("./shape/Image"), d = new h({ id: t, style: { x: 0, y: 0, image: r } }); return null != l.position && (d.position = i.position = l.position), null != l.rotation && (d.rotation = i.rotation = l.rotation), null != l.scale && (d.scale = i.scale = l.scale), d }, h.prototype._createShapeToImageProcessor = function() { if (window.G_vmlCanvasManager) return i; var e = this; return function(t, i, n, o) { return e._shapeToImage(t, i, n, o, a.devicePixelRatio) } }, h }), define("zrender/Storage", ["require", "./tool/util", "./Group"], function(e) { "use strict"; function t(e, t) { return e.zlevel == t.zlevel ? e.z == t.z ? e.__renderidx - t.__renderidx : e.z - t.z : e.zlevel - t.zlevel } var i = e("./tool/util"), n = e("./Group"), a = { hover: !1, normal: "down", update: !1 }, o = function() { this._elements = {}, this._hoverElements = [], this._roots = [], this._shapeList = [], this._shapeListOffset = 0 }; return o.prototype.iterShape = function(e, t) { if (t || (t = a), t.hover) for (var i = 0, n = this._hoverElements.length; n > i; i++) { var o = this._hoverElements[i]; if (o.updateTransform(), e(o)) return this } switch (t.update && this.updateShapeList(), t.normal) { case "down": for (var n = this._shapeList.length; n--;) if (e(this._shapeList[n])) return this; break; default: for (var i = 0, n = this._shapeList.length; n > i; i++) if (e(this._shapeList[i])) return this } return this }, o.prototype.getHoverShapes = function(e) { for (var i = [], n = 0, a = this._hoverElements.length; a > n; n++) { i.push(this._hoverElements[n]); var o = this._hoverElements[n].hoverConnect; if (o) { var r; o = o instanceof Array ? o : [o]; for (var s = 0, l = o.length; l > s; s++) r = o[s].id ? o[s] : this.get(o[s]), r && i.push(r) } } if (i.sort(t), e) for (var n = 0, a = i.length; a > n; n++) i[n].updateTransform(); return i }, o.prototype.getShapeList = function(e) { return e && this.updateShapeList(), this._shapeList }, o.prototype.updateShapeList = function() { this._shapeListOffset = 0; for (var e = 0, i = this._roots.length; i > e; e++) { var n = this._roots[e]; this._updateAndAddShape(n) } this._shapeList.length = this._shapeListOffset; for (var e = 0, i = this._shapeList.length; i > e; e++) this._shapeList[e].__renderidx = e; this._shapeList.sort(t) }, o.prototype._updateAndAddShape = function(e, t) { if (!e.ignore) if (e.updateTransform(), e.clipShape && (e.clipShape.parent = e, e.clipShape.updateTransform(), t ? (t = t.slice(), t.push(e.clipShape)) : t = [e.clipShape]), "group" == e.type) { for (var i = 0; i < e._children.length; i++) { var n = e._children[i]; n.__dirty = e.__dirty || n.__dirty, this._updateAndAddShape(n, t) } e.__dirty = !1 } else e.__clipShapes = t, this._shapeList[this._shapeListOffset++] = e }, o.prototype.mod = function(e, t) { if ("string" == typeof e && (e = this._elements[e]), e && (e.modSelf(), t)) if (t.parent || t._storage || t.__clipShapes) { var n = {}; for (var a in t) "parent" !== a && "_storage" !== a && "__clipShapes" !== a && t.hasOwnProperty(a) && (n[a] = t[a]); i.merge(e, n, !0) } else i.merge(e, t, !0); return this }, o.prototype.drift = function(e, t, i) { var n = this._elements[e]; return n && (n.needTransform = !0, "horizontal" === n.draggable ? i = 0 : "vertical" === n.draggable && (t = 0), (!n.ondrift || n.ondrift && !n.ondrift(t, i)) && n.drift(t, i)), this }, o.prototype.addHover = function(e) { return e.updateNeedTransform(), this._hoverElements.push(e), this }, o.prototype.delHover = function() { return this._hoverElements = [], this }, o.prototype.hasHoverShape = function() { return this._hoverElements.length > 0 }, o.prototype.addRoot = function(e) { this._elements[e.id] || (e instanceof n && e.addChildrenToStorage(this), this.addToMap(e), this._roots.push(e)) }, o.prototype.delRoot = function(e) { if ("undefined" == typeof e) { for (var t = 0; t < this._roots.length; t++) { var a = this._roots[t]; a instanceof n && a.delChildrenFromStorage(this) } return this._elements = {}, this._hoverElements = [], this._roots = [], this._shapeList = [], void(this._shapeListOffset = 0) } if (e instanceof Array) for (var t = 0, o = e.length; o > t; t++) this.delRoot(e[t]); else { var r; r = "string" == typeof e ? this._elements[e] : e; var s = i.indexOf(this._roots, r); s >= 0 && (this.delFromMap(r.id), this._roots.splice(s, 1), r instanceof n && r.delChildrenFromStorage(this)) } }, o.prototype.addToMap = function(e) { return e instanceof n && (e._storage = this), e.modSelf(), this._elements[e.id] = e, this }, o.prototype.get = function(e) { return this._elements[e] }, o.prototype.delFromMap = function(e) { var t = this._elements[e]; return t && (delete this._elements[e], t instanceof n && (t._storage = null)), this }, o.prototype.dispose = function() { this._elements = this._renderList = this._roots = this._hoverElements = null }, o }), define("zrender/animation/Animation", ["require", "./Clip", "../tool/color", "../tool/util", "../tool/event"], function(e) { "use strict"; function t(e, t) { return e[t] } function i(e, t, i) { e[t] = i } function n(e, t, i) { return (t - e) * i + e } function a(e, t, i, a, o) { var r = e.length; if (1 == o) for (var s = 0; r > s; s++) a[s] = n(e[s], t[s], i); else for (var l = e[0].length, s = 0; r > s; s++) for (var h = 0; l > h; h++) a[s][h] = n(e[s][h], t[s][h], i) } function o(e) { switch (typeof e) { case "undefined": case "string": return !1 } return "undefined" != typeof e.length } function r(e, t, i, n, a, o, r, l, h) { var d = e.length; if (1 == h) for (var c = 0; d > c; c++) l[c] = s(e[c], t[c], i[c], n[c], a, o, r); else for (var m = e[0].length, c = 0; d > c; c++) for (var p = 0; m > p; p++) l[c][p] = s(e[c][p], t[c][p], i[c][p], n[c][p], a, o, r) } function s(e, t, i, n, a, o, r) { var s = .5 * (i - e), l = .5 * (n - t); return (2 * (t - i) + s + l) * r + (-3 * (t - i) - 2 * s - l) * o + s * a + t } function l(e) { if (o(e)) { var t = e.length; if (o(e[0])) { for (var i = [], n = 0; t > n; n++) i.push(V.call(e[n])); return i } return V.call(e) } return e } function h(e) { return e[0] = Math.floor(e[0]), e[1] = Math.floor(e[1]), e[2] = Math.floor(e[2]), "rgba(" + e.join(",") + ")" } var d = e("./Clip"), c = e("../tool/color"), m = e("../tool/util"), p = e("../tool/event").Dispatcher, u = window.requestAnimationFrame || window.msRequestAnimationFrame || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame || function(e) { setTimeout(e, 16) }, V = Array.prototype.slice, U = function(e) { e = e || {}, this.stage = e.stage || {}, this.onframe = e.onframe || function() {}, this._clips = [], this._running = !1, this._time = 0, p.call(this) }; U.prototype = { add: function(e) { this._clips.push(e) }, remove: function(e) { if (e.__inStep) e.__needsRemove = !0; else { var t = m.indexOf(this._clips, e); t >= 0 && this._clips.splice(t, 1) } }, _update: function() { for (var e = (new Date).getTime(), t = e - this._time, i = this._clips, n = i.length, a = [], o = [], r = 0; n > r; r++) { var s = i[r]; s.__inStep = !0; var l = s.step(e); s.__inStep = !1, l && (a.push(l), o.push(s)) } for (var r = 0; n > r;) i[r].__needsRemove ? (i[r] = i[n - 1], i.pop(), n--) : r++; n = a.length; for (var r = 0; n > r; r++) o[r].fire(a[r]); this._time = e, this.onframe(t), this.dispatch("frame", t), this.stage.update && this.stage.update() }, start: function() { function e() { t._running && (u(e), t._update()) } var t = this; this._running = !0, this._time = (new Date).getTime(), u(e) }, stop: function() { this._running = !1 }, clear: function() { this._clips = [] }, animate: function(e, t) { t = t || {}; var i = new g(e, t.loop, t.getter, t.setter); return i.animation = this, i }, constructor: U }, m.merge(U.prototype, p.prototype, !0); var g = function(e, n, a, o) { this._tracks = {}, this._target = e, this._loop = n || !1, this._getter = a || t, this._setter = o || i, this._clipCount = 0, this._delay = 0, this._doneList = [], this._onframeList = [], this._clipList = [] }; return g.prototype = { when: function(e, t) { for (var i in t) this._tracks[i] || (this._tracks[i] = [], 0 !== e && this._tracks[i].push({ time: 0, value: l(this._getter(this._target, i)) })), this._tracks[i].push({ time: parseInt(e, 10), value: t[i] }); return this }, during: function(e) { return this._onframeList.push(e), this }, start: function(e) { var t = this, i = this._setter, l = this._getter, m = "spline" === e, p = function() { if (t._clipCount--, 0 === t._clipCount) { t._tracks = {}; for (var e = t._doneList.length, i = 0; e > i; i++) t._doneList[i].call(t) } }, u = function(u, V) { var U = u.length; if (U) { var g = u[0].value, f = o(g), y = !1, b = f && o(g[0]) ? 2 : 1; u.sort(function(e, t) { return e.time - t.time }); var _; if (U) { _ = u[U - 1].time; for (var x = [], k = [], v = 0; U > v; v++) { x.push(u[v].time / _); var L = u[v].value; "string" == typeof L && (L = c.toArray(L), 0 === L.length && (L[0] = L[1] = L[2] = 0, L[3] = 1), y = !0), k.push(L) } var w, v, W, X, I, S, K, C = 0, T = 0; if (y) var E = [0, 0, 0, 0]; var z = function(e, o) { if (T > o) { for (w = Math.min(C + 1, U - 1), v = w; v >= 0 && !(x[v] <= o); v--); v = Math.min(v, U - 2) } else { for (v = C; U > v && !(x[v] > o); v++); v = Math.min(v - 1, U - 2) } C = v, T = o; var d = x[v + 1] - x[v]; if (0 !== d) { if (W = (o - x[v]) / d, m) if (I = k[v], X = k[0 === v ? v : v - 1], S = k[v > U - 2 ? U - 1 : v + 1], K = k[v > U - 3 ? U - 1 : v + 2], f) r(X, I, S, K, W, W * W, W * W * W, l(e, V), b); else { var c; y ? (c = r(X, I, S, K, W, W * W, W * W * W, E, 1), c = h(E)) : c = s(X, I, S, K, W, W * W, W * W * W), i(e, V, c) } else if (f) a(k[v], k[v + 1], W, l(e, V), b); else { var c; y ? (a(k[v], k[v + 1], W, E, 1), c = h(E)) : c = n(k[v], k[v + 1], W), i(e, V, c) } for (v = 0; v < t._onframeList.length; v++) t._onframeList[v](e, o); } }, A = new d({ target: t._target, life: _, loop: t._loop, delay: t._delay, onframe: z, ondestroy: p }); e && "spline" !== e && (A.easing = e), t._clipList.push(A), t._clipCount++, t.animation.add(A) } } }; for (var V in this._tracks) u(this._tracks[V], V); return this }, stop: function() { for (var e = 0; e < this._clipList.length; e++) { var t = this._clipList[e]; this.animation.remove(t) } this._clipList = [] }, delay: function(e) { return this._delay = e, this }, done: function(e) { return e && this._doneList.push(e), this } }, U }), define("zrender/tool/vector", [], function() { var e = "undefined" == typeof Float32Array ? Array : Float32Array, t = { create: function(t, i) { var n = new e(2); return n[0] = t || 0, n[1] = i || 0, n }, copy: function(e, t) { return e[0] = t[0], e[1] = t[1], e }, clone: function(t) { var i = new e(2); return i[0] = t[0], i[1] = t[1], i }, set: function(e, t, i) { return e[0] = t, e[1] = i, e }, add: function(e, t, i) { return e[0] = t[0] + i[0], e[1] = t[1] + i[1], e }, scaleAndAdd: function(e, t, i, n) { return e[0] = t[0] + i[0] * n, e[1] = t[1] + i[1] * n, e }, sub: function(e, t, i) { return e[0] = t[0] - i[0], e[1] = t[1] - i[1], e }, len: function(e) { return Math.sqrt(this.lenSquare(e)) }, lenSquare: function(e) { return e[0] * e[0] + e[1] * e[1] }, mul: function(e, t, i) { return e[0] = t[0] * i[0], e[1] = t[1] * i[1], e }, div: function(e, t, i) { return e[0] = t[0] / i[0], e[1] = t[1] / i[1], e }, dot: function(e, t) { return e[0] * t[0] + e[1] * t[1] }, scale: function(e, t, i) { return e[0] = t[0] * i, e[1] = t[1] * i, e }, normalize: function(e, i) { var n = t.len(i); return 0 === n ? (e[0] = 0, e[1] = 0) : (e[0] = i[0] / n, e[1] = i[1] / n), e }, distance: function(e, t) { return Math.sqrt((e[0] - t[0]) * (e[0] - t[0]) + (e[1] - t[1]) * (e[1] - t[1])) }, distanceSquare: function(e, t) { return (e[0] - t[0]) * (e[0] - t[0]) + (e[1] - t[1]) * (e[1] - t[1]) }, negate: function(e, t) { return e[0] = -t[0], e[1] = -t[1], e }, lerp: function(e, t, i, n) { return e[0] = t[0] + n * (i[0] - t[0]), e[1] = t[1] + n * (i[1] - t[1]), e }, applyTransform: function(e, t, i) { var n = t[0], a = t[1]; return e[0] = i[0] * n + i[2] * a + i[4], e[1] = i[1] * n + i[3] * a + i[5], e }, min: function(e, t, i) { return e[0] = Math.min(t[0], i[0]), e[1] = Math.min(t[1], i[1]), e }, max: function(e, t, i) { return e[0] = Math.max(t[0], i[0]), e[1] = Math.max(t[1], i[1]), e } }; return t.length = t.len, t.lengthSquare = t.lenSquare, t.dist = t.distance, t.distSquare = t.distanceSquare, t }), define("zrender/tool/matrix", [], function() { var e = "undefined" == typeof Float32Array ? Array : Float32Array, t = { create: function() { var i = new e(6); return t.identity(i), i }, identity: function(e) { return e[0] = 1, e[1] = 0, e[2] = 0, e[3] = 1, e[4] = 0, e[5] = 0, e }, copy: function(e, t) { return e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e[4] = t[4], e[5] = t[5], e }, mul: function(e, t, i) { return e[0] = t[0] * i[0] + t[2] * i[1], e[1] = t[1] * i[0] + t[3] * i[1], e[2] = t[0] * i[2] + t[2] * i[3], e[3] = t[1] * i[2] + t[3] * i[3], e[4] = t[0] * i[4] + t[2] * i[5] + t[4], e[5] = t[1] * i[4] + t[3] * i[5] + t[5], e }, translate: function(e, t, i) { return e[0] = t[0], e[1] = t[1], e[2] = t[2], e[3] = t[3], e[4] = t[4] + i[0], e[5] = t[5] + i[1], e }, rotate: function(e, t, i) { var n = t[0], a = t[2], o = t[4], r = t[1], s = t[3], l = t[5], h = Math.sin(i), d = Math.cos(i); return e[0] = n * d + r * h, e[1] = -n * h + r * d, e[2] = a * d + s * h, e[3] = -a * h + d * s, e[4] = d * o + h * l, e[5] = d * l - h * o, e }, scale: function(e, t, i) { var n = i[0], a = i[1]; return e[0] = t[0] * n, e[1] = t[1] * a, e[2] = t[2] * n, e[3] = t[3] * a, e[4] = t[4] * n, e[5] = t[5] * a, e }, invert: function(e, t) { var i = t[0], n = t[2], a = t[4], o = t[1], r = t[3], s = t[5], l = i * r - o * n; return l ? (l = 1 / l, e[0] = r * l, e[1] = -o * l, e[2] = -n * l, e[3] = i * l, e[4] = (n * s - r * a) * l, e[5] = (o * a - i * s) * l, e) : null } }; return t }), define("zrender/loadingEffect/Base", ["require", "../tool/util", "../shape/Text", "../shape/Rectangle"], function(e) { function t(e) { this.setOptions(e) } var i = e("../tool/util"), n = e("../shape/Text"), a = e("../shape/Rectangle"), o = "Loading...", r = "normal 16px Arial"; return t.prototype.createTextShape = function(e) { return new n({ highlightStyle: i.merge({ x: this.canvasWidth / 2, y: this.canvasHeight / 2, text: o, textAlign: "center", textBaseline: "middle", textFont: r, color: "#333", brushType: "fill" }, e, !0) }) }, t.prototype.createBackgroundShape = function(e) { return new a({ highlightStyle: { x: 0, y: 0, width: this.canvasWidth, height: this.canvasHeight, brushType: "fill", color: e } }) }, t.prototype.start = function(e) { function t(t) { e.storage.addHover(t) } function i() { e.refreshHover() } this.canvasWidth = e._width, this.canvasHeight = e._height, this.loadingTimer = this._start(t, i) }, t.prototype._start = function() { return setInterval(function() {}, 1e4) }, t.prototype.stop = function() { clearInterval(this.loadingTimer) }, t.prototype.setOptions = function(e) { this.options = e || {} }, t.prototype.adjust = function(e, t) { return e <= t[0] ? e = t[0] : e >= t[1] && (e = t[1]), e }, t.prototype.getLocation = function(e, t, i) { var n = null != e.x ? e.x : "center"; switch (n) { case "center": n = Math.floor((this.canvasWidth - t) / 2); break; case "left": n = 0; break; case "right": n = this.canvasWidth - t } var a = null != e.y ? e.y : "center"; switch (a) { case "center": a = Math.floor((this.canvasHeight - i) / 2); break; case "top": a = 0; break; case "bottom": a = this.canvasHeight - i } return { x: n, y: a, width: t, height: i } }, t }), define("zrender/Layer", ["require", "./mixin/Transformable", "./tool/util", "./config"], function(e) { function t() { return !1 } function i(e, t, i) { var n = document.createElement(t), a = i.getWidth(), o = i.getHeight(); return n.style.position = "absolute", n.style.left = 0, n.style.top = 0, n.style.width = a + "px", n.style.height = o + "px", n.width = a * r.devicePixelRatio, n.height = o * r.devicePixelRatio, n.setAttribute("data-zr-dom-id", e), n } var n = e("./mixin/Transformable"), a = e("./tool/util"), o = window.G_vmlCanvasManager, r = e("./config"), s = function(e, a) { this.id = e, this.dom = i(e, "canvas", a), this.dom.onselectstart = t, this.dom.style["-webkit-user-select"] = "none", this.dom.style["user-select"] = "none", this.dom.style["-webkit-touch-callout"] = "none", this.dom.style["-webkit-tap-highlight-color"] = "rgba(0,0,0,0)", this.dom.className = r.elementClassName, o && o.initElement(this.dom), this.domBack = null, this.ctxBack = null, this.painter = a, this.unusedCount = 0, this.config = null, this.dirty = !0, this.elCount = 0, this.clearColor = 0, this.motionBlur = !1, this.lastFrameAlpha = .7, this.zoomable = !1, this.panable = !1, this.maxZoom = 1 / 0, this.minZoom = 0, n.call(this) }; return s.prototype.initContext = function() { this.ctx = this.dom.getContext("2d"); var e = r.devicePixelRatio; 1 != e && this.ctx.scale(e, e) }, s.prototype.createBackBuffer = function() { if (!o) { this.domBack = i("back-" + this.id, "canvas", this.painter), this.ctxBack = this.domBack.getContext("2d"); var e = r.devicePixelRatio; 1 != e && this.ctxBack.scale(e, e) } }, s.prototype.resize = function(e, t) { var i = r.devicePixelRatio; this.dom.style.width = e + "px", this.dom.style.height = t + "px", this.dom.setAttribute("width", e * i), this.dom.setAttribute("height", t * i), 1 != i && this.ctx.scale(i, i), this.domBack && (this.domBack.setAttribute("width", e * i), this.domBack.setAttribute("height", t * i), 1 != i && this.ctxBack.scale(i, i)) }, s.prototype.clear = function() { var e = this.dom, t = this.ctx, i = e.width, n = e.height, a = this.clearColor && !o, s = this.motionBlur && !o, l = this.lastFrameAlpha, h = r.devicePixelRatio; if (s && (this.domBack || this.createBackBuffer(), this.ctxBack.globalCompositeOperation = "copy", this.ctxBack.drawImage(e, 0, 0, i / h, n / h)), t.clearRect(0, 0, i / h, n / h), a && (t.save(), t.fillStyle = this.clearColor, t.fillRect(0, 0, i / h, n / h), t.restore()), s) { var d = this.domBack; t.save(), t.globalAlpha = l, t.drawImage(d, 0, 0, i / h, n / h), t.restore() } }, a.merge(s.prototype, n.prototype), s }), define("zrender/shape/Text", ["require", "../tool/area", "./Base", "../tool/util"], function(e) { var t = e("../tool/area"), i = e("./Base"), n = function(e) { i.call(this, e) }; return n.prototype = { type: "text", brush: function(e, i) { var n = this.style; if (i && (n = this.getHighlightStyle(n, this.highlightStyle || {})), "undefined" != typeof n.text && n.text !== !1) { e.save(), this.doClip(e), this.setContext(e, n), this.setTransform(e), n.textFont && (e.font = n.textFont), e.textAlign = n.textAlign || "start", e.textBaseline = n.textBaseline || "middle"; var a, o = (n.text + "").split("\n"), r = t.getTextHeight("国", n.textFont), s = this.getRect(n), l = n.x; a = "top" == n.textBaseline ? s.y : "bottom" == n.textBaseline ? s.y + r : s.y + r / 2; for (var h = 0, d = o.length; d > h; h++) { if (n.maxWidth) switch (n.brushType) { case "fill": e.fillText(o[h], l, a, n.maxWidth); break; case "stroke": e.strokeText(o[h], l, a, n.maxWidth); break; case "both": e.fillText(o[h], l, a, n.maxWidth), e.strokeText(o[h], l, a, n.maxWidth); break; default: e.fillText(o[h], l, a, n.maxWidth) } else switch (n.brushType) { case "fill": e.fillText(o[h], l, a); break; case "stroke": e.strokeText(o[h], l, a); break; case "both": e.fillText(o[h], l, a), e.strokeText(o[h], l, a); break; default: e.fillText(o[h], l, a) } a += r } e.restore() } }, getRect: function(e) { if (e.__rect) return e.__rect; var i = t.getTextWidth(e.text, e.textFont), n = t.getTextHeight(e.text, e.textFont), a = e.x; "end" == e.textAlign || "right" == e.textAlign ? a -= i : "center" == e.textAlign && (a -= i / 2); var o; return o = "top" == e.textBaseline ? e.y : "bottom" == e.textBaseline ? e.y - n : e.y - n / 2, e.__rect = { x: a, y: o, width: i, height: n }, e.__rect } }, e("../tool/util").inherits(n, i), n }), define("zrender/shape/Rectangle", ["require", "./Base", "../tool/util"], function(e) { var t = e("./Base"), i = function(e) { t.call(this, e) }; return i.prototype = { type: "rectangle", _buildRadiusPath: function(e, t) { var i, n, a, o, r = t.x, s = t.y, l = t.width, h = t.height, d = t.radius; "number" == typeof d ? i = n = a = o = d : d instanceof Array ? 1 === d.length ? i = n = a = o = d[0] : 2 === d.length ? (i = a = d[0], n = o = d[1]) : 3 === d.length ? (i = d[0], n = o = d[1], a = d[2]) : (i = d[0], n = d[1], a = d[2], o = d[3]) : i = n = a = o = 0; var c; i + n > l && (c = i + n, i *= l / c, n *= l / c), a + o > l && (c = a + o, a *= l / c, o *= l / c), n + a > h && (c = n + a, n *= h / c, a *= h / c), i + o > h && (c = i + o, i *= h / c, o *= h / c), e.moveTo(r + i, s), e.lineTo(r + l - n, s), 0 !== n && e.quadraticCurveTo(r + l, s, r + l, s + n), e.lineTo(r + l, s + h - a), 0 !== a && e.quadraticCurveTo(r + l, s + h, r + l - a, s + h), e.lineTo(r + o, s + h), 0 !== o && e.quadraticCurveTo(r, s + h, r, s + h - o), e.lineTo(r, s + i), 0 !== i && e.quadraticCurveTo(r, s, r + i, s) }, buildPath: function(e, t) { t.radius ? this._buildRadiusPath(e, t) : (e.moveTo(t.x, t.y), e.lineTo(t.x + t.width, t.y), e.lineTo(t.x + t.width, t.y + t.height), e.lineTo(t.x, t.y + t.height), e.lineTo(t.x, t.y)), e.closePath() }, getRect: function(e) { if (e.__rect) return e.__rect; var t; return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = { x: Math.round(e.x - t / 2), y: Math.round(e.y - t / 2), width: e.width + t, height: e.height + t }, e.__rect } }, e("../tool/util").inherits(i, t), i }), define("zrender/tool/area", ["require", "./util", "./curve"], function(e) { "use strict"; function t(e) { return e %= C, 0 > e && (e += C), e } function i(e, t, i, o) { if (!t || !e) return !1; var r = e.type; v = v || L.getContext(); var s = n(e, t, i, o); if ("undefined" != typeof s) return s; if (e.buildPath && v.isPointInPath) return a(e, v, t, i, o); switch (r) { case "ellipse": return !0; case "trochoid": var l = "out" == t.location ? t.r1 + t.r2 + t.d : t.r1 - t.r2 + t.d; return p(t, i, o, l); case "rose": return p(t, i, o, t.maxr); default: return !1 } } function n(e, t, i, n) { var a = e.type; switch (a) { case "bezier-curve": return "undefined" == typeof t.cpX2 ? l(t.xStart, t.yStart, t.cpX1, t.cpY1, t.xEnd, t.yEnd, t.lineWidth, i, n) : s(t.xStart, t.yStart, t.cpX1, t.cpY1, t.cpX2, t.cpY2, t.xEnd, t.yEnd, t.lineWidth, i, n); case "line": return r(t.xStart, t.yStart, t.xEnd, t.yEnd, t.lineWidth, i, n); case "polyline": return d(t.pointList, t.lineWidth, i, n); case "ring": return c(t.x, t.y, t.r0, t.r, i, n); case "circle": return p(t.x, t.y, t.r, i, n); case "sector": var o = t.startAngle * Math.PI / 180, h = t.endAngle * Math.PI / 180; return t.clockWise || (o = -o, h = -h), u(t.x, t.y, t.r0, t.r, o, h, !t.clockWise, i, n); case "path": return t.pathArray && _(t.pathArray, Math.max(t.lineWidth, 5), t.brushType, i, n); case "polygon": case "star": case "isogon": return V(t.pointList, i, n); case "text": var U = t.__rect || e.getRect(t); return m(U.x, U.y, U.width, U.height, i, n); case "rectangle": case "image": return m(t.x, t.y, t.width, t.height, i, n) } } function a(e, t, i, n, a) { return t.beginPath(), e.buildPath(t, i), t.closePath(), t.isPointInPath(n, a) } function o(e, t, n, a) { return !i(e, t, n, a) } function r(e, t, i, n, a, o, r) { if (0 === a) return !1; var s = Math.max(a, 5), l = 0, h = e; if (r > t + s && r > n + s || t - s > r && n - s > r || o > e + s && o > i + s || e - s > o && i - s > o) return !1; if (e === i) return Math.abs(o - e) <= s / 2; l = (t - n) / (e - i), h = (e * n - i * t) / (e - i); var d = l * o - r + h, c = d * d / (l * l + 1); return s / 2 * s / 2 >= c } function s(e, t, i, n, a, o, r, s, l, h, d) { if (0 === l) return !1; var c = Math.max(l, 5); if (d > t + c && d > n + c && d > o + c && d > s + c || t - c > d && n - c > d && o - c > d && s - c > d || h > e + c && h > i + c && h > a + c && h > r + c || e - c > h && i - c > h && a - c > h && r - c > h) return !1; var m = w.cubicProjectPoint(e, t, i, n, a, o, r, s, h, d, null); return c / 2 >= m } function l(e, t, i, n, a, o, r, s, l) { if (0 === r) return !1; var h = Math.max(r, 5); if (l > t + h && l > n + h && l > o + h || t - h > l && n - h > l && o - h > l || s > e + h && s > i + h && s > a + h || e - h > s && i - h > s && a - h > s) return !1; var d = w.quadraticProjectPoint(e, t, i, n, a, o, s, l, null); return h / 2 >= d } function h(e, i, n, a, o, r, s, l, h) { if (0 === s) return !1; var d = Math.max(s, 5); l -= e, h -= i; var c = Math.sqrt(l * l + h * h); if (c - d > n || n > c + d) return !1; if (Math.abs(a - o) >= C) return !0; if (r) { var m = a; a = t(o), o = t(m) } else a = t(a), o = t(o); a > o && (o += C); var p = Math.atan2(h, l); return 0 > p && (p += C), p >= a && o >= p || p + C >= a && o >= p + C } function d(e, t, i, n) { for (var t = Math.max(t, 10), a = 0, o = e.length - 1; o > a; a++) { var s = e[a][0], l = e[a][1], h = e[a + 1][0], d = e[a + 1][1]; if (r(s, l, h, d, t, i, n)) return !0 } return !1 } function c(e, t, i, n, a, o) { var r = (a - e) * (a - e) + (o - t) * (o - t); return n * n > r && r > i * i } function m(e, t, i, n, a, o) { return a >= e && e + i >= a && o >= t && t + n >= o } function p(e, t, i, n, a) { return i * i > (n - e) * (n - e) + (a - t) * (a - t) } function u(e, t, i, n, a, o, r, s, l) { return h(e, t, (i + n) / 2, a, o, r, n - i, s, l) } function V(e, t, i) { for (var n = e.length, a = 0, o = 0, r = n - 1; n > o; o++) { var s = e[r][0], l = e[r][1], h = e[o][0], d = e[o][1]; a += U(s, l, h, d, t, i), r = o } return 0 !== a } function U(e, t, i, n, a, o) { if (o > t && o > n || t > o && n > o) return 0; if (n == t) return 0; var r = t > n ? 1 : -1, s = (o - t) / (n - t), l = s * (i - e) + e; return l > a ? r : 0 } function g() { var e = E[0]; E[0] = E[1], E[1] = e } function f(e, t, i, n, a, o, r, s, l, h) { if (h > t && h > n && h > o && h > s || t > h && n > h && o > h && s > h) return 0; var d = w.cubicRootAt(t, n, o, s, h, T); if (0 === d) return 0; for (var c, m, p = 0, u = -1, V = 0; d > V; V++) { var U = T[V], f = w.cubicAt(e, i, a, r, U); l > f || (0 > u && (u = w.cubicExtrema(t, n, o, s, E), E[1] < E[0] && u > 1 && g(), c = w.cubicAt(t, n, o, s, E[0]), u > 1 && (m = w.cubicAt(t, n, o, s, E[1]))), p += 2 == u ? U < E[0] ? t > c ? 1 : -1 : U < E[1] ? c > m ? 1 : -1 : m > s ? 1 : -1 : U < E[0] ? t > c ? 1 : -1 : c > s ? 1 : -1) } return p } function y(e, t, i, n, a, o, r, s) { if (s > t && s > n && s > o || t > s && n > s && o > s) return 0; var l = w.quadraticRootAt(t, n, o, s, T); if (0 === l) return 0; var h = w.quadraticExtremum(t, n, o); if (h >= 0 && 1 >= h) { for (var d = 0, c = w.quadraticAt(t, n, o, h), m = 0; l > m; m++) { var p = w.quadraticAt(e, i, a, T[m]); r > p || (d += T[m] < h ? t > c ? 1 : -1 : c > o ? 1 : -1) } return d } var p = w.quadraticAt(e, i, a, T[0]); return r > p ? 0 : t > o ? 1 : -1 } function b(e, i, n, a, o, r, s, l) { if (l -= i, l > n || -n > l) return 0; var h = Math.sqrt(n * n - l * l); if (T[0] = -h, T[1] = h, Math.abs(a - o) >= C) { a = 0, o = C; var d = r ? 1 : -1; return s >= T[0] + e && s <= T[1] + e ? d : 0 } if (r) { var h = a; a = t(o), o = t(h) } else a = t(a), o = t(o); a > o && (o += C); for (var c = 0, m = 0; 2 > m; m++) { var p = T[m]; if (p + e > s) { var u = Math.atan2(l, p), d = r ? 1 : -1; 0 > u && (u = C + u), (u >= a && o >= u || u + C >= a && o >= u + C) && (u > Math.PI / 2 && u < 1.5 * Math.PI && (d = -d), c += d) } } return c } function _(e, t, i, n, a) { var o = 0, d = 0, c = 0, m = 0, p = 0, u = !0, V = !0; i = i || "fill"; for (var g = "stroke" === i || "both" === i, _ = "fill" === i || "both" === i, x = 0; x < e.length; x++) { var k = e[x], v = k.points; if (u || "M" === k.command) { if (x > 0 && (_ && (o += U(d, c, m, p, n, a)), 0 !== o)) return !0; m = v[v.length - 2], p = v[v.length - 1], u = !1, V && "A" !== k.command && (V = !1, d = m, c = p) } switch (k.command) { case "M": d = v[0], c = v[1]; break; case "L": if (g && r(d, c, v[0], v[1], t, n, a)) return !0; _ && (o += U(d, c, v[0], v[1], n, a)), d = v[0], c = v[1]; break; case "C": if (g && s(d, c, v[0], v[1], v[2], v[3], v[4], v[5], t, n, a)) return !0; _ && (o += f(d, c, v[0], v[1], v[2], v[3], v[4], v[5], n, a)), d = v[4], c = v[5]; break; case "Q": if (g && l(d, c, v[0], v[1], v[2], v[3], t, n, a)) return !0; _ && (o += y(d, c, v[0], v[1], v[2], v[3], n, a)), d = v[2], c = v[3]; break; case "A": var L = v[0], w = v[1], W = v[2], X = v[3], I = v[4], S = v[5], K = Math.cos(I) * W + L, C = Math.sin(I) * X + w; V ? (V = !1, m = K, p = C) : o += U(d, c, K, C); var T = (n - L) * X / W + L; if (g && h(L, w, X, I, I + S, 1 - v[7], t, T, a)) return !0; _ && (o += b(L, w, X, I, I + S, 1 - v[7], T, a)), d = Math.cos(I + S) * W + L, c = Math.sin(I + S) * X + w; break; case "z": if (g && r(d, c, m, p, t, n, a)) return !0; u = !0 } } return _ && (o += U(d, c, m, p, n, a)), 0 !== o } function x(e, t) { var i = e + ":" + t; if (W[i]) return W[i]; v = v || L.getContext(), v.save(), t && (v.font = t), e = (e + "").split("\n"); for (var n = 0, a = 0, o = e.length; o > a; a++) n = Math.max(v.measureText(e[a]).width, n); return v.restore(), W[i] = n, ++I > K && (I = 0, W = {}), n } function k(e, t) { var i = e + ":" + t; if (X[i]) return X[i]; v = v || L.getContext(), v.save(), t && (v.font = t), e = (e + "").split("\n"); var n = (v.measureText("国").width + 2) * e.length; return v.restore(), X[i] = n, ++S > K && (S = 0, X = {}), n } var v, L = e("./util"), w = e("./curve"), W = {}, X = {}, I = 0, S = 0, K = 5e3, C = 2 * Math.PI, T = [-1, -1, -1], E = [-1, -1]; return { isInside: i, isOutside: o, getTextWidth: x, getTextHeight: k, isInsidePath: _, isInsidePolygon: V, isInsideSector: u, isInsideCircle: p, isInsideLine: r, isInsideRect: m, isInsidePolyline: d, isInsideCubicStroke: s, isInsideQuadraticStroke: l } }), define("zrender/shape/Base", ["require", "../tool/matrix", "../tool/guid", "../tool/util", "../tool/log", "../mixin/Transformable", "../mixin/Eventful", "../tool/area", "../tool/color"], function(e) { function t(t, n, a, o, r, s, l) { r && (t.font = r), t.textAlign = s, t.textBaseline = l; var h = i(n, a, o, r, s, l); n = (n + "").split("\n"); var d = e("../tool/area").getTextHeight("国", r); switch (l) { case "top": o = h.y; break; case "bottom": o = h.y + d; break; default: o = h.y + d / 2 } for (var c = 0, m = n.length; m > c; c++) t.fillText(n[c], a, o), o += d } function i(t, i, n, a, o, r) { var s = e("../tool/area"), l = s.getTextWidth(t, a), h = s.getTextHeight("国", a); switch (t = (t + "").split("\n"), o) { case "end": case "right": i -= l; break; case "center": i -= l / 2 } switch (r) { case "top": break; case "bottom": n -= h * t.length; break; default: n -= h * t.length / 2 } return { x: i, y: n, width: l, height: h * t.length } } var n = window.G_vmlCanvasManager, a = e("../tool/matrix"), o = e("../tool/guid"), r = e("../tool/util"), s = e("../tool/log"), l = e("../mixin/Transformable"), h = e("../mixin/Eventful"), d = function(e) { e = e || {}, this.id = e.id || o(); for (var t in e) this[t] = e[t]; this.style = this.style || {}, this.highlightStyle = this.highlightStyle || null, this.parent = null, this.__dirty = !0, this.__clipShapes = [], l.call(this), h.call(this) }; d.prototype.invisible = !1, d.prototype.ignore = !1, d.prototype.zlevel = 0, d.prototype.draggable = !1, d.prototype.clickable = !1, d.prototype.hoverable = !0, d.prototype.z = 0, d.prototype.brush = function(e, t) { var i = this.beforeBrush(e, t); switch (e.beginPath(), this.buildPath(e, i), i.brushType) { case "both": e.fill(); case "stroke": i.lineWidth > 0 && e.stroke(); break; default: e.fill() } this.drawText(e, i, this.style), this.afterBrush(e) }, d.prototype.beforeBrush = function(e, t) { var i = this.style; return this.brushTypeOnly && (i.brushType = this.brushTypeOnly), t && (i = this.getHighlightStyle(i, this.highlightStyle || {}, this.brushTypeOnly)), "stroke" == this.brushTypeOnly && (i.strokeColor = i.strokeColor || i.color), e.save(), this.doClip(e), this.setContext(e, i), this.setTransform(e), i }, d.prototype.afterBrush = function(e) { e.restore() }; var c = [ ["color", "fillStyle"], ["strokeColor", "strokeStyle"], ["opacity", "globalAlpha"], ["lineCap", "lineCap"], ["lineJoin", "lineJoin"], ["miterLimit", "miterLimit"], ["lineWidth", "lineWidth"], ["shadowBlur", "shadowBlur"], ["shadowColor", "shadowColor"], ["shadowOffsetX", "shadowOffsetX"], ["shadowOffsetY", "shadowOffsetY"] ]; d.prototype.setContext = function(e, t) { for (var i = 0, n = c.length; n > i; i++) { var a = c[i][0], o = t[a], r = c[i][1]; "undefined" != typeof o && (e[r] = o) } }; var m = a.create(); return d.prototype.doClip = function(e) { if (this.__clipShapes && !n) for (var t = 0; t < this.__clipShapes.length; t++) { var i = this.__clipShapes[t]; if (i.needTransform) { var o = i.transform; a.invert(m, o), e.transform(o[0], o[1], o[2], o[3], o[4], o[5]) } if (e.beginPath(), i.buildPath(e, i.style), e.clip(), i.needTransform) { var o = m; e.transform(o[0], o[1], o[2], o[3], o[4], o[5]) } } }, d.prototype.getHighlightStyle = function(t, i, n) { var a = {}; for (var o in t) a[o] = t[o]; var r = e("../tool/color"), s = r.getHighlightColor(); "stroke" != t.brushType ? (a.strokeColor = s, a.lineWidth = (t.lineWidth || 1) + this.getHighlightZoom(), a.brushType = "both") : "stroke" != n ? (a.strokeColor = s, a.lineWidth = (t.lineWidth || 1) + this.getHighlightZoom()) : a.strokeColor = i.strokeColor || r.mix(t.strokeColor, r.toRGB(s)); for (var o in i) "undefined" != typeof i[o] && (a[o] = i[o]); return a }, d.prototype.getHighlightZoom = function() { return "text" != this.type ? 6 : 2 }, d.prototype.drift = function(e, t) { this.position[0] += e, this.position[1] += t }, d.prototype.buildPath = function() { s("buildPath not implemented in " + this.type) }, d.prototype.getRect = function() { s("getRect not implemented in " + this.type) }, d.prototype.isCover = function(t, i) { var n = this.transformCoordToLocal(t, i); return t = n[0], i = n[1], this.isCoverRect(t, i) ? e("../tool/area").isInside(this, this.style, t, i) : !1 }, d.prototype.isCoverRect = function(e, t) { var i = this.style.__rect; return i || (i = this.style.__rect = this.getRect(this.style)), e >= i.x && e <= i.x + i.width && t >= i.y && t <= i.y + i.height }, d.prototype.drawText = function(e, i, n) { if ("undefined" != typeof i.text && i.text !== !1) { var a = i.textColor || i.color || i.strokeColor; e.fillStyle = a; var o, r, s, l, h = 10, d = i.textPosition || this.textPosition || "top"; switch (d) { case "inside": case "top": case "bottom": case "left": case "right": if (this.getRect) { var c = (n || i).__rect || this.getRect(n || i); switch (d) { case "inside": s = c.x + c.width / 2, l = c.y + c.height / 2, o = "center", r = "middle", "stroke" != i.brushType && a == i.color && (e.fillStyle = "#fff"); break; case "left": s = c.x - h, l = c.y + c.height / 2, o = "end", r = "middle"; break; case "right": s = c.x + c.width + h, l = c.y + c.height / 2, o = "start", r = "middle"; break; case "top": s = c.x + c.width / 2, l = c.y - h, o = "center", r = "bottom"; break; case "bottom": s = c.x + c.width / 2, l = c.y + c.height + h, o = "center", r = "top" } } break; case "start": case "end": var m = i.pointList || [ [i.xStart || 0, i.yStart || 0], [i.xEnd || 0, i.yEnd || 0] ], p = m.length; if (2 > p) return; var u, V, U, g; switch (d) { case "start": u = m[1][0], V = m[0][0], U = m[1][1], g = m[0][1]; break; case "end": u = m[p - 2][0], V = m[p - 1][0], U = m[p - 2][1], g = m[p - 1][1] } s = V, l = g; var f = Math.atan((U - g) / (V - u)) / Math.PI * 180; 0 > V - u ? f += 180 : 0 > U - g && (f += 360), h = 5, f >= 30 && 150 >= f ? (o = "center", r = "bottom", l -= h) : f > 150 && 210 > f ? (o = "right", r = "middle", s -= h) : f >= 210 && 330 >= f ? (o = "center", r = "top", l += h) : (o = "left", r = "middle", s += h); break; case "specific": s = i.textX || 0, l = i.textY || 0, o = "start", r = "middle" } null != s && null != l && t(e, i.text, s, l, i.textFont, i.textAlign || o, i.textBaseline || r) } }, d.prototype.modSelf = function() { this.__dirty = !0, this.style && (this.style.__rect = null), this.highlightStyle && (this.highlightStyle.__rect = null) }, d.prototype.isSilent = function() { return !(this.hoverable || this.draggable || this.clickable || this.onmousemove || this.onmouseover || this.onmouseout || this.onmousedown || this.onmouseup || this.onclick || this.ondragenter || this.ondragover || this.ondragleave || this.ondrop) }, r.merge(d.prototype, l.prototype, !0), r.merge(d.prototype, h.prototype, !0), d }), define("zrender/tool/curve", ["require", "./vector"], function(e) { function t(e) { return e > -U && U > e } function i(e) { return e > U || -U > e } function n(e, t, i, n, a) { var o = 1 - a; return o * o * (o * e + 3 * a * t) + a * a * (a * n + 3 * o * i) } function a(e, t, i, n, a) { var o = 1 - a; return 3 * (((t - e) * o + 2 * (i - t) * a) * o + (n - i) * a * a) } function o(e, i, n, a, o, r) { var s = a + 3 * (i - n) - e, l = 3 * (n - 2 * i + e), h = 3 * (i - e), d = e - o, c = l * l - 3 * s * h, m = l * h - 9 * s * d, p = h * h - 3 * l * d, u = 0; if (t(c) && t(m)) if (t(l)) r[0] = 0; else { var V = -h / l; V >= 0 && 1 >= V && (r[u++] = V) } else { var U = m * m - 4 * c * p; if (t(U)) { var y = m / c, V = -l / s + y, b = -y / 2; V >= 0 && 1 >= V && (r[u++] = V), b >= 0 && 1 >= b && (r[u++] = b) } else if (U > 0) { var _ = Math.sqrt(U), x = c * l + 1.5 * s * (-m + _), k = c * l + 1.5 * s * (-m - _); x = 0 > x ? -Math.pow(-x, f) : Math.pow(x, f), k = 0 > k ? -Math.pow(-k, f) : Math.pow(k, f); var V = (-l - (x + k)) / (3 * s); V >= 0 && 1 >= V && (r[u++] = V) } else { var v = (2 * c * l - 3 * s * m) / (2 * Math.sqrt(c * c * c)), L = Math.acos(v) / 3, w = Math.sqrt(c), W = Math.cos(L), V = (-l - 2 * w * W) / (3 * s), b = (-l + w * (W + g * Math.sin(L))) / (3 * s), X = (-l + w * (W - g * Math.sin(L))) / (3 * s); V >= 0 && 1 >= V && (r[u++] = V), b >= 0 && 1 >= b && (r[u++] = b), X >= 0 && 1 >= X && (r[u++] = X) } } return u } function r(e, n, a, o, r) { var s = 6 * a - 12 * n + 6 * e, l = 9 * n + 3 * o - 3 * e - 9 * a, h = 3 * n - 3 * e, d = 0; if (t(l)) { if (i(s)) { var c = -h / s; c >= 0 && 1 >= c && (r[d++] = c) } } else { var m = s * s - 4 * l * h; if (t(m)) r[0] = -s / (2 * l); else if (m > 0) { var p = Math.sqrt(m), c = (-s + p) / (2 * l), u = (-s - p) / (2 * l); c >= 0 && 1 >= c && (r[d++] = c), u >= 0 && 1 >= u && (r[d++] = u) } } return d } function s(e, t, i, n, a, o) { var r = (t - e) * a + e, s = (i - t) * a + t, l = (n - i) * a + i, h = (s - r) * a + r, d = (l - s) * a + s, c = (d - h) * a + h; o[0] = e, o[1] = r, o[2] = h, o[3] = c, o[4] = c, o[5] = d, o[6] = l, o[7] = n } function l(e, t, i, a, o, r, s, l, h, d, c) { var m, p = .005, u = 1 / 0; y[0] = h, y[1] = d; for (var g = 0; 1 > g; g += .05) { b[0] = n(e, i, o, s, g), b[1] = n(t, a, r, l, g); var f = V.distSquare(y, b); u > f && (m = g, u = f) } u = 1 / 0; for (var x = 0; 32 > x && !(U > p); x++) { var k = m - p, v = m + p; b[0] = n(e, i, o, s, k), b[1] = n(t, a, r, l, k); var f = V.distSquare(b, y); if (k >= 0 && u > f) m = k, u = f; else { _[0] = n(e, i, o, s, v), _[1] = n(t, a, r, l, v); var L = V.distSquare(_, y); 1 >= v && u > L ? (m = v, u = L) : p *= .5 } } return c && (c[0] = n(e, i, o, s, m), c[1] = n(t, a, r, l, m)), Math.sqrt(u) } function h(e, t, i, n) { var a = 1 - n; return a * (a * e + 2 * n * t) + n * n * i } function d(e, t, i, n) { return 2 * ((1 - n) * (t - e) + n * (i - t)) } function c(e, n, a, o, r) { var s = e - 2 * n + a, l = 2 * (n - e), h = e - o, d = 0; if (t(s)) { if (i(l)) { var c = -h / l; c >= 0 && 1 >= c && (r[d++] = c) } } else { var m = l * l - 4 * s * h; if (t(m)) { var c = -l / (2 * s); c >= 0 && 1 >= c && (r[d++] = c) } else if (m > 0) { var p = Math.sqrt(m), c = (-l + p) / (2 * s), u = (-l - p) / (2 * s); c >= 0 && 1 >= c && (r[d++] = c), u >= 0 && 1 >= u && (r[d++] = u) } } return d } function m(e, t, i) { var n = e + i - 2 * t; return 0 === n ? .5 : (e - t) / n } function p(e, t, i, n, a) { var o = (t - e) * n + e, r = (i - t) * n + t, s = (r - o) * n + o; a[0] = e, a[1] = o, a[2] = s, a[3] = s, a[4] = r, a[5] = i } function u(e, t, i, n, a, o, r, s, l) { var d, c = .005, m = 1 / 0; y[0] = r, y[1] = s; for (var p = 0; 1 > p; p += .05) { b[0] = h(e, i, a, p), b[1] = h(t, n, o, p); var u = V.distSquare(y, b); m > u && (d = p, m = u) } m = 1 / 0; for (var g = 0; 32 > g && !(U > c); g++) { var f = d - c, x = d + c; b[0] = h(e, i, a, f), b[1] = h(t, n, o, f); var u = V.distSquare(b, y); if (f >= 0 && m > u) d = f, m = u; else { _[0] = h(e, i, a, x), _[1] = h(t, n, o, x); var k = V.distSquare(_, y); 1 >= x && m > k ? (d = x, m = k) : c *= .5 } } return l && (l[0] = h(e, i, a, d), l[1] = h(t, n, o, d)), Math.sqrt(m) } var V = e("./vector"), U = 1e-4, g = Math.sqrt(3), f = 1 / 3, y = V.create(), b = V.create(), _ = V.create(); return { cubicAt: n, cubicDerivativeAt: a, cubicRootAt: o, cubicExtrema: r, cubicSubdivide: s, cubicProjectPoint: l, quadraticAt: h, quadraticDerivativeAt: d, quadraticRootAt: c, quadraticExtremum: m, quadraticSubdivide: p, quadraticProjectPoint: u } }), define("zrender/mixin/Transformable", ["require", "../tool/matrix", "../tool/vector"], function(e) { "use strict"; function t(e) { return e > -s && s > e } function i(e) { return e > s || -s > e } var n = e("../tool/matrix"), a = e("../tool/vector"), o = [0, 0], r = n.translate, s = 5e-5, l = function() { this.position || (this.position = [0, 0]), "undefined" == typeof this.rotation && (this.rotation = [0, 0, 0]), this.scale || (this.scale = [1, 1, 0, 0]), this.needLocalTransform = !1, this.needTransform = !1 }; return l.prototype = { constructor: l, updateNeedTransform: function() { this.needLocalTransform = i(this.rotation[0]) || i(this.position[0]) || i(this.position[1]) || i(this.scale[0] - 1) || i(this.scale[1] - 1) }, updateTransform: function() { this.updateNeedTransform(); var e = this.parent && this.parent.needTransform; if (this.needTransform = this.needLocalTransform || e, this.needTransform) { var t = this.transform || n.create(); if (n.identity(t), this.needLocalTransform) { var a = this.scale; if (i(a[0]) || i(a[1])) { o[0] = -a[2] || 0, o[1] = -a[3] || 0; var s = i(o[0]) || i(o[1]); s && r(t, t, o), n.scale(t, t, a), s && (o[0] = -o[0], o[1] = -o[1], r(t, t, o)) } if (this.rotation instanceof Array) { if (0 !== this.rotation[0]) { o[0] = -this.rotation[1] || 0, o[1] = -this.rotation[2] || 0; var s = i(o[0]) || i(o[1]); s && r(t, t, o), n.rotate(t, t, this.rotation[0]), s && (o[0] = -o[0], o[1] = -o[1], r(t, t, o)) } } else 0 !== this.rotation && n.rotate(t, t, this.rotation); (i(this.position[0]) || i(this.position[1])) && r(t, t, this.position) } e && (this.needLocalTransform ? n.mul(t, this.parent.transform, t) : n.copy(t, this.parent.transform)), this.transform = t, this.invTransform = this.invTransform || n.create(), n.invert(this.invTransform, t) } }, setTransform: function(e) { if (this.needTransform) { var t = this.transform; e.transform(t[0], t[1], t[2], t[3], t[4], t[5]) } }, lookAt: function() { var e = a.create(); return function(i) { this.transform || (this.transform = n.create()); var o = this.transform; if (a.sub(e, i, this.position), !t(e[0]) || !t(e[1])) { a.normalize(e, e); var r = this.scale; o[2] = e[0] * r[1], o[3] = e[1] * r[1], o[0] = e[1] * r[0], o[1] = -e[0] * r[0], o[4] = this.position[0], o[5] = this.position[1], this.decomposeTransform() } } }(), decomposeTransform: function() { if (this.transform) { var e = this.transform, t = e[0] * e[0] + e[1] * e[1], n = this.position, a = this.scale, o = this.rotation; i(t - 1) && (t = Math.sqrt(t)); var r = e[2] * e[2] + e[3] * e[3]; i(r - 1) && (r = Math.sqrt(r)), n[0] = e[4], n[1] = e[5], a[0] = t, a[1] = r, a[2] = a[3] = 0, o[0] = Math.atan2(-e[1] / r, e[0] / t), o[1] = o[2] = 0 } }, transformCoordToLocal: function(e, t) { var i = [e, t]; return this.needTransform && this.invTransform && a.applyTransform(i, i, this.invTransform), i } }, l }), define("zrender/Group", ["require", "./tool/guid", "./tool/util", "./mixin/Transformable", "./mixin/Eventful"], function(e) { var t = e("./tool/guid"), i = e("./tool/util"), n = e("./mixin/Transformable"), a = e("./mixin/Eventful"), o = function(e) { e = e || {}, this.id = e.id || t(); for (var i in e) this[i] = e[i]; this.type = "group", this.clipShape = null, this._children = [], this._storage = null, this.__dirty = !0, n.call(this), a.call(this) }; return o.prototype.ignore = !1, o.prototype.children = function() { return this._children.slice() }, o.prototype.childAt = function(e) { return this._children[e] }, o.prototype.addChild = function(e) { e != this && e.parent != this && (e.parent && e.parent.removeChild(e), this._children.push(e), e.parent = this, this._storage && this._storage !== e._storage && (this._storage.addToMap(e), e instanceof o && e.addChildrenToStorage(this._storage))) }, o.prototype.removeChild = function(e) { var t = i.indexOf(this._children, e); t >= 0 && this._children.splice(t, 1), e.parent = null, this._storage && (this._storage.delFromMap(e.id), e instanceof o && e.delChildrenFromStorage(this._storage)) }, o.prototype.clearChildren = function() { for (var e = 0; e < this._children.length; e++) { var t = this._children[e]; this._storage && (this._storage.delFromMap(t.id), t instanceof o && t.delChildrenFromStorage(this._storage)) } this._children.length = 0 }, o.prototype.eachChild = function(e, t) { for (var i = !!t, n = 0; n < this._children.length; n++) { var a = this._children[n]; i ? e.call(t, a) : e(a) } }, o.prototype.traverse = function(e, t) { for (var i = !!t, n = 0; n < this._children.length; n++) { var a = this._children[n]; i ? e.call(t, a) : e(a), "group" === a.type && a.traverse(e, t) } }, o.prototype.addChildrenToStorage = function(e) { for (var t = 0; t < this._children.length; t++) { var i = this._children[t]; e.addToMap(i), i instanceof o && i.addChildrenToStorage(e) } }, o.prototype.delChildrenFromStorage = function(e) { for (var t = 0; t < this._children.length; t++) { var i = this._children[t]; e.delFromMap(i.id), i instanceof o && i.delChildrenFromStorage(e) } }, o.prototype.modSelf = function() { this.__dirty = !0 }, i.merge(o.prototype, n.prototype, !0), i.merge(o.prototype, a.prototype, !0), o }), define("zrender/animation/Clip", ["require", "./easing"], function(e) { function t(e) { this._targetPool = e.target || {}, this._targetPool instanceof Array || (this._targetPool = [this._targetPool]), this._life = e.life || 1e3, this._delay = e.delay || 0, this._startTime = (new Date).getTime() + this._delay, this._endTime = this._startTime + 1e3 * this._life, this.loop = "undefined" == typeof e.loop ? !1 : e.loop, this.gap = e.gap || 0, this.easing = e.easing || "Linear", this.onframe = e.onframe, this.ondestroy = e.ondestroy, this.onrestart = e.onrestart } var i = e("./easing"); return t.prototype = { step: function(e) { var t = (e - this._startTime) / this._life; if (!(0 > t)) { t = Math.min(t, 1); var n = "string" == typeof this.easing ? i[this.easing] : this.easing, a = "function" == typeof n ? n(t) : t; return this.fire("frame", a), 1 == t ? this.loop ? (this.restart(), "restart") : (this.__needsRemove = !0, "destroy") : null } }, restart: function() { var e = (new Date).getTime(), t = (e - this._startTime) % this._life; this._startTime = (new Date).getTime() - t + this.gap, this.__needsRemove = !1 }, fire: function(e, t) { for (var i = 0, n = this._targetPool.length; n > i; i++) this["on" + e] && this["on" + e](this._targetPool[i], t) }, constructor: t }, t }), define("zrender/animation/easing", [], function() { var e = { Linear: function(e) { return e }, QuadraticIn: function(e) { return e * e }, QuadraticOut: function(e) { return e * (2 - e) }, QuadraticInOut: function(e) { return (e *= 2) < 1 ? .5 * e * e : -.5 * (--e * (e - 2) - 1) }, CubicIn: function(e) { return e * e * e }, CubicOut: function(e) { return --e * e * e + 1 }, CubicInOut: function(e) { return (e *= 2) < 1 ? .5 * e * e * e : .5 * ((e -= 2) * e * e + 2) }, QuarticIn: function(e) { return e * e * e * e }, QuarticOut: function(e) { return 1 - --e * e * e * e }, QuarticInOut: function(e) { return (e *= 2) < 1 ? .5 * e * e * e * e : -.5 * ((e -= 2) * e * e * e - 2) }, QuinticIn: function(e) { return e * e * e * e * e }, QuinticOut: function(e) { return --e * e * e * e * e + 1 }, QuinticInOut: function(e) { return (e *= 2) < 1 ? .5 * e * e * e * e * e : .5 * ((e -= 2) * e * e * e * e + 2) }, SinusoidalIn: function(e) { return 1 - Math.cos(e * Math.PI / 2) }, SinusoidalOut: function(e) { return Math.sin(e * Math.PI / 2) }, SinusoidalInOut: function(e) { return .5 * (1 - Math.cos(Math.PI * e)) }, ExponentialIn: function(e) { return 0 === e ? 0 : Math.pow(1024, e - 1) }, ExponentialOut: function(e) { return 1 === e ? 1 : 1 - Math.pow(2, -10 * e) }, ExponentialInOut: function(e) { return 0 === e ? 0 : 1 === e ? 1 : (e *= 2) < 1 ? .5 * Math.pow(1024, e - 1) : .5 * (-Math.pow(2, -10 * (e - 1)) + 2) }, CircularIn: function(e) { return 1 - Math.sqrt(1 - e * e) }, CircularOut: function(e) { return Math.sqrt(1 - --e * e) }, CircularInOut: function(e) { return (e *= 2) < 1 ? -.5 * (Math.sqrt(1 - e * e) - 1) : .5 * (Math.sqrt(1 - (e -= 2) * e) + 1) }, ElasticIn: function(e) { var t, i = .1, n = .4; return 0 === e ? 0 : 1 === e ? 1 : (!i || 1 > i ? (i = 1, t = n / 4) : t = n * Math.asin(1 / i) / (2 * Math.PI), -(i * Math.pow(2, 10 * (e -= 1)) * Math.sin(2 * (e - t) * Math.PI / n))) }, ElasticOut: function(e) { var t, i = .1, n = .4; return 0 === e ? 0 : 1 === e ? 1 : (!i || 1 > i ? (i = 1, t = n / 4) : t = n * Math.asin(1 / i) / (2 * Math.PI), i * Math.pow(2, -10 * e) * Math.sin(2 * (e - t) * Math.PI / n) + 1); }, ElasticInOut: function(e) { var t, i = .1, n = .4; return 0 === e ? 0 : 1 === e ? 1 : (!i || 1 > i ? (i = 1, t = n / 4) : t = n * Math.asin(1 / i) / (2 * Math.PI), (e *= 2) < 1 ? -.5 * i * Math.pow(2, 10 * (e -= 1)) * Math.sin(2 * (e - t) * Math.PI / n) : i * Math.pow(2, -10 * (e -= 1)) * Math.sin(2 * (e - t) * Math.PI / n) * .5 + 1) }, BackIn: function(e) { var t = 1.70158; return e * e * ((t + 1) * e - t) }, BackOut: function(e) { var t = 1.70158; return --e * e * ((t + 1) * e + t) + 1 }, BackInOut: function(e) { var t = 2.5949095; return (e *= 2) < 1 ? .5 * e * e * ((t + 1) * e - t) : .5 * ((e -= 2) * e * ((t + 1) * e + t) + 2) }, BounceIn: function(t) { return 1 - e.BounceOut(1 - t) }, BounceOut: function(e) { return 1 / 2.75 > e ? 7.5625 * e * e : 2 / 2.75 > e ? 7.5625 * (e -= 1.5 / 2.75) * e + .75 : 2.5 / 2.75 > e ? 7.5625 * (e -= 2.25 / 2.75) * e + .9375 : 7.5625 * (e -= 2.625 / 2.75) * e + .984375 }, BounceInOut: function(t) { return .5 > t ? .5 * e.BounceIn(2 * t) : .5 * e.BounceOut(2 * t - 1) + .5 } }; return e }), define("echarts/chart/base", ["require", "zrender/shape/Image", "../util/shape/Icon", "../util/shape/MarkLine", "../util/shape/Symbol", "zrender/shape/Polyline", "zrender/shape/ShapeBundle", "../config", "../util/ecData", "../util/ecAnimation", "../util/ecEffect", "../util/accMath", "../component/base", "../layout/EdgeBundling", "zrender/tool/util", "zrender/tool/area"], function(e) { function t(e) { return null != e.x && null != e.y } function i(e, t, i, n, a) { u.call(this, e, t, i, n, a); var o = this; this.selectedMap = {}, this.lastShapeList = [], this.shapeHandler = { onclick: function() { o.isClick = !0 }, ondragover: function(e) { var t = e.target; t.highlightStyle = t.highlightStyle || {}; var i = t.highlightStyle, n = i.brushTyep, a = i.strokeColor, r = i.lineWidth; i.brushType = "stroke", i.strokeColor = o.ecTheme.calculableColor || h.calculableColor, i.lineWidth = "icon" === t.type ? 30 : 10, o.zr.addHoverShape(t), setTimeout(function() { i && (i.brushType = n, i.strokeColor = a, i.lineWidth = r) }, 20) }, ondrop: function(e) { null != d.get(e.dragged, "data") && (o.isDrop = !0) }, ondragend: function() { o.isDragend = !0 } } } var n = e("zrender/shape/Image"), a = e("../util/shape/Icon"), o = e("../util/shape/MarkLine"), r = e("../util/shape/Symbol"), s = e("zrender/shape/Polyline"), l = e("zrender/shape/ShapeBundle"), h = e("../config"), d = e("../util/ecData"), c = e("../util/ecAnimation"), m = e("../util/ecEffect"), p = e("../util/accMath"), u = e("../component/base"), V = e("../layout/EdgeBundling"), U = e("zrender/tool/util"), g = e("zrender/tool/area"); return i.prototype = { setCalculable: function(e) { return e.dragEnableTime = this.ecTheme.DRAG_ENABLE_TIME || h.DRAG_ENABLE_TIME, e.ondragover = this.shapeHandler.ondragover, e.ondragend = this.shapeHandler.ondragend, e.ondrop = this.shapeHandler.ondrop, e }, ondrop: function(e, t) { if (this.isDrop && e.target && !t.dragIn) { var i, n = e.target, a = e.dragged, o = d.get(n, "seriesIndex"), r = d.get(n, "dataIndex"), s = this.series, l = this.component.legend; if (-1 === r) { if (d.get(a, "seriesIndex") == o) return t.dragOut = t.dragIn = t.needRefresh = !0, void(this.isDrop = !1); i = { value: d.get(a, "value"), name: d.get(a, "name") }, this.type === h.CHART_TYPE_PIE && i.value < 0 && (i.value = 0); for (var c = !1, m = s[o].data, u = 0, V = m.length; V > u; u++) m[u].name === i.name && "-" === m[u].value && (s[o].data[u].value = i.value, c = !0); !c && s[o].data.push(i), l && l.add(i.name, a.style.color || a.style.strokeColor) } else i = s[o].data[r] || "-", null != i.value ? (s[o].data[r].value = "-" != i.value ? p.accAdd(s[o].data[r].value, d.get(a, "value")) : d.get(a, "value"), (this.type === h.CHART_TYPE_FUNNEL || this.type === h.CHART_TYPE_PIE) && (l && 1 === l.getRelatedAmount(i.name) && this.component.legend.del(i.name), i.name += this.option.nameConnector + d.get(a, "name"), l && l.add(i.name, a.style.color || a.style.strokeColor))) : s[o].data[r] = "-" != i ? p.accAdd(s[o].data[r], d.get(a, "value")) : d.get(a, "value"); t.dragIn = t.dragIn || !0, this.isDrop = !1; var U = this; setTimeout(function() { U.zr.trigger("mousemove", e.event) }, 300) } }, ondragend: function(e, t) { if (this.isDragend && e.target && !t.dragOut) { var i = e.target, n = d.get(i, "seriesIndex"), a = d.get(i, "dataIndex"), o = this.series; if (null != o[n].data[a].value) { o[n].data[a].value = "-"; var r = o[n].data[a].name, s = this.component.legend; s && 0 === s.getRelatedAmount(r) && s.del(r) } else o[n].data[a] = "-"; t.dragOut = !0, t.needRefresh = !0, this.isDragend = !1 } }, onlegendSelected: function(e, t) { var i = e.selected; for (var n in this.selectedMap) this.selectedMap[n] != i[n] && (t.needRefresh = !0), this.selectedMap[n] = i[n] }, _buildPosition: function() { this._symbol = this.option.symbolList, this._sIndex2ShapeMap = {}, this._sIndex2ColorMap = {}, this.selectedMap = {}, this.xMarkMap = {}; for (var e, t, i, n, a = this.series, o = { top: [], bottom: [], left: [], right: [], other: [] }, r = 0, s = a.length; s > r; r++) a[r].type === this.type && (a[r] = this.reformOption(a[r]), this.legendHoverLink = a[r].legendHoverLink || this.legendHoverLink, e = a[r].xAxisIndex, t = a[r].yAxisIndex, i = this.component.xAxis.getAxis(e), n = this.component.yAxis.getAxis(t), i.type === h.COMPONENT_TYPE_AXIS_CATEGORY ? o[i.getPosition()].push(r) : n.type === h.COMPONENT_TYPE_AXIS_CATEGORY ? o[n.getPosition()].push(r) : o.other.push(r)); for (var l in o) o[l].length > 0 && this._buildSinglePosition(l, o[l]); this.addShapeList() }, _buildSinglePosition: function(e, t) { var i = this._mapData(t), n = i.locationMap, a = i.maxDataLength; if (0 !== a && 0 !== n.length) { switch (e) { case "bottom": case "top": this._buildHorizontal(t, a, n, this.xMarkMap); break; case "left": case "right": this._buildVertical(t, a, n, this.xMarkMap); break; case "other": this._buildOther(t, a, n, this.xMarkMap) } for (var o = 0, r = t.length; r > o; o++) this.buildMark(t[o]) } }, _mapData: function(e) { for (var t, i, n, a, o = this.series, r = 0, s = {}, l = "__kener__stack__", d = this.component.legend, c = [], m = 0, p = 0, u = e.length; u > p; p++) { if (t = o[e[p]], n = t.name, this._sIndex2ShapeMap[e[p]] = this._sIndex2ShapeMap[e[p]] || this.query(t, "symbol") || this._symbol[p % this._symbol.length], d) { if (this.selectedMap[n] = d.isSelected(n), this._sIndex2ColorMap[e[p]] = d.getColor(n), a = d.getItemShape(n)) { var V = a.style; if (this.type == h.CHART_TYPE_LINE) V.iconType = "legendLineIcon", V.symbol = this._sIndex2ShapeMap[e[p]]; else if (t.itemStyle.normal.barBorderWidth > 0) { var U = a.highlightStyle; V.brushType = "both", V.x += 1, V.y += 1, V.width -= 2, V.height -= 2, V.strokeColor = U.strokeColor = t.itemStyle.normal.barBorderColor, U.lineWidth = 3 } d.setItemShape(n, a) } } else this.selectedMap[n] = !0, this._sIndex2ColorMap[e[p]] = this.zr.getColor(e[p]); this.selectedMap[n] && (i = t.stack || l + e[p], null == s[i] ? (s[i] = r, c[r] = [e[p]], r++) : c[s[i]].push(e[p])), m = Math.max(m, t.data.length) } return { locationMap: c, maxDataLength: m } }, _calculMarkMapXY: function(e, t, i) { for (var n = this.series, a = 0, o = t.length; o > a; a++) for (var r = 0, s = t[a].length; s > r; r++) { var l = t[a][r], h = "xy" == i ? 0 : "", d = this.component.grid, c = e[l]; if ("-1" != i.indexOf("x")) { c["counter" + h] > 0 && (c["average" + h] = c["sum" + h] / c["counter" + h]); var m = this.component.xAxis.getAxis(n[l].xAxisIndex || 0).getCoord(c["average" + h]); c["averageLine" + h] = [ [m, d.getYend()], [m, d.getY()] ], c["minLine" + h] = [ [c["minX" + h], d.getYend()], [c["minX" + h], d.getY()] ], c["maxLine" + h] = [ [c["maxX" + h], d.getYend()], [c["maxX" + h], d.getY()] ], c.isHorizontal = !1 } if (h = "xy" == i ? 1 : "", "-1" != i.indexOf("y")) { c["counter" + h] > 0 && (c["average" + h] = c["sum" + h] / c["counter" + h]); var p = this.component.yAxis.getAxis(n[l].yAxisIndex || 0).getCoord(c["average" + h]); c["averageLine" + h] = [ [d.getX(), p], [d.getXend(), p] ], c["minLine" + h] = [ [d.getX(), c["minY" + h]], [d.getXend(), c["minY" + h]] ], c["maxLine" + h] = [ [d.getX(), c["maxY" + h]], [d.getXend(), c["maxY" + h]] ], c.isHorizontal = !0 } } }, addLabel: function(e, t, i, n, a) { var o = [i, t], r = this.deepMerge(o, "itemStyle.normal.label"), s = this.deepMerge(o, "itemStyle.emphasis.label"), l = r.textStyle || {}, h = s.textStyle || {}; if (r.show) { var d = e.style; d.text = this._getLabelText(t, i, n, "normal"), d.textPosition = null == r.position ? "horizontal" === a ? "right" : "top" : r.position, d.textColor = l.color, d.textFont = this.getFont(l), d.textAlign = l.align, d.textBaseline = l.baseline } if (s.show) { var c = e.highlightStyle; c.text = this._getLabelText(t, i, n, "emphasis"), c.textPosition = r.show ? e.style.textPosition : null == s.position ? "horizontal" === a ? "right" : "top" : s.position, c.textColor = h.color, c.textFont = this.getFont(h), c.textAlign = h.align, c.textBaseline = h.baseline } return e }, _getLabelText: function(e, t, i, n) { var a = this.deepQuery([t, e], "itemStyle." + n + ".label.formatter"); a || "emphasis" !== n || (a = this.deepQuery([t, e], "itemStyle.normal.label.formatter")); var o = this.getDataFromOption(t, "-"); return a ? "function" == typeof a ? a.call(this.myChart, { seriesName: e.name, series: e, name: i, value: o, data: t, status: n }) : "string" == typeof a ? a = a.replace("{a}", "{a0}").replace("{b}", "{b0}").replace("{c}", "{c0}").replace("{a0}", e.name).replace("{b0}", i).replace("{c0}", this.numAddCommas(o)) : void 0 : o instanceof Array ? null != o[2] ? this.numAddCommas(o[2]) : o[0] + " , " + o[1] : this.numAddCommas(o) }, buildMark: function(e) { var t = this.series[e]; this.selectedMap[t.name] && (t.markLine && this._buildMarkLine(e), t.markPoint && this._buildMarkPoint(e)) }, _buildMarkPoint: function(e) { for (var t, i, n = (this.markAttachStyle || {})[e], a = this.series[e], o = U.clone(a.markPoint), r = 0, s = o.data.length; s > r; r++) t = o.data[r], i = this.getMarkCoord(e, t), t.x = null != t.x ? t.x : i[0], t.y = null != t.y ? t.y : i[1], !t.type || "max" !== t.type && "min" !== t.type || (t.value = i[3], t.name = t.name || t.type, t.symbolSize = t.symbolSize || g.getTextWidth(i[3], this.getFont()) / 2 + 5); for (var l = this._markPoint(e, o), r = 0, s = l.length; s > r; r++) { var d = l[r]; d.zlevel = a.zlevel, d.z = a.z + 1; for (var c in n) d[c] = U.clone(n[c]); this.shapeList.push(d) } if (this.type === h.CHART_TYPE_FORCE || this.type === h.CHART_TYPE_CHORD) for (var r = 0, s = l.length; s > r; r++) this.zr.addShape(l[r]) }, _buildMarkLine: function(e) { for (var t, i = (this.markAttachStyle || {})[e], n = this.series[e], a = U.clone(n.markLine), o = 0, r = a.data.length; r > o; o++) { var s = a.data[o]; !s.type || "max" !== s.type && "min" !== s.type && "average" !== s.type ? t = [this.getMarkCoord(e, s[0]), this.getMarkCoord(e, s[1])] : (t = this.getMarkCoord(e, s), a.data[o] = [U.clone(s), {}], a.data[o][0].name = s.name || s.type, a.data[o][0].value = "average" !== s.type ? t[3] : +t[3].toFixed(null != a.precision ? a.precision : this.deepQuery([this.ecTheme, h], "markLine.precision")), t = t[2], s = [{}, {}]), null != t && null != t[0] && null != t[1] && (a.data[o][0].x = null != s[0].x ? s[0].x : t[0][0], a.data[o][0].y = null != s[0].y ? s[0].y : t[0][1], a.data[o][1].x = null != s[1].x ? s[1].x : t[1][0], a.data[o][1].y = null != s[1].y ? s[1].y : t[1][1]) } var d = this._markLine(e, a), c = a.large; if (c) { var m = new l({ style: { shapeList: d } }), p = d[0]; if (p) { U.merge(m.style, p.style), U.merge(m.highlightStyle = {}, p.highlightStyle), m.style.brushType = "stroke", m.zlevel = n.zlevel, m.z = n.z + 1, m.hoverable = !1; for (var u in i) m[u] = U.clone(i[u]) } this.shapeList.push(m), this.zr.addShape(m), m._mark = "largeLine"; var V = a.effect; V.show && (m.effect = V) } else { for (var o = 0, r = d.length; r > o; o++) { var g = d[o]; g.zlevel = n.zlevel, g.z = n.z + 1; for (var u in i) g[u] = U.clone(i[u]); this.shapeList.push(g) } if (this.type === h.CHART_TYPE_FORCE || this.type === h.CHART_TYPE_CHORD) for (var o = 0, r = d.length; r > o; o++) this.zr.addShape(d[o]) } }, _markPoint: function(e, t) { var i = this.series[e], n = this.component; U.merge(U.merge(t, U.clone(this.ecTheme.markPoint || {})), U.clone(h.markPoint)), t.name = i.name; var a, o, r, s, l, c, m, p = [], u = t.data, V = n.dataRange, g = n.legend, f = this.zr.getWidth(), y = this.zr.getHeight(); if (t.large) a = this.getLargeMarkPointShape(e, t), a._mark = "largePoint", a && p.push(a); else for (var b = 0, _ = u.length; _ > b; b++) null != u[b].x && null != u[b].y && (r = null != u[b].value ? u[b].value : "", g && (o = g.getColor(i.name)), V && (o = isNaN(r) ? o : V.getColor(r), s = [u[b], t], l = this.deepQuery(s, "itemStyle.normal.color") || o, c = this.deepQuery(s, "itemStyle.emphasis.color") || l, null == l && null == c) || (o = null == o ? this.zr.getColor(e) : o, u[b].tooltip = u[b].tooltip || t.tooltip || { trigger: "item" }, u[b].name = null != u[b].name ? u[b].name : "", u[b].value = r, a = this.getSymbolShape(t, e, u[b], b, u[b].name, this.parsePercent(u[b].x, f), this.parsePercent(u[b].y, y), "pin", o, "rgba(0,0,0,0)", "horizontal"), a._mark = "point", m = this.deepMerge([u[b], t], "effect"), m.show && (a.effect = m), i.type === h.CHART_TYPE_MAP && (a._geo = this.getMarkGeo(u[b])), d.pack(a, i, e, u[b], b, u[b].name, r), p.push(a))); return p }, _markLine: function() { function e(e, t) { e[t] = e[t] instanceof Array ? e[t].length > 1 ? e[t] : [e[t][0], e[t][0]] : [e[t], e[t]] } return function(i, n) { var a = this.series[i], o = this.component, r = o.dataRange, s = o.legend; U.merge(U.merge(n, U.clone(this.ecTheme.markLine || {})), U.clone(h.markLine)); var l = s ? s.getColor(a.name) : this.zr.getColor(i); e(n, "symbol"), e(n, "symbolSize"), e(n, "symbolRotate"); for (var c = n.data, m = [], p = this.zr.getWidth(), u = this.zr.getHeight(), g = 0; g < c.length; g++) { var f = c[g]; if (t(f[0]) && t(f[1])) { var y = this.deepMerge(f), b = [y, n], _ = l, x = null != y.value ? y.value : ""; if (r) { _ = isNaN(x) ? _ : r.getColor(x); var k = this.deepQuery(b, "itemStyle.normal.color") || _, v = this.deepQuery(b, "itemStyle.emphasis.color") || k; if (null == k && null == v) continue } f[0].tooltip = y.tooltip || n.tooltip || { trigger: "item" }, f[0].name = f[0].name || "", f[1].name = f[1].name || "", f[0].value = x, m.push({ points: [ [this.parsePercent(f[0].x, p), this.parsePercent(f[0].y, u)], [this.parsePercent(f[1].x, p), this.parsePercent(f[1].y, u)] ], rawData: f, color: _ }) } } var L = this.query(n, "bundling.enable"); if (L) { var w = new V; w.maxTurningAngle = this.query(n, "bundling.maxTurningAngle") / 180 * Math.PI, m = w.run(m) } n.name = a.name; for (var W = [], g = 0, X = m.length; X > g; g++) { var I = m[g], S = I.rawEdge || I, f = S.rawData, x = null != f.value ? f.value : "", K = this.getMarkLineShape(n, i, f, g, I.points, L, S.color); K._mark = "line"; var C = this.deepMerge([f[0], f[1], n], "effect"); C.show && (K.effect = C, K.effect.large = n.large), a.type === h.CHART_TYPE_MAP && (K._geo = [this.getMarkGeo(f[0]), this.getMarkGeo(f[1])]), d.pack(K, a, i, f[0], g, f[0].name + ("" !== f[1].name ? " > " + f[1].name : ""), x), W.push(K) } return W } }(), getMarkCoord: function() { return [0, 0] }, getSymbolShape: function(e, t, i, o, r, s, l, h, c, m, p) { var u = [i, e], V = this.getDataFromOption(i, "-"); h = this.deepQuery(u, "symbol") || h; var U = this.deepQuery(u, "symbolSize"); U = "function" == typeof U ? U(V) : U, "number" == typeof U && (U = [U, U]); var g = this.deepQuery(u, "symbolRotate"), f = this.deepMerge(u, "itemStyle.normal"), y = this.deepMerge(u, "itemStyle.emphasis"), b = null != f.borderWidth ? f.borderWidth : f.lineStyle && f.lineStyle.width; null == b && (b = h.match("empty") ? 2 : 0); var _ = null != y.borderWidth ? y.borderWidth : y.lineStyle && y.lineStyle.width; null == _ && (_ = b + 2); var x = this.getItemStyleColor(f.color, t, o, i), k = this.getItemStyleColor(y.color, t, o, i), v = U[0], L = U[1], w = new a({ style: { iconType: h.replace("empty", "").toLowerCase(), x: s - v, y: l - L, width: 2 * v, height: 2 * L, brushType: "both", color: h.match("empty") ? m : x || c, strokeColor: f.borderColor || x || c, lineWidth: b }, highlightStyle: { color: h.match("empty") ? m : k || x || c, strokeColor: y.borderColor || f.borderColor || k || x || c, lineWidth: _ }, clickable: this.deepQuery(u, "clickable") }); return h.match("image") && (w.style.image = h.replace(new RegExp("^image:\\/\\/"), ""), w = new n({ style: w.style, highlightStyle: w.highlightStyle, clickable: this.deepQuery(u, "clickable") })), null != g && (w.rotation = [g * Math.PI / 180, s, l]), h.match("star") && (w.style.iconType = "star", w.style.n = h.replace("empty", "").replace("star", "") - 0 || 5), "none" === h && (w.invisible = !0, w.hoverable = !1), w = this.addLabel(w, e, i, r, p), h.match("empty") && (null == w.style.textColor && (w.style.textColor = w.style.strokeColor), null == w.highlightStyle.textColor && (w.highlightStyle.textColor = w.highlightStyle.strokeColor)), d.pack(w, e, t, i, o, r), w._x = s, w._y = l, w._dataIndex = o, w._seriesIndex = t, w }, getMarkLineShape: function(e, t, i, n, a, r, l) { var h = null != i[0].value ? i[0].value : "-", d = null != i[1].value ? i[1].value : "-", c = [i[0].symbol || e.symbol[0], i[1].symbol || e.symbol[1]], m = [i[0].symbolSize || e.symbolSize[0], i[1].symbolSize || e.symbolSize[1]]; m[0] = "function" == typeof m[0] ? m[0](h) : m[0], m[1] = "function" == typeof m[1] ? m[1](d) : m[1]; var p = [this.query(i[0], "symbolRotate") || e.symbolRotate[0], this.query(i[1], "symbolRotate") || e.symbolRotate[1]], u = [i[0], i[1], e], V = this.deepMerge(u, "itemStyle.normal"); V.color = this.getItemStyleColor(V.color, t, n, i); var U = this.deepMerge(u, "itemStyle.emphasis"); U.color = this.getItemStyleColor(U.color, t, n, i); var g = V.lineStyle, f = U.lineStyle, y = g.width; null == y && (y = V.borderWidth); var b = f.width; null == b && (b = null != U.borderWidth ? U.borderWidth : y + 2); var _ = this.deepQuery(u, "smoothness"); this.deepQuery(u, "smooth") || (_ = 0); var x = r ? s : o, k = new x({ style: { symbol: c, symbolSize: m, symbolRotate: p, brushType: "both", lineType: g.type, shadowColor: g.shadowColor || g.color || V.borderColor || V.color || l, shadowBlur: g.shadowBlur, shadowOffsetX: g.shadowOffsetX, shadowOffsetY: g.shadowOffsetY, color: V.color || l, strokeColor: g.color || V.borderColor || V.color || l, lineWidth: y, symbolBorderColor: V.borderColor || V.color || l, symbolBorder: V.borderWidth }, highlightStyle: { shadowColor: f.shadowColor, shadowBlur: f.shadowBlur, shadowOffsetX: f.shadowOffsetX, shadowOffsetY: f.shadowOffsetY, color: U.color || V.color || l, strokeColor: f.color || g.color || U.borderColor || V.borderColor || U.color || V.color || l, lineWidth: b, symbolBorderColor: U.borderColor || V.borderColor || U.color || V.color || l, symbolBorder: null == U.borderWidth ? V.borderWidth + 2 : U.borderWidth }, clickable: this.deepQuery(u, "clickable") }), v = k.style; return r ? (v.pointList = a, v.smooth = _) : (v.xStart = a[0][0], v.yStart = a[0][1], v.xEnd = a[1][0], v.yEnd = a[1][1], v.curveness = _, k.updatePoints(k.style)), k = this.addLabel(k, e, i[0], i[0].name + " : " + i[1].name) }, getLargeMarkPointShape: function(e, t) { var i, n, a, o, s, l, h = this.series[e], d = this.component, c = t.data, m = d.dataRange, p = d.legend, u = [c[0], t]; if (p && (n = p.getColor(h.name)), !m || (a = null != c[0].value ? c[0].value : "", n = isNaN(a) ? n : m.getColor(a), o = this.deepQuery(u, "itemStyle.normal.color") || n, s = this.deepQuery(u, "itemStyle.emphasis.color") || o, null != o || null != s)) { n = this.deepMerge(u, "itemStyle.normal").color || n; var V = this.deepQuery(u, "symbol") || "circle"; V = V.replace("empty", "").replace(/\d/g, ""), l = this.deepMerge([c[0], t], "effect"); var U = window.devicePixelRatio || 1; return i = new r({ style: { pointList: c, color: n, strokeColor: n, shadowColor: l.shadowColor || n, shadowBlur: (null != l.shadowBlur ? l.shadowBlur : 8) * U, size: this.deepQuery(u, "symbolSize"), iconType: V, brushType: "fill", lineWidth: 1 }, draggable: !1, hoverable: !1 }), l.show && (i.effect = l), i } }, backupShapeList: function() { this.shapeList && this.shapeList.length > 0 ? (this.lastShapeList = this.shapeList, this.shapeList = []) : this.lastShapeList = [] }, addShapeList: function() { var e, t, i = this.option.animationThreshold / (this.canvasSupported ? 2 : 4), n = this.lastShapeList, a = this.shapeList, o = n.length > 0, r = o ? this.query(this.option, "animationDurationUpdate") : this.query(this.option, "animationDuration"), s = this.query(this.option, "animationEasing"), l = {}, d = {}; if (this.option.animation && !this.option.renderAsImage && a.length < i && !this.motionlessOnce) { for (var c = 0, m = n.length; m > c; c++) t = this._getAnimationKey(n[c]), t.match("undefined") ? this.zr.delShape(n[c].id) : (t += n[c].type, l[t] ? this.zr.delShape(n[c].id) : l[t] = n[c]); for (var c = 0, m = a.length; m > c; c++) t = this._getAnimationKey(a[c]), t.match("undefined") ? this.zr.addShape(a[c]) : (t += a[c].type, d[t] = a[c]); for (t in l) d[t] || this.zr.delShape(l[t].id); for (t in d) l[t] ? (this.zr.delShape(l[t].id), this._animateMod(l[t], d[t], r, s, 0, o)) : (e = this.type != h.CHART_TYPE_LINE && this.type != h.CHART_TYPE_RADAR || 0 === t.indexOf("icon") ? 0 : r / 2, this._animateMod(!1, d[t], r, s, e, o)); this.zr.refresh(), this.animationEffect() } else { this.motionlessOnce = !1, this.zr.delShape(n); for (var c = 0, m = a.length; m > c; c++) this.zr.addShape(a[c]) } }, _getAnimationKey: function(e) { return this.type != h.CHART_TYPE_MAP && this.type != h.CHART_TYPE_TREEMAP && this.type != h.CHART_TYPE_VENN && this.type != h.CHART_TYPE_TREE ? d.get(e, "seriesIndex") + "_" + d.get(e, "dataIndex") + (e._mark ? e._mark : "") + (this.type === h.CHART_TYPE_RADAR ? d.get(e, "special") : "") : d.get(e, "seriesIndex") + "_" + d.get(e, "dataIndex") + (e._mark ? e._mark : "undefined") }, _animateMod: function(e, t, i, n, a, o) { switch (t.type) { case "polyline": case "half-smooth-polygon": c.pointList(this.zr, e, t, i, n); break; case "rectangle": c.rectangle(this.zr, e, t, i, n); break; case "image": case "icon": c.icon(this.zr, e, t, i, n, a); break; case "candle": o ? this.zr.addShape(t) : c.candle(this.zr, e, t, i, n); break; case "ring": case "sector": case "circle": o ? "sector" === t.type ? c.sector(this.zr, e, t, i, n) : this.zr.addShape(t) : c.ring(this.zr, e, t, i + (d.get(t, "dataIndex") || 0) % 20 * 100, n); break; case "text": c.text(this.zr, e, t, i, n); break; case "polygon": o ? c.pointList(this.zr, e, t, i, n) : c.polygon(this.zr, e, t, i, n); break; case "ribbon": c.ribbon(this.zr, e, t, i, n); break; case "gauge-pointer": c.gaugePointer(this.zr, e, t, i, n); break; case "mark-line": c.markline(this.zr, e, t, i, n); break; case "bezier-curve": case "line": c.line(this.zr, e, t, i, n); break; default: this.zr.addShape(t) } }, animationMark: function(e, t, i) { for (var i = i || this.shapeList, n = 0, a = i.length; a > n; n++) i[n]._mark && this._animateMod(!1, i[n], e, t, 0, !0); this.animationEffect(i) }, animationEffect: function(e) { if (!e && this.clearEffectShape(), e = e || this.shapeList, null != e) { var t = h.EFFECT_ZLEVEL; this.canvasSupported && this.zr.modLayer(t, { motionBlur: !0, lastFrameAlpha: this.option.effectBlendAlpha || h.effectBlendAlpha }); for (var i, n = 0, a = e.length; a > n; n++) i = e[n], i._mark && i.effect && i.effect.show && m[i._mark] && (m[i._mark](this.zr, this.effectList, i, t), this.effectList[this.effectList.length - 1]._mark = i._mark) } }, clearEffectShape: function(e) { var t = this.effectList; if (this.zr && t && t.length > 0) { e && this.zr.modLayer(h.EFFECT_ZLEVEL, { motionBlur: !1 }), this.zr.delShape(t); for (var i = 0; i < t.length; i++) t[i].effectAnimator && t[i].effectAnimator.stop() } this.effectList = [] }, addMark: function(e, t, i) { var n = this.series[e]; if (this.selectedMap[n.name]) { var a = this.query(this.option, "animationDurationUpdate"), o = this.query(this.option, "animationEasing"), r = n[i].data, s = this.shapeList.length; if (n[i].data = t.data, this["_build" + i.replace("m", "M")](e), this.option.animation && !this.option.renderAsImage) this.animationMark(a, o, this.shapeList.slice(s)); else { for (var l = s, h = this.shapeList.length; h > l; l++) this.zr.addShape(this.shapeList[l]); this.zr.refreshNextFrame() } n[i].data = r } }, delMark: function(e, t, i) { i = i.replace("mark", "").replace("large", "").toLowerCase(); var n = this.series[e]; if (this.selectedMap[n.name]) { for (var a = !1, o = [this.shapeList, this.effectList], r = 2; r--;) for (var s = 0, l = o[r].length; l > s; s++) if (o[r][s]._mark == i && d.get(o[r][s], "seriesIndex") == e && d.get(o[r][s], "name") == t) { this.zr.delShape(o[r][s].id), o[r].splice(s, 1), a = !0; break } a && this.zr.refreshNextFrame() } } }, U.inherits(i, u), i }), define("zrender/shape/Circle", ["require", "./Base", "../tool/util"], function(e) { "use strict"; var t = e("./Base"), i = function(e) { t.call(this, e) }; return i.prototype = { type: "circle", buildPath: function(e, t) { e.moveTo(t.x + t.r, t.y), e.arc(t.x, t.y, t.r, 0, 2 * Math.PI, !0) }, getRect: function(e) { if (e.__rect) return e.__rect; var t; return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = { x: Math.round(e.x - e.r - t / 2), y: Math.round(e.y - e.r - t / 2), width: 2 * e.r + t, height: 2 * e.r + t }, e.__rect } }, e("../tool/util").inherits(i, t), i }), define("echarts/util/accMath", [], function() { function e(e, t) { var i = e.toString(), n = t.toString(), a = 0; try { a = n.split(".")[1].length } catch (o) {} try { a -= i.split(".")[1].length } catch (o) {} return (i.replace(".", "") - 0) / (n.replace(".", "") - 0) * Math.pow(10, a) } function t(e, t) { var i = e.toString(), n = t.toString(), a = 0; try { a += i.split(".")[1].length } catch (o) {} try { a += n.split(".")[1].length } catch (o) {} return (i.replace(".", "") - 0) * (n.replace(".", "") - 0) / Math.pow(10, a) } function i(e, t) { var i = 0, n = 0; try { i = e.toString().split(".")[1].length } catch (a) {} try { n = t.toString().split(".")[1].length } catch (a) {} var o = Math.pow(10, Math.max(i, n)); return (Math.round(e * o) + Math.round(t * o)) / o } function n(e, t) { return i(e, -t) } return { accDiv: e, accMul: t, accAdd: i, accSub: n } }), define("echarts/util/shape/Icon", ["require", "zrender/tool/util", "zrender/shape/Star", "zrender/shape/Heart", "zrender/shape/Droplet", "zrender/shape/Image", "zrender/shape/Base"], function(e) { function t(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i, n + t.height), e.lineTo(i + 5 * a, n + 14 * o), e.lineTo(i + t.width, n + 3 * o), e.lineTo(i + 13 * a, n), e.lineTo(i + 2 * a, n + 11 * o), e.lineTo(i, n + t.height), e.moveTo(i + 6 * a, n + 10 * o), e.lineTo(i + 14 * a, n + 2 * o), e.moveTo(i + 10 * a, n + 13 * o), e.lineTo(i + t.width, n + 13 * o), e.moveTo(i + 13 * a, n + 10 * o), e.lineTo(i + 13 * a, n + t.height) } function i(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i, n + t.height), e.lineTo(i + 5 * a, n + 14 * o), e.lineTo(i + t.width, n + 3 * o), e.lineTo(i + 13 * a, n), e.lineTo(i + 2 * a, n + 11 * o), e.lineTo(i, n + t.height), e.moveTo(i + 6 * a, n + 10 * o), e.lineTo(i + 14 * a, n + 2 * o), e.moveTo(i + 10 * a, n + 13 * o), e.lineTo(i + t.width, n + 13 * o) } function n(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i + 4 * a, n + 15 * o), e.lineTo(i + 9 * a, n + 13 * o), e.lineTo(i + 14 * a, n + 8 * o), e.lineTo(i + 11 * a, n + 5 * o), e.lineTo(i + 6 * a, n + 10 * o), e.lineTo(i + 4 * a, n + 15 * o), e.moveTo(i + 5 * a, n), e.lineTo(i + 11 * a, n), e.moveTo(i + 5 * a, n + o), e.lineTo(i + 11 * a, n + o), e.moveTo(i, n + 2 * o), e.lineTo(i + t.width, n + 2 * o), e.moveTo(i, n + 5 * o), e.lineTo(i + 3 * a, n + t.height), e.lineTo(i + 13 * a, n + t.height), e.lineTo(i + t.width, n + 5 * o) } function a(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i, n + 3 * o), e.lineTo(i + 6 * a, n + 3 * o), e.moveTo(i + 3 * a, n), e.lineTo(i + 3 * a, n + 6 * o), e.moveTo(i + 3 * a, n + 8 * o), e.lineTo(i + 3 * a, n + t.height), e.lineTo(i + t.width, n + t.height), e.lineTo(i + t.width, n + 3 * o), e.lineTo(i + 8 * a, n + 3 * o) } function o(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i + 6 * a, n), e.lineTo(i + 2 * a, n + 3 * o), e.lineTo(i + 6 * a, n + 6 * o), e.moveTo(i + 2 * a, n + 3 * o), e.lineTo(i + 14 * a, n + 3 * o), e.lineTo(i + 14 * a, n + 11 * o), e.moveTo(i + 2 * a, n + 5 * o), e.lineTo(i + 2 * a, n + 13 * o), e.lineTo(i + 14 * a, n + 13 * o), e.moveTo(i + 10 * a, n + 10 * o), e.lineTo(i + 14 * a, n + 13 * o), e.lineTo(i + 10 * a, n + t.height) } function r(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16, r = t.width / 2; e.lineWidth = 1.5, e.arc(i + r, n + r, r - a, 0, 2 * Math.PI / 3), e.moveTo(i + 3 * a, n + t.height), e.lineTo(i + 0 * a, n + 12 * o), e.lineTo(i + 5 * a, n + 11 * o), e.moveTo(i, n + 8 * o), e.arc(i + r, n + r, r - a, Math.PI, 5 * Math.PI / 3), e.moveTo(i + 13 * a, n), e.lineTo(i + t.width, n + 4 * o), e.lineTo(i + 11 * a, n + 5 * o) } function s(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i, n), e.lineTo(i, n + t.height), e.lineTo(i + t.width, n + t.height), e.moveTo(i + 2 * a, n + 14 * o), e.lineTo(i + 7 * a, n + 6 * o), e.lineTo(i + 11 * a, n + 11 * o), e.lineTo(i + 15 * a, n + 2 * o) } function l(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i, n), e.lineTo(i, n + t.height), e.lineTo(i + t.width, n + t.height), e.moveTo(i + 3 * a, n + 14 * o), e.lineTo(i + 3 * a, n + 6 * o), e.lineTo(i + 4 * a, n + 6 * o), e.lineTo(i + 4 * a, n + 14 * o), e.moveTo(i + 7 * a, n + 14 * o), e.lineTo(i + 7 * a, n + 2 * o), e.lineTo(i + 8 * a, n + 2 * o), e.lineTo(i + 8 * a, n + 14 * o), e.moveTo(i + 11 * a, n + 14 * o), e.lineTo(i + 11 * a, n + 9 * o), e.lineTo(i + 12 * a, n + 9 * o), e.lineTo(i + 12 * a, n + 14 * o) } function h(e, t) { var i = t.x, n = t.y, a = t.width - 2, o = t.height - 2, r = Math.min(a, o) / 2; n += 2, e.moveTo(i + r + 3, n + r - 3), e.arc(i + r + 3, n + r - 3, r - 1, 0, -Math.PI / 2, !0), e.lineTo(i + r + 3, n + r - 3), e.moveTo(i + r, n), e.lineTo(i + r, n + r), e.arc(i + r, n + r, r, -Math.PI / 2, 2 * Math.PI, !0), e.lineTo(i + r, n + r), e.lineWidth = 1.5 } function d(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; n -= o, e.moveTo(i + 1 * a, n + 2 * o), e.lineTo(i + 15 * a, n + 2 * o), e.lineTo(i + 14 * a, n + 3 * o), e.lineTo(i + 2 * a, n + 3 * o), e.moveTo(i + 3 * a, n + 6 * o), e.lineTo(i + 13 * a, n + 6 * o), e.lineTo(i + 12 * a, n + 7 * o), e.lineTo(i + 4 * a, n + 7 * o), e.moveTo(i + 5 * a, n + 10 * o), e.lineTo(i + 11 * a, n + 10 * o), e.lineTo(i + 10 * a, n + 11 * o), e.lineTo(i + 6 * a, n + 11 * o), e.moveTo(i + 7 * a, n + 14 * o), e.lineTo(i + 9 * a, n + 14 * o), e.lineTo(i + 8 * a, n + 15 * o), e.lineTo(i + 7 * a, n + 15 * o) } function c(e, t) { var i = t.x, n = t.y, a = t.width, o = t.height, r = a / 16, s = o / 16, l = 2 * Math.min(r, s); e.moveTo(i + r + l, n + s + l), e.arc(i + r, n + s, l, Math.PI / 4, 3 * Math.PI), e.lineTo(i + 7 * r - l, n + 6 * s - l), e.arc(i + 7 * r, n + 6 * s, l, Math.PI / 4 * 5, 4 * Math.PI), e.arc(i + 7 * r, n + 6 * s, l / 2, Math.PI / 4 * 5, 4 * Math.PI), e.moveTo(i + 7 * r - l / 2, n + 6 * s + l), e.lineTo(i + r + l, n + 14 * s - l), e.arc(i + r, n + 14 * s, l, -Math.PI / 4, 2 * Math.PI), e.moveTo(i + 7 * r + l / 2, n + 6 * s), e.lineTo(i + 14 * r - l, n + 10 * s - l / 2), e.moveTo(i + 16 * r, n + 10 * s), e.arc(i + 14 * r, n + 10 * s, l, 0, 3 * Math.PI), e.lineWidth = 1.5 } function m(e, t) { var i = t.x, n = t.y, a = t.width, o = t.height, r = Math.min(a, o) / 2; e.moveTo(i + a, n + o / 2), e.arc(i + r, n + r, r, 0, 2 * Math.PI), e.arc(i + r, n, r, Math.PI / 4, Math.PI / 5 * 4), e.arc(i, n + r, r, -Math.PI / 3, Math.PI / 3), e.arc(i + a, n + o, r, Math.PI, Math.PI / 2 * 3), e.lineWidth = 1.5 } function p(e, t) { for (var i = t.x, n = t.y, a = t.width, o = t.height, r = Math.round(o / 3), s = Math.round((r - 2) / 2), l = 3; l--;) e.rect(i, n + r * l + s, a, 2) } function u(e, t) { for (var i = t.x, n = t.y, a = t.width, o = t.height, r = Math.round(a / 3), s = Math.round((r - 2) / 2), l = 3; l--;) e.rect(i + r * l + s, n, 2, o) } function V(e, t) { var i = t.x, n = t.y, a = t.width / 16; e.moveTo(i + a, n), e.lineTo(i + a, n + t.height), e.lineTo(i + 15 * a, n + t.height), e.lineTo(i + 15 * a, n), e.lineTo(i + a, n), e.moveTo(i + 3 * a, n + 3 * a), e.lineTo(i + 13 * a, n + 3 * a), e.moveTo(i + 3 * a, n + 6 * a), e.lineTo(i + 13 * a, n + 6 * a), e.moveTo(i + 3 * a, n + 9 * a), e.lineTo(i + 13 * a, n + 9 * a), e.moveTo(i + 3 * a, n + 12 * a), e.lineTo(i + 9 * a, n + 12 * a) } function U(e, t) { var i = t.x, n = t.y, a = t.width / 16, o = t.height / 16; e.moveTo(i, n), e.lineTo(i, n + t.height), e.lineTo(i + t.width, n + t.height), e.lineTo(i + t.width, n), e.lineTo(i, n), e.moveTo(i + 4 * a, n), e.lineTo(i + 4 * a, n + 8 * o), e.lineTo(i + 12 * a, n + 8 * o), e.lineTo(i + 12 * a, n), e.moveTo(i + 6 * a, n + 11 * o), e.lineTo(i + 6 * a, n + 13 * o), e.lineTo(i + 10 * a, n + 13 * o), e.lineTo(i + 10 * a, n + 11 * o), e.lineTo(i + 6 * a, n + 11 * o) } function g(e, t) { var i = t.x, n = t.y, a = t.width, o = t.height; e.moveTo(i, n + o / 2), e.lineTo(i + a, n + o / 2), e.moveTo(i + a / 2, n), e.lineTo(i + a / 2, n + o) } function f(e, t) { var i = t.width / 2, n = t.height / 2, a = Math.min(i, n); e.moveTo(t.x + i + a, t.y + n), e.arc(t.x + i, t.y + n, a, 0, 2 * Math.PI), e.closePath() } function y(e, t) { e.rect(t.x, t.y, t.width, t.height), e.closePath() } function b(e, t) { var i = t.width / 2, n = t.height / 2, a = t.x + i, o = t.y + n, r = Math.min(i, n); e.moveTo(a, o - r), e.lineTo(a + r, o + r), e.lineTo(a - r, o + r), e.lineTo(a, o - r), e.closePath() } function _(e, t) { var i = t.width / 2, n = t.height / 2, a = t.x + i, o = t.y + n, r = Math.min(i, n); e.moveTo(a, o - r), e.lineTo(a + r, o), e.lineTo(a, o + r), e.lineTo(a - r, o), e.lineTo(a, o - r), e.closePath() } function x(e, t) { var i = t.x, n = t.y, a = t.width / 16; e.moveTo(i + 8 * a, n), e.lineTo(i + a, n + t.height), e.lineTo(i + 8 * a, n + t.height / 4 * 3), e.lineTo(i + 15 * a, n + t.height), e.lineTo(i + 8 * a, n), e.closePath() } function k(t, i) { var n = e("zrender/shape/Star"), a = i.width / 2, o = i.height / 2; n.prototype.buildPath(t, { x: i.x + a, y: i.y + o, r: Math.min(a, o), n: i.n || 5 }) } function v(t, i) { var n = e("zrender/shape/Heart"); n.prototype.buildPath(t, { x: i.x + i.width / 2, y: i.y + .2 * i.height, a: i.width / 2, b: .8 * i.height }) } function L(t, i) { var n = e("zrender/shape/Droplet"); n.prototype.buildPath(t, { x: i.x + .5 * i.width, y: i.y + .5 * i.height, a: .5 * i.width, b: .8 * i.height }) } function w(e, t) { var i = t.x, n = t.y - t.height / 2 * 1.5, a = t.width / 2, o = t.height / 2, r = Math.min(a, o); e.arc(i + a, n + o, r, Math.PI / 5 * 4, Math.PI / 5), e.lineTo(i + a, n + o + 1.5 * r), e.closePath() } function W(t, i, n) { var a = e("zrender/shape/Image"); this._imageShape = this._imageShape || new a({ style: {} }); for (var o in i) this._imageShape.style[o] = i[o]; this._imageShape.brush(t, !1, n) } function X(e) { S.call(this, e) } var I = e("zrender/tool/util"), S = e("zrender/shape/Base"); return X.prototype = { type: "icon", iconLibrary: { mark: t, markUndo: i, markClear: n, dataZoom: a, dataZoomReset: o, restore: r, lineChart: s, barChart: l, pieChart: h, funnelChart: d, forceChart: c, chordChart: m, stackChart: p, tiledChart: u, dataView: V, saveAsImage: U, cross: g, circle: f, rectangle: y, triangle: b, diamond: _, arrow: x, star: k, heart: v, droplet: L, pin: w, image: W }, brush: function(t, i, n) { var a = i ? this.highlightStyle : this.style; a = a || {}; var o = a.iconType || this.style.iconType; if ("image" === o) { var r = e("zrender/shape/Image"); r.prototype.brush.call(this, t, i, n) } else { var a = this.beforeBrush(t, i); switch (t.beginPath(), this.buildPath(t, a, n), a.brushType) { case "both": t.fill(); case "stroke": a.lineWidth > 0 && t.stroke(); break; default: t.fill() } this.drawText(t, a, this.style), this.afterBrush(t) } }, buildPath: function(e, t, i) { this.iconLibrary[t.iconType] ? this.iconLibrary[t.iconType].call(this, e, t, i) : (e.moveTo(t.x, t.y), e.lineTo(t.x + t.width, t.y), e.lineTo(t.x + t.width, t.y + t.height), e.lineTo(t.x, t.y + t.height), e.lineTo(t.x, t.y), e.closePath()) }, getRect: function(e) { return e.__rect ? e.__rect : (e.__rect = { x: Math.round(e.x), y: Math.round(e.y - ("pin" == e.iconType ? e.height / 2 * 1.5 : 0)), width: e.width, height: e.height * ("pin" === e.iconType ? 1.25 : 1) }, e.__rect) }, isCover: function(e, t) { var i = this.transformCoordToLocal(e, t); e = i[0], t = i[1]; var n = this.style.__rect; n || (n = this.style.__rect = this.getRect(this.style)); var a = n.height < 8 || n.width < 8 ? 4 : 0; return e >= n.x - a && e <= n.x + n.width + a && t >= n.y - a && t <= n.y + n.height + a } }, I.inherits(X, S), X }), define("echarts/util/shape/MarkLine", ["require", "zrender/shape/Base", "./Icon", "zrender/shape/Line", "zrender/shape/BezierCurve", "zrender/tool/area", "zrender/shape/util/dashedLineTo", "zrender/tool/util", "zrender/tool/curve"], function(e) { function t(e) { i.call(this, e), this.style.curveness > 0 && this.updatePoints(this.style), this.highlightStyle.curveness > 0 && this.updatePoints(this.highlightStyle) } var i = e("zrender/shape/Base"), n = e("./Icon"), a = e("zrender/shape/Line"), o = new a({}), r = e("zrender/shape/BezierCurve"), s = new r({}), l = e("zrender/tool/area"), h = e("zrender/shape/util/dashedLineTo"), d = e("zrender/tool/util"), c = e("zrender/tool/curve"); return t.prototype = { type: "mark-line", brush: function(e, t) { var i = this.style; t && (i = this.getHighlightStyle(i, this.highlightStyle || {})), e.save(), this.setContext(e, i), this.setTransform(e), e.save(), e.beginPath(), this.buildPath(e, i), e.stroke(), e.restore(), this.brushSymbol(e, i, 0), this.brushSymbol(e, i, 1), this.drawText(e, i, this.style), e.restore() }, buildPath: function(e, t) { var i = t.lineType || "solid"; if (e.moveTo(t.xStart, t.yStart), t.curveness > 0) { var n = null; switch (i) { case "dashed": n = [5, 5]; break; case "dotted": n = [1, 1] } n && e.setLineDash && e.setLineDash(n), e.quadraticCurveTo(t.cpX1, t.cpY1, t.xEnd, t.yEnd) } else if ("solid" == i) e.lineTo(t.xEnd, t.yEnd); else { var a = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1); h(e, t.xStart, t.yStart, t.xEnd, t.yEnd, a) } }, updatePoints: function(e) { var t = e.curveness || 0, i = 1, n = e.xStart, a = e.yStart, o = e.xEnd, r = e.yEnd, s = (n + o) / 2 - i * (a - r) * t, l = (a + r) / 2 - i * (o - n) * t; e.cpX1 = s, e.cpY1 = l }, brushSymbol: function(e, t, i) { if ("none" != t.symbol[i]) { e.save(), e.beginPath(), e.lineWidth = t.symbolBorder, e.strokeStyle = t.symbolBorderColor; var a = t.symbol[i].replace("empty", "").toLowerCase(); t.symbol[i].match("empty") && (e.fillStyle = "#fff"); var o = t.xStart, r = t.yStart, s = t.xEnd, l = t.yEnd, h = 0 === i ? o : s, d = 0 === i ? r : l, m = t.curveness || 0, p = null != t.symbolRotate[i] ? t.symbolRotate[i] - 0 : 0; if (p = p / 180 * Math.PI, "arrow" == a && 0 === p) if (0 === m) { var u = 0 === i ? -1 : 1; p = Math.PI / 2 + Math.atan2(u * (l - r), u * (s - o)) } else { var V = t.cpX1, U = t.cpY1, g = c.quadraticDerivativeAt, f = g(o, V, s, i), y = g(r, U, l, i); p = Math.PI / 2 + Math.atan2(y, f) } e.translate(h, d), 0 !== p && e.rotate(p); var b = t.symbolSize[i]; n.prototype.buildPath(e, { x: -b, y: -b, width: 2 * b, height: 2 * b, iconType: a }), e.closePath(), e.fill(), e.stroke(), e.restore() } }, getRect: function(e) { return e.curveness > 0 ? s.getRect(e) : o.getRect(e), e.__rect }, isCover: function(e, t) { var i = this.transformCoordToLocal(e, t); return e = i[0], t = i[1], this.isCoverRect(e, t) ? this.style.curveness > 0 ? l.isInside(s, this.style, e, t) : l.isInside(o, this.style, e, t) : !1 } }, d.inherits(t, i), t }), define("echarts/util/shape/Symbol", ["require", "zrender/shape/Base", "zrender/shape/Polygon", "zrender/tool/util", "./normalIsCover"], function(e) { function t(e) { i.call(this, e) } var i = e("zrender/shape/Base"), n = e("zrender/shape/Polygon"), a = new n({}), o = e("zrender/tool/util"); return t.prototype = { type: "symbol", buildPath: function(e, t) { var i = t.pointList, n = i.length; if (0 !== n) for (var a, o, r, s, l, h = 1e4, d = Math.ceil(n / h), c = i[0] instanceof Array, m = t.size ? t.size : 2, p = m, u = m / 2, V = 2 * Math.PI, U = 0; d > U; U++) { e.beginPath(), a = U * h, o = a + h, o = o > n ? n : o; for (var g = a; o > g; g++) if (t.random && (r = t["randomMap" + g % 20] / 100, p = m * r * r, u = p / 2), c ? (s = i[g][0], l = i[g][1]) : (s = i[g].x, l = i[g].y), 3 > p) e.rect(s - u, l - u, p, p); else switch (t.iconType) { case "circle": e.moveTo(s, l), e.arc(s, l, u, 0, V, !0); break; case "diamond": e.moveTo(s, l - u), e.lineTo(s + u / 3, l - u / 3), e.lineTo(s + u, l), e.lineTo(s + u / 3, l + u / 3), e.lineTo(s, l + u), e.lineTo(s - u / 3, l + u / 3), e.lineTo(s - u, l), e.lineTo(s - u / 3, l - u / 3), e.lineTo(s, l - u); break; default: e.rect(s - u, l - u, p, p) } if (e.closePath(), d - 1 > U) switch (t.brushType) { case "both": e.fill(), t.lineWidth > 0 && e.stroke(); break; case "stroke": t.lineWidth > 0 && e.stroke(); break; default: e.fill() } } }, getRect: function(e) { return e.__rect || a.getRect(e) }, isCover: e("./normalIsCover") }, o.inherits(t, i), t }), define("zrender/shape/Polyline", ["require", "./Base", "./util/smoothSpline", "./util/smoothBezier", "./util/dashedLineTo", "./Polygon", "../tool/util"], function(e) { var t = e("./Base"), i = e("./util/smoothSpline"), n = e("./util/smoothBezier"), a = e("./util/dashedLineTo"), o = function(e) { this.brushTypeOnly = "stroke", this.textPosition = "end", t.call(this, e) }; return o.prototype = { type: "polyline", buildPath: function(e, t) { var n = t.pointList; if (!(n.length < 2)) { var o = Math.min(t.pointList.length, Math.round(t.pointListLength || t.pointList.length)); if (t.smooth && "spline" !== t.smooth) { t.controlPointList || this.updateControlPoints(t); var r = t.controlPointList; e.moveTo(n[0][0], n[0][1]); for (var s, l, h, d = 0; o - 1 > d; d++) s = r[2 * d], l = r[2 * d + 1], h = n[d + 1], e.bezierCurveTo(s[0], s[1], l[0], l[1], h[0], h[1]) } else if ("spline" === t.smooth && (n = i(n), o = n.length), t.lineType && "solid" != t.lineType) { if ("dashed" == t.lineType || "dotted" == t.lineType) { var c = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1); e.moveTo(n[0][0], n[0][1]); for (var d = 1; o > d; d++) a(e, n[d - 1][0], n[d - 1][1], n[d][0], n[d][1], c) } } else { e.moveTo(n[0][0], n[0][1]); for (var d = 1; o > d; d++) e.lineTo(n[d][0], n[d][1]) } } }, updateControlPoints: function(e) { e.controlPointList = n(e.pointList, e.smooth, !1, e.smoothConstraint) }, getRect: function(t) { return e("./Polygon").prototype.getRect(t) } }, e("../tool/util").inherits(o, t), o }), define("zrender/shape/ShapeBundle", ["require", "./Base", "../tool/util"], function(e) { var t = e("./Base"), i = function(e) { t.call(this, e) }; return i.prototype = { constructor: i, type: "shape-bundle", brush: function(e, t) { var i = this.beforeBrush(e, t); e.beginPath(); for (var n = 0; n < i.shapeList.length; n++) { var a = i.shapeList[n], o = a.style; t && (o = a.getHighlightStyle(o, a.highlightStyle || {}, a.brushTypeOnly)), a.buildPath(e, o) } switch (i.brushType) { case "both": e.fill(); case "stroke": i.lineWidth > 0 && e.stroke(); break; default: e.fill() } this.drawText(e, i, this.style), this.afterBrush(e) }, getRect: function(e) { if (e.__rect) return e.__rect; for (var t = 1 / 0, i = -(1 / 0), n = 1 / 0, a = -(1 / 0), o = 0; o < e.shapeList.length; o++) var r = e.shapeList[o], s = r.getRect(r.style), t = Math.min(s.x, t), n = Math.min(s.y, n), i = Math.max(s.x + s.width, i), a = Math.max(s.y + s.height, a); return e.__rect = { x: t, y: n, width: i - t, height: a - n }, e.__rect }, isCover: function(e, t) { var i = this.transformCoordToLocal(e, t); if (e = i[0], t = i[1], this.isCoverRect(e, t)) for (var n = 0; n < this.style.shapeList.length; n++) { var a = this.style.shapeList[n]; if (a.isCover(e, t)) return !0 } return !1 } }, e("../tool/util").inherits(i, t), i }), define("echarts/util/ecAnimation", ["require", "zrender/tool/util", "zrender/tool/curve", "zrender/shape/Polygon"], function(e) { function t(e, t, i, n, a) { var o, r = i.style.pointList, s = r.length; if (!t) { if (o = [], "vertical" != i._orient) for (var l = r[0][1], h = 0; s > h; h++) o[h] = [r[h][0], l]; else for (var d = r[0][0], h = 0; s > h; h++) o[h] = [d, r[h][1]]; "half-smooth-polygon" == i.type && (o[s - 1] = u.clone(r[s - 1]), o[s - 2] = u.clone(r[s - 2])), t = { style: { pointList: o } } } o = t.style.pointList; var c = o.length; i.style.pointList = c == s ? o : s > c ? o.concat(r.slice(c)) : o.slice(0, s), e.addShape(i), i.__animating = !0, e.animate(i.id, "style").when(n, { pointList: r }).during(function() { i.updateControlPoints && i.updateControlPoints(i.style) }).done(function() { i.__animating = !1 }).start(a) } function i(e, t) { for (var i = arguments.length, n = 2; i > n; n++) { var a = arguments[n]; e.style[a] = t.style[a] } } function n(e, t, n, a, o) { var r = n.style; t || (t = { position: n.position, style: { x: r.x, y: "vertical" == n._orient ? r.y + r.height : r.y, width: "vertical" == n._orient ? r.width : 0, height: "vertical" != n._orient ? r.height : 0 } }); var s = r.x, l = r.y, h = r.width, d = r.height, c = [n.position[0], n.position[1]]; i(n, t, "x", "y", "width", "height"), n.position = t.position, e.addShape(n), (c[0] != t.position[0] || c[1] != t.position[1]) && e.animate(n.id, "").when(a, { position: c }).start(o), n.__animating = !0, e.animate(n.id, "style").when(a, { x: s, y: l, width: h, height: d }).done(function() { n.__animating = !1 }).start(o) } function a(e, t, i, n, a) { if (!t) { var o = i.style.y; t = { style: { y: [o[0], o[0], o[0], o[0]] } } } var r = i.style.y; i.style.y = t.style.y, e.addShape(i), i.__animating = !0, e.animate(i.id, "style").when(n, { y: r }).done(function() { i.__animating = !1 }).start(a) } function o(e, t, i, n, a) { var o = i.style.x, r = i.style.y, s = i.style.r0, l = i.style.r; i.__animating = !0, "r" != i._animationAdd ? (i.style.r0 = 0, i.style.r = 0, i.rotation = [2 * Math.PI, o, r], e.addShape(i), e.animate(i.id, "style").when(n, { r0: s, r: l }).done(function() { i.__animating = !1 }).start(a), e.animate(i.id, "").when(n, { rotation: [0, o, r] }).start(a)) : (i.style.r0 = i.style.r, e.addShape(i), e.animate(i.id, "style").when(n, { r0: s }).done(function() { i.__animating = !1 }).start(a)) } function r(e, t, n, a, o) { t || (t = "r" != n._animationAdd ? { style: { startAngle: n.style.startAngle, endAngle: n.style.startAngle } } : { style: { r0: n.style.r } }); var r = n.style.startAngle, s = n.style.endAngle; i(n, t, "startAngle", "endAngle"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, { startAngle: r, endAngle: s }).done(function() { n.__animating = !1 }).start(o) } function s(e, t, n, a, o) { t || (t = { style: { x: "left" == n.style.textAlign ? n.style.x + 100 : n.style.x - 100, y: n.style.y } }); var r = n.style.x, s = n.style.y; i(n, t, "x", "y"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, { x: r, y: s }).done(function() { n.__animating = !1 }).start(o) } function l(t, i, n, a, o) { var r = e("zrender/shape/Polygon").prototype.getRect(n.style), s = r.x + r.width / 2, l = r.y + r.height / 2; n.scale = [.1, .1, s, l], t.addShape(n), n.__animating = !0, t.animate(n.id, "").when(a, { scale: [1, 1, s, l] }).done(function() { n.__animating = !1 }).start(o) } function h(e, t, n, a, o) { t || (t = { style: { source0: 0, source1: n.style.source1 > 0 ? 360 : -360, target0: 0, target1: n.style.target1 > 0 ? 360 : -360 } }); var r = n.style.source0, s = n.style.source1, l = n.style.target0, h = n.style.target1; t.style && i(n, t, "source0", "source1", "target0", "target1"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, { source0: r, source1: s, target0: l, target1: h }).done(function() { n.__animating = !1 }).start(o) } function d(e, t, i, n, a) { t || (t = { style: { angle: i.style.startAngle } }); var o = i.style.angle; i.style.angle = t.style.angle, e.addShape(i), i.__animating = !0, e.animate(i.id, "style").when(n, { angle: o }).done(function() { i.__animating = !1 }).start(a) } function c(e, t, i, a, o, r) { if (i.style._x = i.style.x, i.style._y = i.style.y, i.style._width = i.style.width, i.style._height = i.style.height, t) n(e, t, i, a, o); else { var s = i._x || 0, l = i._y || 0; i.scale = [.01, .01, s, l], e.addShape(i), i.__animating = !0, e.animate(i.id, "").delay(r).when(a, { scale: [1, 1, s, l] }).done(function() { i.__animating = !1 }).start(o || "QuinticOut") } } function m(e, t, n, a, o) { t || (t = { style: { xStart: n.style.xStart, yStart: n.style.yStart, xEnd: n.style.xStart, yEnd: n.style.yStart } }); var r = n.style.xStart, s = n.style.xEnd, l = n.style.yStart, h = n.style.yEnd; i(n, t, "xStart", "xEnd", "yStart", "yEnd"), e.addShape(n), n.__animating = !0, e.animate(n.id, "style").when(a, { xStart: r, xEnd: s, yStart: l, yEnd: h }).done(function() { n.__animating = !1 }).start(o) } function p(e, t, i, n, a) { a = a || "QuinticOut", i.__animating = !0, e.addShape(i); var o = i.style, r = function() { i.__animating = !1 }, s = o.xStart, l = o.yStart, h = o.xEnd, d = o.yEnd; if (o.curveness > 0) { i.updatePoints(o); var c = { p: 0 }, m = o.cpX1, p = o.cpY1, u = [], U = [], g = V.quadraticSubdivide; e.animation.animate(c).when(n, { p: 1 }).during(function() { g(s, m, h, c.p, u), g(l, p, d, c.p, U), o.cpX1 = u[1], o.cpY1 = U[1], o.xEnd = u[2], o.yEnd = U[2], e.modShape(i) }).done(r).start(a) } else e.animate(i.id, "style").when(0, { xEnd: s, yEnd: l }).when(n, { xEnd: h, yEnd: d }).done(r).start(a) } var u = e("zrender/tool/util"), V = e("zrender/tool/curve"); return { pointList: t, rectangle: n, candle: a, ring: o, sector: r, text: s, polygon: l, ribbon: h, gaugePointer: d, icon: c, line: m, markline: p } }), define("echarts/util/ecEffect", ["require", "../util/ecData", "zrender/shape/Circle", "zrender/shape/Image", "zrender/tool/curve", "../util/shape/Icon", "../util/shape/Symbol", "zrender/shape/ShapeBundle", "zrender/shape/Polyline", "zrender/tool/vector", "zrender/tool/env"], function(e) { function t(e, t, i, n) { var a, r = i.effect, l = r.color || i.style.strokeColor || i.style.color, d = r.shadowColor || l, c = r.scaleSize, m = r.bounceDistance, p = "undefined" != typeof r.shadowBlur ? r.shadowBlur : c; "image" !== i.type ? (a = new h({ zlevel: n, style: { brushType: "stroke", iconType: "droplet" != i.style.iconType ? i.style.iconType : "circle", x: p + 1, y: p + 1, n: i.style.n, width: i.style._width * c, height: i.style._height * c, lineWidth: 1, strokeColor: l, shadowColor: d, shadowBlur: p }, draggable: !1, hoverable: !1 }), "pin" == i.style.iconType && (a.style.y += a.style.height / 2 * 1.5), u && (a.style.image = e.shapeToImage(a, a.style.width + 2 * p + 2, a.style.height + 2 * p + 2).style.image, a = new s({ zlevel: a.zlevel, style: a.style, draggable: !1, hoverable: !1 }))) : a = new s({ zlevel: n, style: i.style, draggable: !1, hoverable: !1 }), o.clone(i, a), a.position = i.position, t.push(a), e.addShape(a); var V = "image" !== i.type ? window.devicePixelRatio || 1 : 1, U = (a.style.width / V - i.style._width) / 2; a.style.x = i.style._x - U, a.style.y = i.style._y - U, "pin" == i.style.iconType && (a.style.y -= i.style.height / 2 * 1.5); var g = 100 * (r.period + 10 * Math.random()); e.modShape(i.id, { invisible: !0 }); var f = a.style.x + a.style.width / 2 / V, y = a.style.y + a.style.height / 2 / V; "scale" === r.type ? (e.modShape(a.id, { scale: [.1, .1, f, y] }), e.animate(a.id, "", r.loop).when(g, { scale: [1, 1, f, y] }).done(function() { i.effect.show = !1, e.delShape(a.id) }).start()) : e.animate(a.id, "style", r.loop).when(g, { y: a.style.y - m }).when(2 * g, { y: a.style.y }).done(function() { i.effect.show = !1, e.delShape(a.id) }).start() } function i(e, t, i, n) { var a = i.effect, o = a.color || i.style.strokeColor || i.style.color, r = a.scaleSize, s = a.shadowColor || o, l = "undefined" != typeof a.shadowBlur ? a.shadowBlur : 2 * r, h = window.devicePixelRatio || 1, c = new d({ zlevel: n, position: i.position, scale: i.scale, style: { pointList: i.style.pointList, iconType: i.style.iconType, color: o, strokeColor: o, shadowColor: s, shadowBlur: l * h, random: !0, brushType: "fill", lineWidth: 1, size: i.style.size }, draggable: !1, hoverable: !1 }); t.push(c), e.addShape(c), e.modShape(i.id, { invisible: !0 }); for (var m = Math.round(100 * a.period), p = {}, u = {}, V = 0; 20 > V; V++) c.style["randomMap" + V] = 0, p = {}, p["randomMap" + V] = 100, u = {}, u["randomMap" + V] = 0, c.style["randomMap" + V] = 100 * Math.random(), e.animate(c.id, "style", !0).when(m, p).when(2 * m, u).when(3 * m, p).when(4 * m, p).delay(Math.random() * m * V).start() } function n(e, t, i, n, a) { var s = i.effect, h = i.style, d = s.color || h.strokeColor || h.color, c = s.shadowColor || h.strokeColor || d, V = h.lineWidth * s.scaleSize, U = "undefined" != typeof s.shadowBlur ? s.shadowBlur : V, g = new r({ zlevel: n, style: { x: U, y: U, r: V, color: d, shadowColor: c, shadowBlur: U }, hoverable: !1 }), f = 0; if (u && !a) { var n = g.zlevel; g = e.shapeToImage(g, 2 * (V + U), 2 * (V + U)), g.zlevel = n, g.hoverable = !1, f = U } a || (o.clone(i, g), g.position = i.position, t.push(g), e.addShape(g)); var y = function() { a || (i.effect.show = !1, e.delShape(g.id)), g.effectAnimator = null }; if (i instanceof m) { for (var b = [0], _ = 0, x = h.pointList, k = h.controlPointList, v = 1; v < x.length; v++) { if (k) { var L = k[2 * (v - 1)], w = k[2 * (v - 1) + 1]; _ += p.dist(x[v - 1], L) + p.dist(L, w) + p.dist(w, x[v]) } else _ += p.dist(x[v - 1], x[v]); b.push(_) } for (var W = { p: 0 }, X = e.animation.animate(W, { loop: s.loop }), v = 0; v < b.length; v++) X.when(b[v] * s.period, { p: v }); X.during(function() { var t, i, n = Math.floor(W.p); if (n == x.length - 1) t = x[n][0], i = x[n][1]; else { var o = W.p - n, r = x[n], s = x[n + 1]; if (k) { var h = k[2 * n], d = k[2 * n + 1]; t = l.cubicAt(r[0], h[0], d[0], s[0], o), i = l.cubicAt(r[1], h[1], d[1], s[1], o) } else t = (s[0] - r[0]) * o + r[0], i = (s[1] - r[1]) * o + r[1] } g.style.x = t, g.style.y = i, a || e.modShape(g) }).done(y).start(), X.duration = _ * s.period, g.effectAnimator = X } else { var I = h.xStart - f, S = h.yStart - f, K = h.xEnd - f, C = h.yEnd - f; g.style.x = I, g.style.y = S; var T = (K - I) * (K - I) + (C - S) * (C - S), E = Math.round(Math.sqrt(Math.round(T * s.period * s.period))); if (i.style.curveness > 0) { var z = h.cpX1 - f, A = h.cpY1 - f; g.effectAnimator = e.animation.animate(g, { loop: s.loop }).when(E, { p: 1 }).during(function(t, i) { g.style.x = l.quadraticAt(I, z, K, i), g.style.y = l.quadraticAt(S, A, C, i), a || e.modShape(g) }).done(y).start() } else g.effectAnimator = e.animation.animate(g.style, { loop: s.loop }).when(E, { x: K, y: C }).during(function() { a || e.modShape(g) }).done(y).start(); g.effectAnimator.duration = E } return g } function a(e, t, i, a) { var o = new c({ style: { shapeList: [] }, zlevel: a, hoverable: !1 }), r = i.style.shapeList, s = i.effect; o.position = i.position; for (var l = 0, h = [], d = 0; d < r.length; d++) { r[d].effect = s; var m = n(e, null, r[d], a, !0), p = m.effectAnimator; o.style.shapeList.push(m), p.duration > l && (l = p.duration), 0 === d && (o.style.color = m.style.color, o.style.shadowBlur = m.style.shadowBlur, o.style.shadowColor = m.style.shadowColor), h.push(p) } t.push(o), e.addShape(o); var u = function() { for (var e = 0; e < h.length; e++) h[e].stop() }; if (l) { o.__dummy = 0; var V = e.animate(o.id, "", s.loop).when(l, { __dummy: 1 }).during(function() { e.modShape(o) }).done(function() { i.effect.show = !1, e.delShape(o.id) }).start(), U = V.stop; V.stop = function() { u(), U.call(this) } } } var o = e("../util/ecData"), r = e("zrender/shape/Circle"), s = e("zrender/shape/Image"), l = e("zrender/tool/curve"), h = e("../util/shape/Icon"), d = e("../util/shape/Symbol"), c = e("zrender/shape/ShapeBundle"), m = e("zrender/shape/Polyline"), p = e("zrender/tool/vector"), u = e("zrender/tool/env").canvasSupported; return { point: t, largePoint: i, line: n, largeLine: a } }), define("echarts/component/base", ["require", "../config", "../util/ecData", "../util/ecQuery", "../util/number", "zrender/tool/util", "zrender/tool/env"], function(e) { function t(e, t, a, o, r) { this.ecTheme = e, this.messageCenter = t, this.zr = a, this.option = o, this.series = o.series, this.myChart = r, this.component = r.component, this.shapeList = [], this.effectList = []; var s = this; s._onlegendhoverlink = function(e) { if (s.legendHoverLink) for (var t, a = e.target, o = s.shapeList.length - 1; o >= 0; o--) t = s.type == i.CHART_TYPE_PIE || s.type == i.CHART_TYPE_FUNNEL ? n.get(s.shapeList[o], "name") : (n.get(s.shapeList[o], "series") || {}).name, t != a || s.shapeList[o].invisible || s.shapeList[o].__animating || s.zr.addHoverShape(s.shapeList[o]) }, t && t.bind(i.EVENT.LEGEND_HOVERLINK, this._onlegendhoverlink) } var i = e("../config"), n = e("../util/ecData"), a = e("../util/ecQuery"), o = e("../util/number"), r = e("zrender/tool/util"); return t.prototype = { canvasSupported: e("zrender/tool/env").canvasSupported, _getZ: function(e) { if (null != this[e]) return this[e]; var t = this.ecTheme[this.type]; return t && null != t[e] ? t[e] : (t = i[this.type], t && null != t[e] ? t[e] : 0) }, getZlevelBase: function() { return this._getZ("zlevel") }, getZBase: function() { return this._getZ("z") }, reformOption: function(e) { return e = r.merge(r.merge(e || {}, r.clone(this.ecTheme[this.type] || {})), r.clone(i[this.type] || {})), this.z = e.z, this.zlevel = e.zlevel, e }, reformCssArray: function(e) { if (!(e instanceof Array)) return [e, e, e, e]; switch (e.length + "") { case "4": return e; case "3": return [e[0], e[1], e[2], e[1]]; case "2": return [e[0], e[1], e[0], e[1]]; case "1": return [e[0], e[0], e[0], e[0]]; case "0": return [0, 0, 0, 0] } }, getShapeById: function(e) { for (var t = 0, i = this.shapeList.length; i > t; t++) if (this.shapeList[t].id === e) return this.shapeList[t]; return null }, getFont: function(e) { var t = this.getTextStyle(r.clone(e)); return t.fontStyle + " " + t.fontWeight + " " + t.fontSize + "px " + t.fontFamily }, getTextStyle: function(e) { return r.merge(r.merge(e || {}, this.ecTheme.textStyle), i.textStyle) }, getItemStyleColor: function(e, t, i, n) { return "function" == typeof e ? e.call(this.myChart, { seriesIndex: t, series: this.series[t], dataIndex: i, data: n }) : e }, getDataFromOption: function(e, t) { return null != e ? null != e.value ? e.value : e : t }, subPixelOptimize: function(e, t) { return e = t % 2 === 1 ? Math.floor(e) + .5 : Math.round(e) }, resize: function() { this.refresh && this.refresh(), this.clearEffectShape && this.clearEffectShape(!0); var e = this; setTimeout(function() { e.animationEffect && e.animationEffect() }, 200) }, clear: function() { this.clearEffectShape && this.clearEffectShape(), this.zr && this.zr.delShape(this.shapeList), this.shapeList = [] }, dispose: function() { this.onbeforDispose && this.onbeforDispose(), this.clear(), this.shapeList = null, this.effectList = null, this.messageCenter && this.messageCenter.unbind(i.EVENT.LEGEND_HOVERLINK, this._onlegendhoverlink), this.onafterDispose && this.onafterDispose() }, query: a.query, deepQuery: a.deepQuery, deepMerge: a.deepMerge, parsePercent: o.parsePercent, parseCenter: o.parseCenter, parseRadius: o.parseRadius, numAddCommas: o.addCommas, getPrecision: o.getPrecision }, t }), define("echarts/layout/EdgeBundling", ["require", "../data/KDTree", "zrender/tool/vector"], function(e) { function t(e, t) { e = e.array, t = t.array; var i = t[0] - e[0], n = t[1] - e[1], a = t[2] - e[2], o = t[3] - e[3]; return i * i + n * n + a * a + o * o } function i(e) { this.points = [e.mp0, e.mp1], this.group = e } function n(e) { var t = e.points; t[0][1] < t[1][1] || e instanceof i ? (this.array = [t[0][0], t[0][1], t[1][0], t[1][1]], this._startPoint = t[0], this._endPoint = t[1]) : (this.array = [t[1][0], t[1][1], t[0][0], t[0][1]], this._startPoint = t[1], this._endPoint = t[0]), this.ink = d(t[0], t[1]), this.edge = e, this.group = null } function a() { this.edgeList = [], this.mp0 = l(), this.mp1 = l(), this.ink = 0 } function o() { this.maxNearestEdge = 6, this.maxTurningAngle = Math.PI / 4, this.maxIteration = 20 } var r = e("../data/KDTree"), s = e("zrender/tool/vector"), l = s.create, h = s.distSquare, d = s.dist, c = s.copy, m = s.clone; return n.prototype.getStartPoint = function() { return this._startPoint }, n.prototype.getEndPoint = function() { return this._endPoint }, a.prototype.addEdge = function(e) { e.group = this, this.edgeList.push(e) }, a.prototype.removeEdge = function(e) { e.group = null, this.edgeList.splice(this.edgeList.indexOf(e), 1) }, o.prototype = { constructor: o, run: function(e) { function t(e, t) { return h(e, t) < 1e-10 } function n(e, i) { for (var n = [], a = 0, o = 0; o < e.length; o++) a > 0 && t(e[o], n[a - 1]) || (n[a++] = m(e[o])); return i[0] && !t(n[0], i[0]) && (n = n.reverse()), n } for (var a = this._iterate(e), o = 0; o++ < this.maxIteration;) { for (var r = [], s = 0; s < a.groups.length; s++) r.push(new i(a.groups[s])); var l = this._iterate(r); if (l.savedInk <= 0) break; a = l } var d = [], c = function(e, t) { for (var a, o = 0; o < e.length; o++) { var r = e[o]; if (r.edgeList[0] && r.edgeList[0].edge instanceof i) { for (var s = [], l = 0; l < r.edgeList.length; l++) s.push(r.edgeList[l].edge.group); a = t ? t.slice() : [], a.unshift(r.mp0), a.push(r.mp1), c(s, a) } else for (var l = 0; l < r.edgeList.length; l++) { var h = r.edgeList[l]; a = t ? t.slice() : [], a.unshift(r.mp0), a.push(r.mp1), a.unshift(h.getStartPoint()), a.push(h.getEndPoint()), d.push({ points: n(a, h.edge.points), rawEdge: h.edge }) } } }; return c(a.groups), d }, _iterate: function(e) { for (var i = [], o = [], s = 0, h = 0; h < e.length; h++) { var d = new n(e[h]); i.push(d) } for (var m = new r(i, 4), p = [], u = l(), V = l(), U = 0, g = l(), f = l(), y = 0, h = 0; h < i.length; h++) { var d = i[h]; if (!d.group) { m.nearestN(d, this.maxNearestEdge, t, p); for (var b = 0, _ = null, x = null, k = 0; k < p.length; k++) { var v = p[k], L = 0; v.group ? v.group !== x && (x = v.group, U = this._calculateGroupEdgeInk(v.group, d, u, V), L = v.group.ink + d.ink - U) : (U = this._calculateEdgeEdgeInk(d, v, u, V), L = v.ink + d.ink - U), L > b && (b = L, _ = v, c(f, V), c(g, u), y = U) } if (_) { s += b; var w; _.group || (w = new a, o.push(w), w.addEdge(_)), w = _.group, c(w.mp0, g), c(w.mp1, f), w.ink = y, _.group.addEdge(d) } else { var w = new a; o.push(w), c(w.mp0, d.getStartPoint()), c(w.mp1, d.getEndPoint()), w.ink = d.ink, w.addEdge(d) } } } return { groups: o, edges: i, savedInk: s } }, _calculateEdgeEdgeInk: function() { var e = [], t = []; return function(i, n, a, o) { e[0] = i.getStartPoint(), e[1] = n.getStartPoint(), t[0] = i.getEndPoint(), t[1] = n.getEndPoint(), this._calculateMeetPoints(e, t, a, o); var r = d(e[0], a) + d(a, o) + d(o, t[0]) + d(e[1], a) + d(o, t[1]); return r } }(), _calculateGroupEdgeInk: function(e, t, i, n) { for (var a = [], o = [], r = 0; r < e.edgeList.length; r++) { var s = e.edgeList[r]; a.push(s.getStartPoint()), o.push(s.getEndPoint()) } a.push(t.getStartPoint()), o.push(t.getEndPoint()), this._calculateMeetPoints(a, o, i, n); for (var l = d(i, n), r = 0; r < a.length; r++) l += d(a[r], i) + d(o[r], n); return l }, _calculateMeetPoints: function() { var e = l(), t = l(); return function(i, n, a, o) { s.set(e, 0, 0), s.set(t, 0, 0); for (var r = i.length, l = 0; r > l; l++) s.add(e, e, i[l]); s.scale(e, e, 1 / r), r = n.length; for (var l = 0; r > l; l++) s.add(t, t, n[l]); s.scale(t, t, 1 / r), this._limitTurningAngle(i, e, t, a), this._limitTurningAngle(n, t, e, o) } }(), _limitTurningAngle: function() { var e = l(), t = l(), i = l(), n = l(); return function(a, o, r, l) { var c = Math.cos(this.maxTurningAngle), m = Math.tan(this.maxTurningAngle); s.sub(e, o, r), s.normalize(e, e), s.copy(l, o); for (var p = 0, u = 0; u < a.length; u++) { var V = a[u]; s.sub(t, V, o); var U = s.len(t); s.scale(t, t, 1 / U); var g = s.dot(t, e); if (c > g) { s.scaleAndAdd(i, o, e, U * g); var f = d(i, V), y = f / m; s.scaleAndAdd(n, i, e, -y); var b = h(n, o); b > p && (p = b, s.copy(l, n)) } } } }() }, o }), define("zrender/shape/Star", ["require", "../tool/math", "./Base", "../tool/util"], function(e) { var t = e("../tool/math"), i = t.sin, n = t.cos, a = Math.PI, o = e("./Base"), r = function(e) { o.call(this, e) }; return r.prototype = { type: "star", buildPath: function(e, t) { var o = t.n; if (o && !(2 > o)) { var r = t.x, s = t.y, l = t.r, h = t.r0; null == h && (h = o > 4 ? l * n(2 * a / o) / n(a / o) : l / 3); var d = a / o, c = -a / 2, m = r + l * n(c), p = s + l * i(c); c += d; var u = t.pointList = []; u.push([m, p]); for (var V, U = 0, g = 2 * o - 1; g > U; U++) V = U % 2 === 0 ? h : l, u.push([r + V * n(c), s + V * i(c)]), c += d; u.push([m, p]), e.moveTo(u[0][0], u[0][1]); for (var U = 0; U < u.length; U++) e.lineTo(u[U][0], u[U][1]); e.closePath() } }, getRect: function(e) { if (e.__rect) return e.__rect; var t; return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = { x: Math.round(e.x - e.r - t / 2), y: Math.round(e.y - e.r - t / 2), width: 2 * e.r + t, height: 2 * e.r + t }, e.__rect } }, e("../tool/util").inherits(r, o), r }), define("zrender/shape/Heart", ["require", "./Base", "./util/PathProxy", "../tool/area", "../tool/util"], function(e) { "use strict"; var t = e("./Base"), i = e("./util/PathProxy"), n = e("../tool/area"), a = function(e) { t.call(this, e), this._pathProxy = new i }; return a.prototype = { type: "heart", buildPath: function(e, t) { var n = this._pathProxy || new i; n.begin(e), n.moveTo(t.x, t.y), n.bezierCurveTo(t.x + t.a / 2, t.y - 2 * t.b / 3, t.x + 2 * t.a, t.y + t.b / 3, t.x, t.y + t.b), n.bezierCurveTo(t.x - 2 * t.a, t.y + t.b / 3, t.x - t.a / 2, t.y - 2 * t.b / 3, t.x, t.y), n.closePath() }, getRect: function(e) { return e.__rect ? e.__rect : (this._pathProxy.isEmpty() || this.buildPath(null, e), this._pathProxy.fastBoundingRect()) }, isCover: function(e, t) { var i = this.transformCoordToLocal(e, t); return e = i[0], t = i[1], this.isCoverRect(e, t) ? n.isInsidePath(this._pathProxy.pathCommands, this.style.lineWidth, this.style.brushType, e, t) : void 0 } }, e("../tool/util").inherits(a, t), a }), define("zrender/shape/Droplet", ["require", "./Base", "./util/PathProxy", "../tool/area", "../tool/util"], function(e) { "use strict"; var t = e("./Base"), i = e("./util/PathProxy"), n = e("../tool/area"), a = function(e) { t.call(this, e), this._pathProxy = new i }; return a.prototype = { type: "droplet", buildPath: function(e, t) { var n = this._pathProxy || new i; n.begin(e), n.moveTo(t.x, t.y + t.a), n.bezierCurveTo(t.x + t.a, t.y + t.a, t.x + 3 * t.a / 2, t.y - t.a / 3, t.x, t.y - t.b), n.bezierCurveTo(t.x - 3 * t.a / 2, t.y - t.a / 3, t.x - t.a, t.y + t.a, t.x, t.y + t.a), n.closePath() }, getRect: function(e) { return e.__rect ? e.__rect : (this._pathProxy.isEmpty() || this.buildPath(null, e), this._pathProxy.fastBoundingRect()) }, isCover: function(e, t) { var i = this.transformCoordToLocal(e, t); return e = i[0], t = i[1], this.isCoverRect(e, t) ? n.isInsidePath(this._pathProxy.pathCommands, this.style.lineWidth, this.style.brushType, e, t) : void 0 } }, e("../tool/util").inherits(a, t), a }), define("zrender/tool/math", [], function() { function e(e, t) { return Math.sin(t ? e * a : e) } function t(e, t) { return Math.cos(t ? e * a : e) } function i(e) { return e * a } function n(e) { return e / a } var a = Math.PI / 180; return { sin: e, cos: t, degreeToRadian: i, radianToDegree: n } }), define("zrender/shape/util/PathProxy", ["require", "../../tool/vector"], function(e) { var t = e("../../tool/vector"), i = function(e, t) { this.command = e, this.points = t || null }, n = function() { this.pathCommands = [], this._ctx = null, this._min = [], this._max = [] }; return n.prototype.fastBoundingRect = function() { var e = this._min, i = this._max; e[0] = e[1] = 1 / 0, i[0] = i[1] = -(1 / 0); for (var n = 0; n < this.pathCommands.length; n++) { var a = this.pathCommands[n], o = a.points; switch (a.command) { case "M": t.min(e, e, o), t.max(i, i, o); break; case "L": t.min(e, e, o), t.max(i, i, o); break; case "C": for (var r = 0; 6 > r; r += 2) e[0] = Math.min(e[0], e[0], o[r]), e[1] = Math.min(e[1], e[1], o[r + 1]), i[0] = Math.max(i[0], i[0], o[r]), i[1] = Math.max(i[1], i[1], o[r + 1]); break; case "Q": for (var r = 0; 4 > r; r += 2) e[0] = Math.min(e[0], e[0], o[r]), e[1] = Math.min(e[1], e[1], o[r + 1]), i[0] = Math.max(i[0], i[0], o[r]), i[1] = Math.max(i[1], i[1], o[r + 1]); break; case "A": var s = o[0], l = o[1], h = o[2], d = o[3]; e[0] = Math.min(e[0], e[0], s - h), e[1] = Math.min(e[1], e[1], l - d), i[0] = Math.max(i[0], i[0], s + h), i[1] = Math.max(i[1], i[1], l + d) } } return { x: e[0], y: e[1], width: i[0] - e[0], height: i[1] - e[1] } }, n.prototype.begin = function(e) { return this._ctx = e || null, this.pathCommands.length = 0, this }, n.prototype.moveTo = function(e, t) { return this.pathCommands.push(new i("M", [e, t])), this._ctx && this._ctx.moveTo(e, t), this }, n.prototype.lineTo = function(e, t) { return this.pathCommands.push(new i("L", [e, t])), this._ctx && this._ctx.lineTo(e, t), this }, n.prototype.bezierCurveTo = function(e, t, n, a, o, r) { return this.pathCommands.push(new i("C", [e, t, n, a, o, r])), this._ctx && this._ctx.bezierCurveTo(e, t, n, a, o, r), this }, n.prototype.quadraticCurveTo = function(e, t, n, a) { return this.pathCommands.push(new i("Q", [e, t, n, a])), this._ctx && this._ctx.quadraticCurveTo(e, t, n, a), this }, n.prototype.arc = function(e, t, n, a, o, r) { return this.pathCommands.push(new i("A", [e, t, n, n, a, o - a, 0, r ? 0 : 1])), this._ctx && this._ctx.arc(e, t, n, a, o, r), this }, n.prototype.arcTo = function(e, t, i, n, a) { return this._ctx && this._ctx.arcTo(e, t, i, n, a), this }, n.prototype.rect = function(e, t, i, n) { return this._ctx && this._ctx.rect(e, t, i, n), this }, n.prototype.closePath = function() { return this.pathCommands.push(new i("z")), this._ctx && this._ctx.closePath(), this }, n.prototype.isEmpty = function() { return 0 === this.pathCommands.length }, n.PathSegment = i, n }), define("zrender/shape/Line", ["require", "./Base", "./util/dashedLineTo", "../tool/util"], function(e) { var t = e("./Base"), i = e("./util/dashedLineTo"), n = function(e) { this.brushTypeOnly = "stroke", this.textPosition = "end", t.call(this, e) }; return n.prototype = { type: "line", buildPath: function(e, t) { if (t.lineType && "solid" != t.lineType) { if ("dashed" == t.lineType || "dotted" == t.lineType) { var n = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1); i(e, t.xStart, t.yStart, t.xEnd, t.yEnd, n) } } else e.moveTo(t.xStart, t.yStart), e.lineTo(t.xEnd, t.yEnd) }, getRect: function(e) { if (e.__rect) return e.__rect; var t = e.lineWidth || 1; return e.__rect = { x: Math.min(e.xStart, e.xEnd) - t, y: Math.min(e.yStart, e.yEnd) - t, width: Math.abs(e.xStart - e.xEnd) + t, height: Math.abs(e.yStart - e.yEnd) + t }, e.__rect } }, e("../tool/util").inherits(n, t), n }), define("zrender/shape/BezierCurve", ["require", "./Base", "../tool/util"], function(e) { "use strict"; var t = e("./Base"), i = function(e) { this.brushTypeOnly = "stroke", this.textPosition = "end", t.call(this, e) }; return i.prototype = { type: "bezier-curve", buildPath: function(e, t) { e.moveTo(t.xStart, t.yStart), "undefined" != typeof t.cpX2 && "undefined" != typeof t.cpY2 ? e.bezierCurveTo(t.cpX1, t.cpY1, t.cpX2, t.cpY2, t.xEnd, t.yEnd) : e.quadraticCurveTo(t.cpX1, t.cpY1, t.xEnd, t.yEnd) }, getRect: function(e) { if (e.__rect) return e.__rect; var t = Math.min(e.xStart, e.xEnd, e.cpX1), i = Math.min(e.yStart, e.yEnd, e.cpY1), n = Math.max(e.xStart, e.xEnd, e.cpX1), a = Math.max(e.yStart, e.yEnd, e.cpY1), o = e.cpX2, r = e.cpY2; "undefined" != typeof o && "undefined" != typeof r && (t = Math.min(t, o), i = Math.min(i, r), n = Math.max(n, o), a = Math.max(a, r)); var s = e.lineWidth || 1; return e.__rect = { x: t - s, y: i - s, width: n - t + s, height: a - i + s }, e.__rect } }, e("../tool/util").inherits(i, t), i }), define("zrender/shape/util/dashedLineTo", [], function() { var e = [5, 5]; return function(t, i, n, a, o, r) { if (t.setLineDash) return e[0] = e[1] = r, t.setLineDash(e), t.moveTo(i, n), void t.lineTo(a, o); r = "number" != typeof r ? 5 : r; var s = a - i, l = o - n, h = Math.floor(Math.sqrt(s * s + l * l) / r); s /= h, l /= h; for (var d = !0, c = 0; h > c; ++c) d ? t.moveTo(i, n) : t.lineTo(i, n), d = !d, i += s, n += l; t.lineTo(a, o) } }), define("zrender/shape/Polygon", ["require", "./Base", "./util/smoothSpline", "./util/smoothBezier", "./util/dashedLineTo", "../tool/util"], function(e) { var t = e("./Base"), i = e("./util/smoothSpline"), n = e("./util/smoothBezier"), a = e("./util/dashedLineTo"), o = function(e) { t.call(this, e) }; return o.prototype = { type: "polygon", buildPath: function(e, t) { var o = t.pointList; if (!(o.length < 2)) { if (t.smooth && "spline" !== t.smooth) { var r = n(o, t.smooth, !0, t.smoothConstraint); e.moveTo(o[0][0], o[0][1]); for (var s, l, h, d = o.length, c = 0; d > c; c++) s = r[2 * c], l = r[2 * c + 1], h = o[(c + 1) % d], e.bezierCurveTo(s[0], s[1], l[0], l[1], h[0], h[1]) } else if ("spline" === t.smooth && (o = i(o, !0)), t.lineType && "solid" != t.lineType) { if ("dashed" == t.lineType || "dotted" == t.lineType) { var m = t._dashLength || (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1); t._dashLength = m, e.moveTo(o[0][0], o[0][1]); for (var c = 1, p = o.length; p > c; c++) a(e, o[c - 1][0], o[c - 1][1], o[c][0], o[c][1], m); a(e, o[o.length - 1][0], o[o.length - 1][1], o[0][0], o[0][1], m) } } else { e.moveTo(o[0][0], o[0][1]); for (var c = 1, p = o.length; p > c; c++) e.lineTo(o[c][0], o[c][1]); e.lineTo(o[0][0], o[0][1]) } e.closePath() } }, getRect: function(e) { if (e.__rect) return e.__rect; for (var t = Number.MAX_VALUE, i = Number.MIN_VALUE, n = Number.MAX_VALUE, a = Number.MIN_VALUE, o = e.pointList, r = 0, s = o.length; s > r; r++) o[r][0] < t && (t = o[r][0]), o[r][0] > i && (i = o[r][0]), o[r][1] < n && (n = o[r][1]), o[r][1] > a && (a = o[r][1]); var l; return l = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = { x: Math.round(t - l / 2), y: Math.round(n - l / 2), width: i - t + l, height: a - n + l }, e.__rect } }, e("../tool/util").inherits(o, t), o }), define("echarts/util/shape/normalIsCover", [], function() { return function(e, t) { var i = this.transformCoordToLocal(e, t); return e = i[0], t = i[1], this.isCoverRect(e, t) } }), define("zrender/shape/util/smoothSpline", ["require", "../../tool/vector"], function(e) { function t(e, t, i, n, a, o, r) { var s = .5 * (i - e), l = .5 * (n - t); return (2 * (t - i) + s + l) * r + (-3 * (t - i) - 2 * s - l) * o + s * a + t } var i = e("../../tool/vector"); return function(e, n) { for (var a = e.length, o = [], r = 0, s = 1; a > s; s++) r += i.distance(e[s - 1], e[s]); var l = r / 5; l = a > l ? a : l; for (var s = 0; l > s; s++) { var h, d, c, m = s / (l - 1) * (n ? a : a - 1), p = Math.floor(m), u = m - p, V = e[p % a]; n ? (h = e[(p - 1 + a) % a], d = e[(p + 1) % a], c = e[(p + 2) % a]) : (h = e[0 === p ? p : p - 1], d = e[p > a - 2 ? a - 1 : p + 1], c = e[p > a - 3 ? a - 1 : p + 2]); var U = u * u, g = u * U; o.push([t(h[0], V[0], d[0], c[0], u, U, g), t(h[1], V[1], d[1], c[1], u, U, g)]) } return o } }), define("zrender/shape/util/smoothBezier", ["require", "../../tool/vector"], function(e) { var t = e("../../tool/vector"); return function(e, i, n, a) { var o, r, s, l, h = [], d = [], c = [], m = [], p = !!a; if (p) { s = [1 / 0, 1 / 0], l = [-(1 / 0), -(1 / 0)]; for (var u = 0, V = e.length; V > u; u++) t.min(s, s, e[u]), t.max(l, l, e[u]); t.min(s, s, a[0]), t.max(l, l, a[1]) } for (var u = 0, V = e.length; V > u; u++) { var o, r, U = e[u]; if (n) o = e[u ? u - 1 : V - 1], r = e[(u + 1) % V]; else { if (0 === u || u === V - 1) { h.push(t.clone(e[u])); continue } o = e[u - 1], r = e[u + 1] } t.sub(d, r, o), t.scale(d, d, i); var g = t.distance(U, o), f = t.distance(U, r), y = g + f; 0 !== y && (g /= y, f /= y), t.scale(c, d, -g), t.scale(m, d, f); var b = t.add([], U, c), _ = t.add([], U, m); p && (t.max(b, b, s), t.min(b, b, l), t.max(_, _, s), t.min(_, _, l)), h.push(b), h.push(_) } return n && h.push(t.clone(h.shift())), h } }), define("echarts/util/ecQuery", ["require", "zrender/tool/util"], function(e) { function t(e, t) { if ("undefined" != typeof e) { if (!t) return e; t = t.split("."); for (var i = t.length, n = 0; i > n;) { if (e = e[t[n]], "undefined" == typeof e) return; n++ } return e } } function i(e, i) { for (var n, a = 0, o = e.length; o > a; a++) if (n = t(e[a], i), "undefined" != typeof n) return n } function n(e, i) { for (var n, o = e.length; o--;) { var r = t(e[o], i); "undefined" != typeof r && ("undefined" == typeof n ? n = a.clone(r) : a.merge(n, r, !0)) } return n } var a = e("zrender/tool/util"); return { query: t, deepQuery: i, deepMerge: n } }), define("echarts/util/number", [], function() { function e(e) { return e.replace(/^\s+/, "").replace(/\s+$/, "") } function t(t, i) { return "string" == typeof t ? e(t).match(/%$/) ? parseFloat(t) / 100 * i : parseFloat(t) : t } function i(e, i) { return [t(i[0], e.getWidth()), t(i[1], e.getHeight())] } function n(e, i) { i instanceof Array || (i = [0, i]); var n = Math.min(e.getWidth(), e.getHeight()) / 2; return [t(i[0], n), t(i[1], n)] } function a(e) { return isNaN(e) ? "-" : (e = (e + "").split("."), e[0].replace(/(\d{1,3})(?=(?:\d{3})+(?!\d))/g, "$1,") + (e.length > 1 ? "." + e[1] : "")) } function o(e) { for (var t = 1, i = 0; Math.round(e * t) / t !== e;) t *= 10, i++; return i } return { parsePercent: t, parseCenter: i, parseRadius: n, addCommas: a, getPrecision: o } }), define("echarts/data/KDTree", ["require", "./quickSelect"], function(e) { function t(e, t) { this.left = null, this.right = null, this.axis = e, this.data = t } var i = e("./quickSelect"), n = function(e, t) { e.length && (t || (t = e[0].array.length), this.dimension = t, this.root = this._buildTree(e, 0, e.length - 1, 0), this._stack = [], this._nearstNList = []) }; return n.prototype._buildTree = function(e, n, a, o) { if (n > a) return null; var r = Math.floor((n + a) / 2); r = i(e, n, a, r, function(e, t) { return e.array[o] - t.array[o] }); var s = e[r], l = new t(o, s); return o = (o + 1) % this.dimension, a > n && (l.left = this._buildTree(e, n, r - 1, o), l.right = this._buildTree(e, r + 1, a, o)), l }, n.prototype.nearest = function(e, t) { var i = this.root, n = this._stack, a = 0, o = 1 / 0, r = null; for (i.data !== e && (o = t(i.data, e), r = i), e.array[i.axis] < i.data.array[i.axis] ? (i.right && (n[a++] = i.right), i.left && (n[a++] = i.left)) : (i.left && (n[a++] = i.left), i.right && (n[a++] = i.right)); a--;) { i = n[a]; var s = e.array[i.axis] - i.data.array[i.axis], l = 0 > s, h = !1; s *= s, o > s && (s = t(i.data, e), o > s && i.data !== e && (o = s, r = i), h = !0), l ? (h && i.right && (n[a++] = i.right), i.left && (n[a++] = i.left)) : (h && i.left && (n[a++] = i.left), i.right && (n[a++] = i.right)) } return r.data }, n.prototype._addNearest = function(e, t, i) { for (var n = this._nearstNList, a = e - 1; a > 0 && !(t >= n[a - 1].dist); a--) n[a].dist = n[a - 1].dist, n[a].node = n[a - 1].node; n[a].dist = t, n[a].node = i }, n.prototype.nearestN = function(e, t, i, n) { if (0 >= t) return n.length = 0, n; for (var a = this.root, o = this._stack, r = 0, s = this._nearstNList, l = 0; t > l; l++) s[l] || (s[l] = {}), s[l].dist = 0, s[l].node = null; var h = i(a.data, e), d = 0; for (a.data !== e && (d++, this._addNearest(d, h, a)), e.array[a.axis] < a.data.array[a.axis] ? (a.right && (o[r++] = a.right), a.left && (o[r++] = a.left)) : (a.left && (o[r++] = a.left), a.right && (o[r++] = a.right)); r--;) { a = o[r]; var h = e.array[a.axis] - a.data.array[a.axis], c = 0 > h, m = !1; h *= h, (t > d || h < s[d - 1].dist) && (h = i(a.data, e), (t > d || h < s[d - 1].dist) && a.data !== e && (t > d && d++, this._addNearest(d, h, a)), m = !0), c ? (m && a.right && (o[r++] = a.right), a.left && (o[r++] = a.left)) : (m && a.left && (o[r++] = a.left), a.right && (o[r++] = a.right)) } for (var l = 0; d > l; l++) n[l] = s[l].node.data; return n.length = d, n }, n }), define("echarts/data/quickSelect", ["require"], function() { function e(e, t) { return e - t } function t(e, t, i) { var n = e[t]; e[t] = e[i], e[i] = n } function i(e, i, n, a, o) { for (var r = i; n > i;) { var r = Math.round((n + i) / 2), s = e[r]; t(e, r, n), r = i; for (var l = i; n - 1 >= l; l++) o(s, e[l]) >= 0 && (t(e, l, r), r++); if (t(e, n, r), r === a) return r; a > r ? i = r + 1 : n = r - 1 } return i } function n(t, n, a, o, r) { return arguments.length <= 3 && (o = n, r = 2 == arguments.length ? e : a, n = 0, a = t.length - 1), i(t, n, a, o, r) } return n }), define("echarts/component/dataView", ["require", "./base", "../config", "zrender/tool/util", "../component"], function(e) { function t(e, t, n, a, o) { i.call(this, e, t, n, a, o), this.dom = o.dom, this._tDom = document.createElement("div"), this._textArea = document.createElement("textArea"), this._buttonRefresh = document.createElement("button"), this._buttonRefresh.setAttribute("type", "button"), this._buttonClose = document.createElement("button"), this._buttonClose.setAttribute("type", "button"), this._hasShow = !1, this._zrHeight = n.getHeight(), this._zrWidth = n.getWidth(), this._tDom.className = "echarts-dataview", this.hide(), this.dom.firstChild.appendChild(this._tDom), window.addEventListener ? (this._tDom.addEventListener("click", this._stop), this._tDom.addEventListener("mousewheel", this._stop), this._tDom.addEventListener("mousemove", this._stop), this._tDom.addEventListener("mousedown", this._stop), this._tDom.addEventListener("mouseup", this._stop), this._tDom.addEventListener("touchstart", this._stop), this._tDom.addEventListener("touchmove", this._stop), this._tDom.addEventListener("touchend", this._stop)) : (this._tDom.attachEvent("onclick", this._stop), this._tDom.attachEvent("onmousewheel", this._stop), this._tDom.attachEvent("onmousemove", this._stop), this._tDom.attachEvent("onmousedown", this._stop), this._tDom.attachEvent("onmouseup", this._stop)) } var i = e("./base"), n = e("../config"), a = e("zrender/tool/util"); return t.prototype = { type: n.COMPONENT_TYPE_DATAVIEW, _lang: ["Data View", "close", "refresh"], _gCssText: "position:absolute;display:block;overflow:hidden;transition:height 0.8s,background-color 1s;-moz-transition:height 0.8s,background-color 1s;-webkit-transition:height 0.8s,background-color 1s;-o-transition:height 0.8s,background-color 1s;z-index:1;left:0;top:0;", hide: function() { this._sizeCssText = "width:" + this._zrWidth + "px;height:0px;background-color:#f0ffff;", this._tDom.style.cssText = this._gCssText + this._sizeCssText }, show: function(e) { this._hasShow = !0; var t = this.query(this.option, "toolbox.feature.dataView.lang") || this._lang; this.option = e, this._tDom.innerHTML = '<p style="padding:8px 0;margin:0 0 10px 0;border-bottom:1px solid #eee">' + (t[0] || this._lang[0]) + "</p>"; var i = this.query(this.option, "toolbox.feature.dataView.optionToContent"); "function" != typeof i ? this._textArea.value = this._optionToContent() : (this._textArea = document.createElement("div"), this._textArea.innerHTML = i(this.option)), this._textArea.style.cssText = "display:block;margin:0 0 8px 0;padding:4px 6px;overflow:auto;width:100%;height:" + (this._zrHeight - 100) + "px;", this._tDom.appendChild(this._textArea), this._buttonClose.style.cssText = "float:right;padding:1px 6px;", this._buttonClose.innerHTML = t[1] || this._lang[1]; var n = this; this._buttonClose.onclick = function() { n.hide() }, this._tDom.appendChild(this._buttonClose), this.query(this.option, "toolbox.feature.dataView.readOnly") === !1 ? (this._buttonRefresh.style.cssText = "float:right;margin-right:10px;padding:1px 6px;", this._buttonRefresh.innerHTML = t[2] || this._lang[2], this._buttonRefresh.onclick = function() { n._save() }, this._textArea.readOnly = !1, this._textArea.style.cursor = "default") : (this._buttonRefresh.style.cssText = "display:none", this._textArea.readOnly = !0, this._textArea.style.cursor = "text"), this._tDom.appendChild(this._buttonRefresh), this._sizeCssText = "width:" + this._zrWidth + "px;height:" + this._zrHeight + "px;background-color:#fff;", this._tDom.style.cssText = this._gCssText + this._sizeCssText }, _optionToContent: function() { var e, t, i, a, o, r, s = [], l = ""; if (this.option.xAxis) for (s = this.option.xAxis instanceof Array ? this.option.xAxis : [this.option.xAxis], e = 0, a = s.length; a > e; e++) if ("category" == (s[e].type || "category")) { for (r = [], t = 0, i = s[e].data.length; i > t; t++) r.push(this.getDataFromOption(s[e].data[t])); l += r.join(", ") + "\n\n" } if (this.option.yAxis) for (s = this.option.yAxis instanceof Array ? this.option.yAxis : [this.option.yAxis], e = 0, a = s.length; a > e; e++) if ("category" == s[e].type) { for (r = [], t = 0, i = s[e].data.length; i > t; t++) r.push(this.getDataFromOption(s[e].data[t])); l += r.join(", ") + "\n\n" } var h, d = this.option.series; for (e = 0, a = d.length; a > e; e++) { for (r = [], t = 0, i = d[e].data.length; i > t; t++) o = d[e].data[t], h = d[e].type == n.CHART_TYPE_PIE || d[e].type == n.CHART_TYPE_MAP ? (o.name || "-") + ":" : "", d[e].type == n.CHART_TYPE_SCATTER && (o = this.getDataFromOption(o).join(", ")), r.push(h + this.getDataFromOption(o)); l += (d[e].name || "-") + " : \n", l += r.join(d[e].type == n.CHART_TYPE_SCATTER ? "\n" : ", "), l += "\n\n" } return l }, _save: function() { var e = this.query(this.option, "toolbox.feature.dataView.contentToOption"); if ("function" != typeof e) { for (var t = this._textArea.value.split("\n"), i = [], a = 0, o = t.length; o > a; a++) t[a] = this._trim(t[a]), "" !== t[a] && i.push(t[a]); this._contentToOption(i) } else e(this._textArea, this.option); this.hide(); var r = this; setTimeout(function() { r.messageCenter && r.messageCenter.dispatch(n.EVENT.DATA_VIEW_CHANGED, null, { option: r.option }, r.myChart) }, r.canvasSupported ? 800 : 100) }, _contentToOption: function(e) { var t, i, a, o, r, s, l, h = [], d = 0; if (this.option.xAxis) for (h = this.option.xAxis instanceof Array ? this.option.xAxis : [this.option.xAxis], t = 0, o = h.length; o > t; t++) if ("category" == (h[t].type || "category")) { for (s = e[d].split(","), i = 0, a = h[t].data.length; a > i; i++) l = this._trim(s[i] || ""), r = h[t].data[i], "undefined" != typeof h[t].data[i].value ? h[t].data[i].value = l : h[t].data[i] = l; d++ } if (this.option.yAxis) for (h = this.option.yAxis instanceof Array ? this.option.yAxis : [this.option.yAxis], t = 0, o = h.length; o > t; t++) if ("category" == h[t].type) { for (s = e[d].split(","), i = 0, a = h[t].data.length; a > i; i++) l = this._trim(s[i] || ""), r = h[t].data[i], "undefined" != typeof h[t].data[i].value ? h[t].data[i].value = l : h[t].data[i] = l; d++ } var c = this.option.series; for (t = 0, o = c.length; o > t; t++) if (d++, c[t].type == n.CHART_TYPE_SCATTER) for (var i = 0, a = c[t].data.length; a > i; i++) s = e[d], l = s.replace(" ", "").split(","), "undefined" != typeof c[t].data[i].value ? c[t].data[i].value = l : c[t].data[i] = l, d++; else { s = e[d].split(","); for (var i = 0, a = c[t].data.length; a > i; i++) l = (s[i] || "").replace(/.*:/, ""), l = this._trim(l), l = "-" != l && "" !== l ? l - 0 : "-", "undefined" != typeof c[t].data[i].value ? c[t].data[i].value = l : c[t].data[i] = l; d++ } }, _trim: function(e) { var t = new RegExp("(^[\\s\\t\\xa0\\u3000]+)|([\\u3000\\xa0\\s\\t]+$)", "g"); return e.replace(t, "") }, _stop: function(e) { e = e || window.event, e.stopPropagation ? e.stopPropagation() : e.cancelBubble = !0 }, resize: function() { this._zrHeight = this.zr.getHeight(), this._zrWidth = this.zr.getWidth(), this._tDom.offsetHeight > 10 && (this._sizeCssText = "width:" + this._zrWidth + "px;height:" + this._zrHeight + "px;background-color:#fff;", this._tDom.style.cssText = this._gCssText + this._sizeCssText, this._textArea.style.cssText = "display:block;margin:0 0 8px 0;padding:4px 6px;overflow:auto;width:100%;height:" + (this._zrHeight - 100) + "px;") }, dispose: function() { window.removeEventListener ? (this._tDom.removeEventListener("click", this._stop), this._tDom.removeEventListener("mousewheel", this._stop), this._tDom.removeEventListener("mousemove", this._stop), this._tDom.removeEventListener("mousedown", this._stop), this._tDom.removeEventListener("mouseup", this._stop), this._tDom.removeEventListener("touchstart", this._stop), this._tDom.removeEventListener("touchmove", this._stop), this._tDom.removeEventListener("touchend", this._stop)) : (this._tDom.detachEvent("onclick", this._stop), this._tDom.detachEvent("onmousewheel", this._stop), this._tDom.detachEvent("onmousemove", this._stop), this._tDom.detachEvent("onmousedown", this._stop), this._tDom.detachEvent("onmouseup", this._stop)), this._buttonRefresh.onclick = null, this._buttonClose.onclick = null, this._hasShow && (this._tDom.removeChild(this._textArea), this._tDom.removeChild(this._buttonRefresh), this._tDom.removeChild(this._buttonClose)), this._textArea = null, this._buttonRefresh = null, this._buttonClose = null, this.dom.firstChild.removeChild(this._tDom), this._tDom = null } }, a.inherits(t, i), e("../component").define("dataView", t), t }), define("echarts/util/shape/Cross", ["require", "zrender/shape/Base", "zrender/shape/Line", "zrender/tool/util", "./normalIsCover"], function(e) { function t(e) { i.call(this, e) } var i = e("zrender/shape/Base"), n = e("zrender/shape/Line"), a = e("zrender/tool/util"); return t.prototype = { type: "cross", buildPath: function(e, t) { var i = t.rect; t.xStart = i.x, t.xEnd = i.x + i.width, t.yStart = t.yEnd = t.y, n.prototype.buildPath(e, t), t.xStart = t.xEnd = t.x, t.yStart = i.y, t.yEnd = i.y + i.height, n.prototype.buildPath(e, t) }, getRect: function(e) { return e.rect }, isCover: e("./normalIsCover") }, a.inherits(t, i), t }), define("zrender/shape/Sector", ["require", "../tool/math", "../tool/computeBoundingBox", "../tool/vector", "./Base", "../tool/util"], function(e) { var t = e("../tool/math"), i = e("../tool/computeBoundingBox"), n = e("../tool/vector"), a = e("./Base"), o = n.create(), r = n.create(), s = n.create(), l = n.create(), h = function(e) { a.call(this, e) }; return h.prototype = { type: "sector", buildPath: function(e, i) { var n = i.x, a = i.y, o = i.r0 || 0, r = i.r, s = i.startAngle, l = i.endAngle, h = i.clockWise || !1; s = t.degreeToRadian(s), l = t.degreeToRadian(l), h || (s = -s, l = -l); var d = t.cos(s), c = t.sin(s); e.moveTo(d * o + n, c * o + a), e.lineTo(d * r + n, c * r + a), e.arc(n, a, r, s, l, !h), e.lineTo(t.cos(l) * o + n, t.sin(l) * o + a), 0 !== o && e.arc(n, a, o, l, s, h), e.closePath() }, getRect: function(e) { if (e.__rect) return e.__rect; var a = e.x, h = e.y, d = e.r0 || 0, c = e.r, m = t.degreeToRadian(e.startAngle), p = t.degreeToRadian(e.endAngle), u = e.clockWise; return u || (m = -m, p = -p), d > 1 ? i.arc(a, h, d, m, p, !u, o, s) : (o[0] = s[0] = a, o[1] = s[1] = h), i.arc(a, h, c, m, p, !u, r, l), n.min(o, o, r), n.max(s, s, l), e.__rect = { x: o[0], y: o[1], width: s[0] - o[0], height: s[1] - o[1] }, e.__rect } }, e("../tool/util").inherits(h, a), h }), define("echarts/util/shape/Candle", ["require", "zrender/shape/Base", "zrender/tool/util", "./normalIsCover"], function(e) { function t(e) { i.call(this, e) } var i = e("zrender/shape/Base"), n = e("zrender/tool/util"); return t.prototype = { type: "candle", _numberOrder: function(e, t) { return t - e }, buildPath: function(e, t) { var i = n.clone(t.y).sort(this._numberOrder); e.moveTo(t.x, i[3]), e.lineTo(t.x, i[2]), e.moveTo(t.x - t.width / 2, i[2]), e.rect(t.x - t.width / 2, i[2], t.width, i[1] - i[2]), e.moveTo(t.x, i[1]), e.lineTo(t.x, i[0]) }, getRect: function(e) { if (!e.__rect) { var t = 0; ("stroke" == e.brushType || "fill" == e.brushType) && (t = e.lineWidth || 1); var i = n.clone(e.y).sort(this._numberOrder); e.__rect = { x: Math.round(e.x - e.width / 2 - t / 2), y: Math.round(i[3] - t / 2), width: e.width + t, height: i[0] - i[3] + t } } return e.__rect }, isCover: e("./normalIsCover") }, n.inherits(t, i), t }), define("zrender/tool/computeBoundingBox", ["require", "./vector", "./curve"], function(e) { function t(e, t, i) { if (0 !== e.length) { for (var n = e[0][0], a = e[0][0], o = e[0][1], r = e[0][1], s = 1; s < e.length; s++) { var l = e[s]; l[0] < n && (n = l[0]), l[0] > a && (a = l[0]), l[1] < o && (o = l[1]), l[1] > r && (r = l[1]) } t[0] = n, t[1] = o, i[0] = a, i[1] = r } } function i(e, t, i, n, a, r) { var s = []; o.cubicExtrema(e[0], t[0], i[0], n[0], s); for (var l = 0; l < s.length; l++) s[l] = o.cubicAt(e[0], t[0], i[0], n[0], s[l]); var h = []; o.cubicExtrema(e[1], t[1], i[1], n[1], h); for (var l = 0; l < h.length; l++) h[l] = o.cubicAt(e[1], t[1], i[1], n[1], h[l]); s.push(e[0], n[0]), h.push(e[1], n[1]); var d = Math.min.apply(null, s), c = Math.max.apply(null, s), m = Math.min.apply(null, h), p = Math.max.apply(null, h); a[0] = d, a[1] = m, r[0] = c, r[1] = p } function n(e, t, i, n, a) { var r = o.quadraticExtremum(e[0], t[0], i[0]), s = o.quadraticExtremum(e[1], t[1], i[1]); r = Math.max(Math.min(r, 1), 0), s = Math.max(Math.min(s, 1), 0); var l = 1 - r, h = 1 - s, d = l * l * e[0] + 2 * l * r * t[0] + r * r * i[0], c = l * l * e[1] + 2 * l * r * t[1] + r * r * i[1], m = h * h * e[0] + 2 * h * s * t[0] + s * s * i[0], p = h * h * e[1] + 2 * h * s * t[1] + s * s * i[1]; n[0] = Math.min(e[0], i[0], d, m), n[1] = Math.min(e[1], i[1], c, p), a[0] = Math.max(e[0], i[0], d, m), a[1] = Math.max(e[1], i[1], c, p) } var a = e("./vector"), o = e("./curve"), r = a.create(), s = a.create(), l = a.create(), h = function(e, t, i, n, o, h, d, c) { if (Math.abs(n - o) >= 2 * Math.PI) return d[0] = e - i, d[1] = t - i, c[0] = e + i, void(c[1] = t + i); if (r[0] = Math.cos(n) * i + e, r[1] = Math.sin(n) * i + t, s[0] = Math.cos(o) * i + e, s[1] = Math.sin(o) * i + t, a.min(d, r, s), a.max(c, r, s), n %= 2 * Math.PI, 0 > n && (n += 2 * Math.PI), o %= 2 * Math.PI, 0 > o && (o += 2 * Math.PI), n > o && !h ? o += 2 * Math.PI : o > n && h && (n += 2 * Math.PI), h) { var m = o; o = n, n = m } for (var p = 0; o > p; p += Math.PI / 2) p > n && (l[0] = Math.cos(p) * i + e, l[1] = Math.sin(p) * i + t, a.min(d, l, d), a.max(c, l, c)) }; return t.cubeBezier = i, t.quadraticBezier = n, t.arc = h, t }), define("echarts/util/shape/Chain", ["require", "zrender/shape/Base", "./Icon", "zrender/shape/util/dashedLineTo", "zrender/tool/util", "zrender/tool/matrix"], function(e) { function t(e) { i.call(this, e) } var i = e("zrender/shape/Base"), n = e("./Icon"), a = e("zrender/shape/util/dashedLineTo"), o = e("zrender/tool/util"), r = e("zrender/tool/matrix"); return t.prototype = { type: "chain", brush: function(e, t) { var i = this.style; t && (i = this.getHighlightStyle(i, this.highlightStyle || {})), e.save(), this.setContext(e, i), this.setTransform(e), e.save(), e.beginPath(), this.buildLinePath(e, i), e.stroke(), e.restore(), this.brushSymbol(e, i), e.restore() }, buildLinePath: function(e, t) { var i = t.x, n = t.y + 5, o = t.width, r = t.height / 2 - 10; if (e.moveTo(i, n), e.lineTo(i, n + r), e.moveTo(i + o, n), e.lineTo(i + o, n + r), e.moveTo(i, n + r / 2), t.lineType && "solid" != t.lineType) { if ("dashed" == t.lineType || "dotted" == t.lineType) { var s = (t.lineWidth || 1) * ("dashed" == t.lineType ? 5 : 1); a(e, i, n + r / 2, i + o, n + r / 2, s) } } else e.lineTo(i + o, n + r / 2) }, brushSymbol: function(e, t) { var i = t.y + t.height / 4; e.save(); for (var a, o = t.chainPoint, r = 0, s = o.length; s > r; r++) { if (a = o[r], "none" != a.symbol) { e.beginPath(); var l = a.symbolSize; n.prototype.buildPath(e, { iconType: a.symbol, x: a.x - l, y: i - l, width: 2 * l, height: 2 * l, n: a.n }), e.fillStyle = a.isEmpty ? "#fff" : t.strokeColor, e.closePath(), e.fill(), e.stroke() } a.showLabel && (e.font = a.textFont, e.fillStyle = a.textColor, e.textAlign = a.textAlign, e.textBaseline = a.textBaseline, a.rotation ? (e.save(), this._updateTextTransform(e, a.rotation), e.fillText(a.name, a.textX, a.textY), e.restore()) : e.fillText(a.name, a.textX, a.textY)) } e.restore() }, _updateTextTransform: function(e, t) { var i = r.create(); if (r.identity(i), 0 !== t[0]) { var n = t[1] || 0, a = t[2] || 0; (n || a) && r.translate(i, i, [-n, -a]), r.rotate(i, i, t[0]), (n || a) && r.translate(i, i, [n, a]) } e.transform.apply(e, i) }, isCover: function(e, t) { var i = this.style; return e >= i.x && e <= i.x + i.width && t >= i.y && t <= i.y + i.height ? !0 : !1 } }, o.inherits(t, i), t }), define("zrender/shape/Ring", ["require", "./Base", "../tool/util"], function(e) { var t = e("./Base"), i = function(e) { t.call(this, e) }; return i.prototype = { type: "ring", buildPath: function(e, t) { e.arc(t.x, t.y, t.r, 0, 2 * Math.PI, !1), e.moveTo(t.x + t.r0, t.y), e.arc(t.x, t.y, t.r0, 0, 2 * Math.PI, !0) }, getRect: function(e) { if (e.__rect) return e.__rect; var t; return t = "stroke" == e.brushType || "fill" == e.brushType ? e.lineWidth || 1 : 0, e.__rect = { x: Math.round(e.x - e.r - t / 2), y: Math.round(e.y - e.r - t / 2), width: 2 * e.r + t, height: 2 * e.r + t }, e.__rect } }, e("../tool/util").inherits(i, t), i }), define("echarts/component/axis", ["require", "./base", "zrender/shape/Line", "../config", "../util/ecData", "zrender/tool/util", "zrender/tool/color", "./categoryAxis", "./valueAxis", "../component"], function(e) { function t(e, t, n, a, o, r) { i.call(this, e, t, n, a, o), this.axisType = r, this._axisList = [], this.refresh(a) } var i = e("./base"), n = e("zrender/shape/Line"), a = e("../config"), o = e("../util/ecData"), r = e("zrender/tool/util"), s = e("zrender/tool/color"); return t.prototype = { type: a.COMPONENT_TYPE_AXIS, axisBase: { _buildAxisLine: function() { var e = this.option.axisLine.lineStyle.width, t = e / 2, i = { _axisShape: "axisLine", zlevel: this.getZlevelBase(), z: this.getZBase() + 3, hoverable: !1 }, a = this.grid; switch (this.option.position) { case "left": i.style = { xStart: a.getX() - t, yStart: a.getYend(), xEnd: a.getX() - t, yEnd: a.getY(), lineCap: "round" }; break; case "right": i.style = { xStart: a.getXend() + t, yStart: a.getYend(), xEnd: a.getXend() + t, yEnd: a.getY(), lineCap: "round" }; break; case "bottom": i.style = { xStart: a.getX(), yStart: a.getYend() + t, xEnd: a.getXend(), yEnd: a.getYend() + t, lineCap: "round" }; break; case "top": i.style = { xStart: a.getX(), yStart: a.getY() - t, xEnd: a.getXend(), yEnd: a.getY() - t, lineCap: "round" } } var o = i.style; "" !== this.option.name && (o.text = this.option.name, o.textPosition = this.option.nameLocation, o.textFont = this.getFont(this.option.nameTextStyle), this.option.nameTextStyle.align && (o.textAlign = this.option.nameTextStyle.align), this.option.nameTextStyle.baseline && (o.textBaseline = this.option.nameTextStyle.baseline), this.option.nameTextStyle.color && (o.textColor = this.option.nameTextStyle.color)), o.strokeColor = this.option.axisLine.lineStyle.color, o.lineWidth = e, this.isHorizontal() ? o.yStart = o.yEnd = this.subPixelOptimize(o.yEnd, e) : o.xStart = o.xEnd = this.subPixelOptimize(o.xEnd, e), o.lineType = this.option.axisLine.lineStyle.type, i = new n(i), this.shapeList.push(i) }, _axisLabelClickable: function(e, t) { return e ? (o.pack(t, void 0, -1, void 0, -1, t.style.text), t.hoverable = !0, t.clickable = !0, t.highlightStyle = { color: s.lift(t.style.color, 1), brushType: "fill" }, t) : t }, refixAxisShape: function(e, t) { if (this.option.axisLine.onZero) { var i; if (this.isHorizontal() && null != t) for (var n = 0, a = this.shapeList.length; a > n; n++) "axisLine" === this.shapeList[n]._axisShape ? (this.shapeList[n].style.yStart = this.shapeList[n].style.yEnd = this.subPixelOptimize(t, this.shapeList[n].stylelineWidth), this.zr.modShape(this.shapeList[n].id)) : "axisTick" === this.shapeList[n]._axisShape && (i = this.shapeList[n].style.yEnd - this.shapeList[n].style.yStart, this.shapeList[n].style.yStart = t - i, this.shapeList[n].style.yEnd = t, this.zr.modShape(this.shapeList[n].id)); if (!this.isHorizontal() && null != e) for (var n = 0, a = this.shapeList.length; a > n; n++) "axisLine" === this.shapeList[n]._axisShape ? (this.shapeList[n].style.xStart = this.shapeList[n].style.xEnd = this.subPixelOptimize(e, this.shapeList[n].stylelineWidth), this.zr.modShape(this.shapeList[n].id)) : "axisTick" === this.shapeList[n]._axisShape && (i = this.shapeList[n].style.xEnd - this.shapeList[n].style.xStart, this.shapeList[n].style.xStart = e, this.shapeList[n].style.xEnd = e + i, this.zr.modShape(this.shapeList[n].id)) } }, getPosition: function() { return this.option.position }, isHorizontal: function() { return "bottom" === this.option.position || "top" === this.option.position } }, reformOption: function(e) { if (!e || e instanceof Array && 0 === e.length ? e = [{ type: a.COMPONENT_TYPE_AXIS_VALUE }] : e instanceof Array || (e = [e]), e.length > 2 && (e = [e[0], e[1]]), "xAxis" === this.axisType) { (!e[0].position || "bottom" != e[0].position && "top" != e[0].position) && (e[0].position = "bottom"), e.length > 1 && (e[1].position = "bottom" === e[0].position ? "top" : "bottom"); for (var t = 0, i = e.length; i > t; t++) e[t].type = e[t].type || "category", e[t].xAxisIndex = t, e[t].yAxisIndex = -1 } else { (!e[0].position || "left" != e[0].position && "right" != e[0].position) && (e[0].position = "left"), e.length > 1 && (e[1].position = "left" === e[0].position ? "right" : "left"); for (var t = 0, i = e.length; i > t; t++) e[t].type = e[t].type || "value", e[t].xAxisIndex = -1, e[t].yAxisIndex = t } return e }, refresh: function(t) { var i; t && (this.option = t, "xAxis" === this.axisType ? (this.option.xAxis = this.reformOption(t.xAxis), i = this.option.xAxis) : (this.option.yAxis = this.reformOption(t.yAxis), i = this.option.yAxis), this.series = t.series); for (var n = e("./categoryAxis"), a = e("./valueAxis"), o = Math.max(i && i.length || 0, this._axisList.length), r = 0; o > r; r++) !this._axisList[r] || !t || i[r] && this._axisList[r].type == i[r].type || (this._axisList[r].dispose && this._axisList[r].dispose(), this._axisList[r] = !1), this._axisList[r] ? this._axisList[r].refresh && this._axisList[r].refresh(i ? i[r] : !1, this.series) : i && i[r] && (this._axisList[r] = "category" === i[r].type ? new n(this.ecTheme, this.messageCenter, this.zr, i[r], this.myChart, this.axisBase) : new a(this.ecTheme, this.messageCenter, this.zr, i[r], this.myChart, this.axisBase, this.series)) }, getAxis: function(e) { return this._axisList[e] }, getAxisCount: function() { return this._axisList.length }, clear: function() { for (var e = 0, t = this._axisList.length; t > e; e++) this._axisList[e].dispose && this._axisList[e].dispose(); this._axisList = [] } }, r.inherits(t, i), e("../component").define("axis", t), t }), define("echarts/component/grid", ["require", "./base", "zrender/shape/Rectangle", "../config", "zrender/tool/util", "../component"], function(e) { function t(e, t, n, a, o) { i.call(this, e, t, n, a, o), this.refresh(a) } var i = e("./base"), n = e("zrender/shape/Rectangle"), a = e("../config"); a.grid = { zlevel: 0, z: 0, x: 80, y: 60, x2: 80, y2: 60, backgroundColor: "rgba(0,0,0,0)", borderWidth: 1, borderColor: "#ccc" }; var o = e("zrender/tool/util"); return t.prototype = { type: a.COMPONENT_TYPE_GRID, getX: function() { return this._x }, getY: function() { return this._y }, getWidth: function() { return this._width }, getHeight: function() { return this._height }, getXend: function() { return this._x + this._width }, getYend: function() { return this._y + this._height }, getArea: function() { return { x: this._x, y: this._y, width: this._width, height: this._height } }, getBbox: function() { return [ [this._x, this._y], [this.getXend(), this.getYend()] ] }, refixAxisShape: function(e) { for (var t, i, n, o = e.xAxis._axisList.concat(e.yAxis ? e.yAxis._axisList : []), r = o.length; r--;) n = o[r], n.type == a.COMPONENT_TYPE_AXIS_VALUE && n._min < 0 && n._max >= 0 && (n.isHorizontal() ? t = n.getCoord(0) : i = n.getCoord(0)); if ("undefined" != typeof t || "undefined" != typeof i) for (r = o.length; r--;) o[r].refixAxisShape(t, i) }, refresh: function(e) { if (e || this._zrWidth != this.zr.getWidth() || this._zrHeight != this.zr.getHeight()) { this.clear(), this.option = e || this.option, this.option.grid = this.reformOption(this.option.grid); var t = this.option.grid; this._zrWidth = this.zr.getWidth(), this._zrHeight = this.zr.getHeight(), this._x = this.parsePercent(t.x, this._zrWidth), this._y = this.parsePercent(t.y, this._zrHeight); var i = this.parsePercent(t.x2, this._zrWidth), a = this.parsePercent(t.y2, this._zrHeight); this._width = "undefined" == typeof t.width ? this._zrWidth - this._x - i : this.parsePercent(t.width, this._zrWidth), this._width = this._width <= 0 ? 10 : this._width, this._height = "undefined" == typeof t.height ? this._zrHeight - this._y - a : this.parsePercent(t.height, this._zrHeight), this._height = this._height <= 0 ? 10 : this._height, this._x = this.subPixelOptimize(this._x, t.borderWidth), this._y = this.subPixelOptimize(this._y, t.borderWidth), this.shapeList.push(new n({ zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this._x, y: this._y, width: this._width, height: this._height, brushType: t.borderWidth > 0 ? "both" : "fill", color: t.backgroundColor, strokeColor: t.borderColor, lineWidth: t.borderWidth } })), this.zr.addShape(this.shapeList[0]) } } }, o.inherits(t, i), e("../component").define("grid", t), t }), define("echarts/component/dataZoom", ["require", "./base", "zrender/shape/Rectangle", "zrender/shape/Polygon", "../util/shape/Icon", "../config", "../util/date", "zrender/tool/util", "../component"], function(e) { function t(e, t, n, a, o) { i.call(this, e, t, n, a, o); var r = this; r._ondrift = function(e, t) { return r.__ondrift(this, e, t) }, r._ondragend = function() { return r.__ondragend() }, this._fillerSize = 30, this._isSilence = !1, this._zoom = {}, this.option.dataZoom = this.reformOption(this.option.dataZoom), this.zoomOption = this.option.dataZoom, this._handleSize = this.zoomOption.handleSize, this.myChart.canvasSupported || (this.zoomOption.realtime = !1), this._location = this._getLocation(), this._zoom = this._getZoom(), this._backupData(), this.option.dataZoom.show && this._buildShape(), this._syncData() } var i = e("./base"), n = e("zrender/shape/Rectangle"), a = e("zrender/shape/Polygon"), o = e("../util/shape/Icon"), r = e("../config"); r.dataZoom = { zlevel: 0, z: 4, show: !1, orient: "horizontal", backgroundColor: "rgba(0,0,0,0)", dataBackgroundColor: "#eee", fillerColor: "rgba(144,197,237,0.2)", handleColor: "rgba(70,130,180,0.8)", handleSize: 8, showDetail: !0, realtime: !0 }; var s = e("../util/date"), l = e("zrender/tool/util"); return t.prototype = { type: r.COMPONENT_TYPE_DATAZOOM, _buildShape: function() { this._buildBackground(), this._buildFiller(), this._buildHandle(), this._buildFrame(); for (var e = 0, t = this.shapeList.length; t > e; e++) this.zr.addShape(this.shapeList[e]); this._syncFrameShape() }, _getLocation: function() { var e, t, i, n, a = this.component.grid; return "horizontal" == this.zoomOption.orient ? (i = this.zoomOption.width || a.getWidth(), n = this.zoomOption.height || this._fillerSize, e = null != this.zoomOption.x ? this.zoomOption.x : a.getX(), t = null != this.zoomOption.y ? this.zoomOption.y : this.zr.getHeight() - n - 2) : (i = this.zoomOption.width || this._fillerSize, n = this.zoomOption.height || a.getHeight(), e = null != this.zoomOption.x ? this.zoomOption.x : 2, t = null != this.zoomOption.y ? this.zoomOption.y : a.getY()), { x: e, y: t, width: i, height: n } }, _getZoom: function() { var e = this.option.series, t = this.option.xAxis; !t || t instanceof Array || (t = [t], this.option.xAxis = t); var i = this.option.yAxis; !i || i instanceof Array || (i = [i], this.option.yAxis = i); var n, a, o = [], s = this.zoomOption.xAxisIndex; if (t && null == s) { n = []; for (var l = 0, h = t.length; h > l; l++)("category" == t[l].type || null == t[l].type) && n.push(l) } else n = s instanceof Array ? s : null != s ? [s] : []; if (s = this.zoomOption.yAxisIndex, i && null == s) { a = []; for (var l = 0, h = i.length; h > l; l++) "category" == i[l].type && a.push(l) } else a = s instanceof Array ? s : null != s ? [s] : []; for (var d, l = 0, h = e.length; h > l; l++) if (d = e[l], d.type == r.CHART_TYPE_LINE || d.type == r.CHART_TYPE_BAR || d.type == r.CHART_TYPE_SCATTER || d.type == r.CHART_TYPE_K) { for (var c = 0, m = n.length; m > c; c++) if (n[c] == (d.xAxisIndex || 0)) { o.push(l); break } for (var c = 0, m = a.length; m > c; c++) if (a[c] == (d.yAxisIndex || 0)) { o.push(l); break } null == this.zoomOption.xAxisIndex && null == this.zoomOption.yAxisIndex && d.data && this.getDataFromOption(d.data[0]) instanceof Array && (d.type == r.CHART_TYPE_SCATTER || d.type == r.CHART_TYPE_LINE || d.type == r.CHART_TYPE_BAR) && o.push(l) } var p = null != this._zoom.start ? this._zoom.start : null != this.zoomOption.start ? this.zoomOption.start : 0, u = null != this._zoom.end ? this._zoom.end : null != this.zoomOption.end ? this.zoomOption.end : 100; p > u && (p += u, u = p - u, p -= u); var V = Math.round((u - p) / 100 * ("horizontal" == this.zoomOption.orient ? this._location.width : this._location.height)); return { start: p, end: u, start2: 0, end2: 100, size: V, xAxisIndex: n, yAxisIndex: a, seriesIndex: o, scatterMap: this._zoom.scatterMap || {} } }, _backupData: function() { this._originalData = { xAxis: {}, yAxis: {}, series: {} }; for (var e = this.option.xAxis, t = this._zoom.xAxisIndex, i = 0, n = t.length; n > i; i++) this._originalData.xAxis[t[i]] = e[t[i]].data; for (var a = this.option.yAxis, o = this._zoom.yAxisIndex, i = 0, n = o.length; n > i; i++) this._originalData.yAxis[o[i]] = a[o[i]].data; for (var s, l = this.option.series, h = this._zoom.seriesIndex, i = 0, n = h.length; n > i; i++) s = l[h[i]], this._originalData.series[h[i]] = s.data, s.data && this.getDataFromOption(s.data[0]) instanceof Array && (s.type == r.CHART_TYPE_SCATTER || s.type == r.CHART_TYPE_LINE || s.type == r.CHART_TYPE_BAR) && (this._backupScale(), this._calculScatterMap(h[i])) }, _calculScatterMap: function(t) { this._zoom.scatterMap = this._zoom.scatterMap || {}, this._zoom.scatterMap[t] = this._zoom.scatterMap[t] || {}; var i = e("../component"), n = i.get("axis"), a = l.clone(this.option.xAxis); "category" == a[0].type && (a[0].type = "value"), a[1] && "category" == a[1].type && (a[1].type = "value"); var o = new n(this.ecTheme, null, !1, { xAxis: a, series: this.option.series }, this, "xAxis"), r = this.option.series[t].xAxisIndex || 0; this._zoom.scatterMap[t].x = o.getAxis(r).getExtremum(), o.dispose(), a = l.clone(this.option.yAxis), "category" == a[0].type && (a[0].type = "value"), a[1] && "category" == a[1].type && (a[1].type = "value"), o = new n(this.ecTheme, null, !1, { yAxis: a, series: this.option.series }, this, "yAxis"), r = this.option.series[t].yAxisIndex || 0, this._zoom.scatterMap[t].y = o.getAxis(r).getExtremum(), o.dispose() }, _buildBackground: function() { var e = this._location.width, t = this._location.height; this.shapeList.push(new n({ zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this._location.x, y: this._location.y, width: e, height: t, color: this.zoomOption.backgroundColor } })); for (var i = 0, o = this._originalData.xAxis, s = this._zoom.xAxisIndex, l = 0, h = s.length; h > l; l++) i = Math.max(i, o[s[l]].length); for (var d = this._originalData.yAxis, c = this._zoom.yAxisIndex, l = 0, h = c.length; h > l; l++) i = Math.max(i, d[c[l]].length); for (var m, p = this._zoom.seriesIndex[0], u = this._originalData.series[p], V = Number.MIN_VALUE, U = Number.MAX_VALUE, l = 0, h = u.length; h > l; l++) m = this.getDataFromOption(u[l], 0), this.option.series[p].type == r.CHART_TYPE_K && (m = m[1]), isNaN(m) && (m = 0), V = Math.max(V, m), U = Math.min(U, m); var g = V - U, f = [], y = e / (i - (i > 1 ? 1 : 0)), b = t / (i - (i > 1 ? 1 : 0)), _ = 1; "horizontal" == this.zoomOption.orient && 1 > y ? _ = Math.floor(3 * i / e) : "vertical" == this.zoomOption.orient && 1 > b && (_ = Math.floor(3 * i / t)); for (var l = 0, h = i; h > l; l += _) m = this.getDataFromOption(u[l], 0), this.option.series[p].type == r.CHART_TYPE_K && (m = m[1]), isNaN(m) && (m = 0), f.push("horizontal" == this.zoomOption.orient ? [this._location.x + y * l, this._location.y + t - 1 - Math.round((m - U) / g * (t - 10))] : [this._location.x + 1 + Math.round((m - U) / g * (e - 10)), this._location.y + b * (h - l - 1)]); "horizontal" == this.zoomOption.orient ? (f.push([this._location.x + e, this._location.y + t]), f.push([this._location.x, this._location.y + t])) : (f.push([this._location.x, this._location.y]), f.push([this._location.x, this._location.y + t])), this.shapeList.push(new a({ zlevel: this.getZlevelBase(), z: this.getZBase(), style: { pointList: f, color: this.zoomOption.dataBackgroundColor }, hoverable: !1 })) }, _buildFiller: function() { this._fillerShae = { zlevel: this.getZlevelBase(), z: this.getZBase(), draggable: !0, ondrift: this._ondrift, ondragend: this._ondragend, _type: "filler" }, this._fillerShae.style = "horizontal" == this.zoomOption.orient ? { x: this._location.x + Math.round(this._zoom.start / 100 * this._location.width) + this._handleSize, y: this._location.y, width: this._zoom.size - 2 * this._handleSize, height: this._location.height, color: this.zoomOption.fillerColor, text: ":::", textPosition: "inside" } : { x: this._location.x, y: this._location.y + Math.round(this._zoom.start / 100 * this._location.height) + this._handleSize, width: this._location.width, height: this._zoom.size - 2 * this._handleSize, color: this.zoomOption.fillerColor, text: "::", textPosition: "inside" }, this._fillerShae.highlightStyle = { brushType: "fill", color: "rgba(0,0,0,0)" }, this._fillerShae = new n(this._fillerShae), this.shapeList.push(this._fillerShae) }, _buildHandle: function() { var e = this.zoomOption.showDetail ? this._getDetail() : { start: "", end: "" }; this._startShape = { zlevel: this.getZlevelBase(), z: this.getZBase(), draggable: !0, style: { iconType: "rectangle", x: this._location.x, y: this._location.y, width: this._handleSize, height: this._handleSize, color: this.zoomOption.handleColor, text: "=", textPosition: "inside" }, highlightStyle: { text: e.start, brushType: "fill", textPosition: "left" }, ondrift: this._ondrift, ondragend: this._ondragend }, "horizontal" == this.zoomOption.orient ? (this._startShape.style.height = this._location.height, this._endShape = l.clone(this._startShape), this._startShape.style.x = this._fillerShae.style.x - this._handleSize, this._endShape.style.x = this._fillerShae.style.x + this._fillerShae.style.width, this._endShape.highlightStyle.text = e.end, this._endShape.highlightStyle.textPosition = "right") : (this._startShape.style.width = this._location.width, this._endShape = l.clone(this._startShape), this._startShape.style.y = this._fillerShae.style.y + this._fillerShae.style.height, this._startShape.highlightStyle.textPosition = "bottom", this._endShape.style.y = this._fillerShae.style.y - this._handleSize, this._endShape.highlightStyle.text = e.end, this._endShape.highlightStyle.textPosition = "top"), this._startShape = new o(this._startShape), this._endShape = new o(this._endShape), this.shapeList.push(this._startShape), this.shapeList.push(this._endShape) }, _buildFrame: function() { var e = this.subPixelOptimize(this._location.x, 1), t = this.subPixelOptimize(this._location.y, 1); this._startFrameShape = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: e, y: t, width: this._location.width - (e > this._location.x ? 1 : 0), height: this._location.height - (t > this._location.y ? 1 : 0), lineWidth: 1, brushType: "stroke", strokeColor: this.zoomOption.handleColor } }, this._endFrameShape = l.clone(this._startFrameShape), this._startFrameShape = new n(this._startFrameShape), this._endFrameShape = new n(this._endFrameShape), this.shapeList.push(this._startFrameShape), this.shapeList.push(this._endFrameShape) }, _syncHandleShape: function() { "horizontal" == this.zoomOption.orient ? (this._startShape.style.x = this._fillerShae.style.x - this._handleSize, this._endShape.style.x = this._fillerShae.style.x + this._fillerShae.style.width, this._zoom.start = (this._startShape.style.x - this._location.x) / this._location.width * 100, this._zoom.end = (this._endShape.style.x + this._handleSize - this._location.x) / this._location.width * 100) : (this._startShape.style.y = this._fillerShae.style.y + this._fillerShae.style.height, this._endShape.style.y = this._fillerShae.style.y - this._handleSize, this._zoom.start = (this._location.y + this._location.height - this._startShape.style.y) / this._location.height * 100, this._zoom.end = (this._location.y + this._location.height - this._endShape.style.y - this._handleSize) / this._location.height * 100), this.zr.modShape(this._startShape.id), this.zr.modShape(this._endShape.id), this._syncFrameShape(), this.zr.refreshNextFrame() }, _syncFillerShape: function() { var e, t; "horizontal" == this.zoomOption.orient ? (e = this._startShape.style.x, t = this._endShape.style.x, this._fillerShae.style.x = Math.min(e, t) + this._handleSize, this._fillerShae.style.width = Math.abs(e - t) - this._handleSize, this._zoom.start = (Math.min(e, t) - this._location.x) / this._location.width * 100, this._zoom.end = (Math.max(e, t) + this._handleSize - this._location.x) / this._location.width * 100) : (e = this._startShape.style.y, t = this._endShape.style.y, this._fillerShae.style.y = Math.min(e, t) + this._handleSize, this._fillerShae.style.height = Math.abs(e - t) - this._handleSize, this._zoom.start = (this._location.y + this._location.height - Math.max(e, t)) / this._location.height * 100, this._zoom.end = (this._location.y + this._location.height - Math.min(e, t) - this._handleSize) / this._location.height * 100), this.zr.modShape(this._fillerShae.id), this._syncFrameShape(), this.zr.refreshNextFrame() }, _syncFrameShape: function() { "horizontal" == this.zoomOption.orient ? (this._startFrameShape.style.width = this._fillerShae.style.x - this._location.x, this._endFrameShape.style.x = this._fillerShae.style.x + this._fillerShae.style.width, this._endFrameShape.style.width = this._location.x + this._location.width - this._endFrameShape.style.x) : (this._startFrameShape.style.y = this._fillerShae.style.y + this._fillerShae.style.height, this._startFrameShape.style.height = this._location.y + this._location.height - this._startFrameShape.style.y, this._endFrameShape.style.height = this._fillerShae.style.y - this._location.y), this.zr.modShape(this._startFrameShape.id), this.zr.modShape(this._endFrameShape.id) }, _syncShape: function() { this.zoomOption.show && ("horizontal" == this.zoomOption.orient ? (this._startShape.style.x = this._location.x + this._zoom.start / 100 * this._location.width, this._endShape.style.x = this._location.x + this._zoom.end / 100 * this._location.width - this._handleSize, this._fillerShae.style.x = this._startShape.style.x + this._handleSize, this._fillerShae.style.width = this._endShape.style.x - this._startShape.style.x - this._handleSize) : (this._startShape.style.y = this._location.y + this._location.height - this._zoom.start / 100 * this._location.height, this._endShape.style.y = this._location.y + this._location.height - this._zoom.end / 100 * this._location.height - this._handleSize, this._fillerShae.style.y = this._endShape.style.y + this._handleSize, this._fillerShae.style.height = this._startShape.style.y - this._endShape.style.y - this._handleSize), this.zr.modShape(this._startShape.id), this.zr.modShape(this._endShape.id), this.zr.modShape(this._fillerShae.id), this._syncFrameShape(), this.zr.refresh()) }, _syncData: function(e) { var t, i, n, a, o; for (var s in this._originalData) { t = this._originalData[s]; for (var l in t) o = t[l], null != o && (a = o.length, i = Math.floor(this._zoom.start / 100 * a), n = Math.ceil(this._zoom.end / 100 * a), this.getDataFromOption(o[0]) instanceof Array && this.option[s][l].type != r.CHART_TYPE_K ? (this._setScale(), this.option[s][l].data = this._synScatterData(l, o)) : this.option[s][l].data = o.slice(i, n)) } this._isSilence || !this.zoomOption.realtime && !e || this.messageCenter.dispatch(r.EVENT.DATA_ZOOM, null, { zoom: this._zoom }, this.myChart) }, _synScatterData: function(e, t) { if (0 === this._zoom.start && 100 == this._zoom.end && 0 === this._zoom.start2 && 100 == this._zoom.end2) return t; var i, n, a, o, r, s = [], l = this._zoom.scatterMap[e]; "horizontal" == this.zoomOption.orient ? (i = l.x.max - l.x.min, n = this._zoom.start / 100 * i + l.x.min, a = this._zoom.end / 100 * i + l.x.min, i = l.y.max - l.y.min, o = this._zoom.start2 / 100 * i + l.y.min, r = this._zoom.end2 / 100 * i + l.y.min) : (i = l.x.max - l.x.min, n = this._zoom.start2 / 100 * i + l.x.min, a = this._zoom.end2 / 100 * i + l.x.min, i = l.y.max - l.y.min, o = this._zoom.start / 100 * i + l.y.min, r = this._zoom.end / 100 * i + l.y.min); var h; (h = l.x.dataMappingMethods) && (n = h.coord2Value(n), a = h.coord2Value(a)), (h = l.y.dataMappingMethods) && (o = h.coord2Value(o), r = h.coord2Value(r)); for (var d, c = 0, m = t.length; m > c; c++) d = t[c].value || t[c], d[0] >= n && d[0] <= a && d[1] >= o && d[1] <= r && s.push(t[c]); return s }, _setScale: function() { var e = 0 !== this._zoom.start || 100 !== this._zoom.end || 0 !== this._zoom.start2 || 100 !== this._zoom.end2, t = { xAxis: this.option.xAxis, yAxis: this.option.yAxis }; for (var i in t) for (var n = 0, a = t[i].length; a > n; n++) t[i][n].scale = e || t[i][n]._scale }, _backupScale: function() { var e = { xAxis: this.option.xAxis, yAxis: this.option.yAxis }; for (var t in e) for (var i = 0, n = e[t].length; n > i; i++) e[t][i]._scale = e[t][i].scale }, _getDetail: function() { for (var e = ["xAxis", "yAxis"], t = 0, i = e.length; i > t; t++) { var n = this._originalData[e[t]]; for (var a in n) { var o = n[a]; if (null != o) { var r = o.length, l = Math.floor(this._zoom.start / 100 * r), h = Math.ceil(this._zoom.end / 100 * r); return h -= h > 0 ? 1 : 0, { start: this.getDataFromOption(o[l]), end: this.getDataFromOption(o[h]) } } } } e = "horizontal" == this.zoomOption.orient ? "xAxis" : "yAxis"; var d = this._zoom.seriesIndex[0], c = this.option.series[d][e + "Index"] || 0, m = this.option[e][c].type, p = this._zoom.scatterMap[d][e.charAt(0)].min, u = this._zoom.scatterMap[d][e.charAt(0)].max, V = u - p; if ("value" == m) return { start: p + V * this._zoom.start / 100, end: p + V * this._zoom.end / 100 }; if ("time" == m) { u = p + V * this._zoom.end / 100, p += V * this._zoom.start / 100; var U = s.getAutoFormatter(p, u).formatter; return { start: s.format(U, p), end: s.format(U, u) } } return { start: "", end: "" } }, __ondrift: function(e, t, i) { this.zoomOption.zoomLock && (e = this._fillerShae); var n = "filler" == e._type ? this._handleSize : 0; if ("horizontal" == this.zoomOption.orient ? e.style.x + t - n <= this._location.x ? e.style.x = this._location.x + n : e.style.x + t + e.style.width + n >= this._location.x + this._location.width ? e.style.x = this._location.x + this._location.width - e.style.width - n : e.style.x += t : e.style.y + i - n <= this._location.y ? e.style.y = this._location.y + n : e.style.y + i + e.style.height + n >= this._location.y + this._location.height ? e.style.y = this._location.y + this._location.height - e.style.height - n : e.style.y += i, "filler" == e._type ? this._syncHandleShape() : this._syncFillerShape(), this.zoomOption.realtime && this._syncData(), this.zoomOption.showDetail) { var a = this._getDetail(); this._startShape.style.text = this._startShape.highlightStyle.text = a.start, this._endShape.style.text = this._endShape.highlightStyle.text = a.end, this._startShape.style.textPosition = this._startShape.highlightStyle.textPosition, this._endShape.style.textPosition = this._endShape.highlightStyle.textPosition } return !0 }, __ondragend: function() { this.zoomOption.showDetail && (this._startShape.style.text = this._endShape.style.text = "=", this._startShape.style.textPosition = this._endShape.style.textPosition = "inside", this.zr.modShape(this._startShape.id), this.zr.modShape(this._endShape.id), this.zr.refreshNextFrame()), this.isDragend = !0 }, ondragend: function(e, t) { this.isDragend && e.target && (!this.zoomOption.realtime && this._syncData(), t.dragOut = !0, t.dragIn = !0, this._isSilence || this.zoomOption.realtime || this.messageCenter.dispatch(r.EVENT.DATA_ZOOM, null, { zoom: this._zoom }, this.myChart), t.needRefresh = !1, this.isDragend = !1) }, ondataZoom: function(e, t) { t.needRefresh = !0 }, absoluteZoom: function(e) { this._zoom.start = e.start, this._zoom.end = e.end, this._zoom.start2 = e.start2, this._zoom.end2 = e.end2, this._syncShape(), this._syncData(!0) }, rectZoom: function(e) { if (!e) return this._zoom.start = this._zoom.start2 = 0, this._zoom.end = this._zoom.end2 = 100, this._syncShape(), this._syncData(!0), this._zoom; var t = this.component.grid.getArea(), i = { x: e.x, y: e.y, width: e.width, height: e.height }; if (i.width < 0 && (i.x += i.width, i.width = -i.width), i.height < 0 && (i.y += i.height, i.height = -i.height), i.x > t.x + t.width || i.y > t.y + t.height) return !1; i.x < t.x && (i.x = t.x), i.x + i.width > t.x + t.width && (i.width = t.x + t.width - i.x), i.y + i.height > t.y + t.height && (i.height = t.y + t.height - i.y); var n, a = (i.x - t.x) / t.width, o = 1 - (i.x + i.width - t.x) / t.width, r = 1 - (i.y + i.height - t.y) / t.height, s = (i.y - t.y) / t.height; return "horizontal" == this.zoomOption.orient ? (n = this._zoom.end - this._zoom.start, this._zoom.start += n * a, this._zoom.end -= n * o, n = this._zoom.end2 - this._zoom.start2, this._zoom.start2 += n * r, this._zoom.end2 -= n * s) : (n = this._zoom.end - this._zoom.start, this._zoom.start += n * r, this._zoom.end -= n * s, n = this._zoom.end2 - this._zoom.start2, this._zoom.start2 += n * a, this._zoom.end2 -= n * o), this._syncShape(), this._syncData(!0), this._zoom }, syncBackupData: function(e) { for (var t, i, n = this._originalData.series, a = e.series, o = 0, r = a.length; r > o; o++) { i = a[o].data || a[o].eventList, t = n[o] ? Math.floor(this._zoom.start / 100 * n[o].length) : 0; for (var s = 0, l = i.length; l > s; s++) n[o] && (n[o][s + t] = i[s]) } }, syncOption: function(e) { this.silence(!0), this.option = e, this.option.dataZoom = this.reformOption(this.option.dataZoom), this.zoomOption = this.option.dataZoom, this.myChart.canvasSupported || (this.zoomOption.realtime = !1), this.clear(), this._location = this._getLocation(), this._zoom = this._getZoom(), this._backupData(), this.option.dataZoom && this.option.dataZoom.show && this._buildShape(), this._syncData(), this.silence(!1) }, silence: function(e) { this._isSilence = e }, getRealDataIndex: function(e, t) { if (!this._originalData || 0 === this._zoom.start && 100 == this._zoom.end) return t; var i = this._originalData.series; return i[e] ? Math.floor(this._zoom.start / 100 * i[e].length) + t : -1 }, resize: function() { this.clear(), this._location = this._getLocation(), this._zoom = this._getZoom(), this.option.dataZoom.show && this._buildShape() } }, l.inherits(t, i), e("../component").define("dataZoom", t), t }), define("echarts/component/categoryAxis", ["require", "./base", "zrender/shape/Text", "zrender/shape/Line", "zrender/shape/Rectangle", "../config", "zrender/tool/util", "zrender/tool/area", "../component"], function(e) { function t(e, t, n, a, o, r) { if (a.data.length < 1) return void console.error("option.data.length < 1."); i.call(this, e, t, n, a, o), this.grid = this.component.grid; for (var s in r) this[s] = r[s]; this.refresh(a) } var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Line"), o = e("zrender/shape/Rectangle"), r = e("../config"); r.categoryAxis = { zlevel: 0, z: 0, show: !0, position: "bottom", name: "", nameLocation: "end", nameTextStyle: {}, boundaryGap: !0, axisLine: { show: !0, onZero: !0, lineStyle: { color: "#48b", width: 2, type: "solid" } }, axisTick: { show: !0, interval: "auto", inside: !1, length: 5, lineStyle: { color: "#333", width: 1 } }, axisLabel: { show: !0, interval: "auto", rotate: 0, margin: 8, textStyle: { color: "#333" } }, splitLine: { show: !0, lineStyle: { color: ["#ccc"], width: 1, type: "solid" } }, splitArea: { show: !1, areaStyle: { color: ["rgba(250,250,250,0.3)", "rgba(200,200,200,0.3)"] } } }; var s = e("zrender/tool/util"), l = e("zrender/tool/area"); return t.prototype = { type: r.COMPONENT_TYPE_AXIS_CATEGORY, _getReformedLabel: function(e) { var t = this.getDataFromOption(this.option.data[e]), i = this.option.data[e].formatter || this.option.axisLabel.formatter; return i && ("function" == typeof i ? t = i.call(this.myChart, t) : "string" == typeof i && (t = i.replace("{value}", t))), t }, _getInterval: function() { var e = this.option.axisLabel.interval; if ("auto" == e) { var t = this.option.axisLabel.textStyle.fontSize, i = this.option.data, n = this.option.data.length; if (this.isHorizontal()) if (n > 3) { var a, o, r = this.getGap(), h = !1, d = Math.floor(.5 / r); for (d = 1 > d ? 1 : d, e = Math.floor(15 / r); !h && n > e;) { e += d, h = !0, a = Math.floor(r * e); for (var c = Math.floor((n - 1) / e) * e; c >= 0; c -= e) { if (0 !== this.option.axisLabel.rotate) o = t; else if (i[c].textStyle) o = l.getTextWidth(this._getReformedLabel(c), this.getFont(s.merge(i[c].textStyle, this.option.axisLabel.textStyle))); else { var m = this._getReformedLabel(c) + "", p = (m.match(/\w/g) || "").length, u = m.length - p; o = p * t * 2 / 3 + u * t } if (o > a) { h = !1; break } } } } else e = 1; else if (n > 3) { var r = this.getGap(); for (e = Math.floor(11 / r); t > r * e - 6 && n > e;) e++ } else e = 1 } else e = "function" == typeof e ? 1 : e - 0 + 1; return e }, _buildShape: function() { if (this._interval = this._getInterval(), this.option.show) { this.option.splitArea.show && this._buildSplitArea(), this.option.splitLine.show && this._buildSplitLine(), this.option.axisLine.show && this._buildAxisLine(), this.option.axisTick.show && this._buildAxisTick(), this.option.axisLabel.show && this._buildAxisLabel(); for (var e = 0, t = this.shapeList.length; t > e; e++) this.zr.addShape(this.shapeList[e]) } }, _buildAxisTick: function() { var e, t = this.option.data, i = this.option.data.length, n = this.option.axisTick, o = n.length, r = n.lineStyle.color, s = n.lineStyle.width, l = "function" == typeof n.interval ? n.interval : "auto" == n.interval && "function" == typeof this.option.axisLabel.interval ? this.option.axisLabel.interval : !1, h = l ? 1 : "auto" == n.interval ? this._interval : n.interval - 0 + 1, d = n.onGap, c = d ? this.getGap() / 2 : "undefined" == typeof d && this.option.boundaryGap ? this.getGap() / 2 : 0, m = c > 0 ? -h : 0; if (this.isHorizontal()) for (var p, u = "bottom" == this.option.position ? n.inside ? this.grid.getYend() - o - 1 : this.grid.getYend() + 1 : n.inside ? this.grid.getY() + 1 : this.grid.getY() - o - 1, V = m; i > V; V += h)(!l || l(V, t[V])) && (p = this.subPixelOptimize(this.getCoordByIndex(V) + (V >= 0 ? c : 0), s), e = { _axisShape: "axisTick", zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: p, yStart: u, xEnd: p, yEnd: u + o, strokeColor: r, lineWidth: s } }, this.shapeList.push(new a(e))); else for (var U, g = "left" == this.option.position ? n.inside ? this.grid.getX() + 1 : this.grid.getX() - o - 1 : n.inside ? this.grid.getXend() - o - 1 : this.grid.getXend() + 1, V = m; i > V; V += h)(!l || l(V, t[V])) && (U = this.subPixelOptimize(this.getCoordByIndex(V) - (V >= 0 ? c : 0), s), e = { _axisShape: "axisTick", zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: g, yStart: U, xEnd: g + o, yEnd: U, strokeColor: r, lineWidth: s } }, this.shapeList.push(new a(e))) }, _buildAxisLabel: function() { var e, t, i = this.option.data, a = this.option.data.length, o = this.option.axisLabel, r = o.rotate, l = o.margin, h = o.clickable, d = o.textStyle, c = "function" == typeof o.interval ? o.interval : !1; if (this.isHorizontal()) { var m, p; "bottom" == this.option.position ? (m = this.grid.getYend() + l, p = "top") : (m = this.grid.getY() - l, p = "bottom"); for (var u = 0; a > u; u += this._interval) c && !c(u, i[u]) || "" === this._getReformedLabel(u) || (t = s.merge(i[u].textStyle || {}, d), e = { zlevel: this.getZlevelBase(), z: this.getZBase() + 3, hoverable: !1, style: { x: this.getCoordByIndex(u), y: m, color: t.color, text: this._getReformedLabel(u), textFont: this.getFont(t), textAlign: t.align || "center", textBaseline: t.baseline || p } }, r && (e.style.textAlign = r > 0 ? "bottom" == this.option.position ? "right" : "left" : "bottom" == this.option.position ? "left" : "right", e.rotation = [r * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(h, e)))) } else { var V, U; "left" == this.option.position ? (V = this.grid.getX() - l, U = "right") : (V = this.grid.getXend() + l, U = "left"); for (var u = 0; a > u; u += this._interval) c && !c(u, i[u]) || "" === this._getReformedLabel(u) || (t = s.merge(i[u].textStyle || {}, d), e = { zlevel: this.getZlevelBase(), z: this.getZBase() + 3, hoverable: !1, style: { x: V, y: this.getCoordByIndex(u), color: t.color, text: this._getReformedLabel(u), textFont: this.getFont(t), textAlign: t.align || U, textBaseline: t.baseline || 0 === u && "" !== this.option.name ? "bottom" : u == a - 1 && "" !== this.option.name ? "top" : "middle" } }, r && (e.rotation = [r * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(h, e)))) } }, _buildSplitLine: function() { var e, t = this.option.data, i = this.option.data.length, n = this.option.splitLine, o = n.lineStyle.type, r = n.lineStyle.width, s = n.lineStyle.color; s = s instanceof Array ? s : [s]; var l = s.length, h = "function" == typeof this.option.axisLabel.interval ? this.option.axisLabel.interval : !1, d = n.onGap, c = d ? this.getGap() / 2 : "undefined" == typeof d && this.option.boundaryGap ? this.getGap() / 2 : 0; if (i -= d || "undefined" == typeof d && this.option.boundaryGap ? 1 : 0, this.isHorizontal()) for (var m, p = this.grid.getY(), u = this.grid.getYend(), V = 0; i > V; V += this._interval)(!h || h(V, t[V])) && (m = this.subPixelOptimize(this.getCoordByIndex(V) + c, r), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: m, yStart: p, xEnd: m, yEnd: u, strokeColor: s[V / this._interval % l], lineType: o, lineWidth: r } }, this.shapeList.push(new a(e))); else for (var U, g = this.grid.getX(), f = this.grid.getXend(), V = 0; i > V; V += this._interval)(!h || h(V, t[V])) && (U = this.subPixelOptimize(this.getCoordByIndex(V) - c, r), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: g, yStart: U, xEnd: f, yEnd: U, strokeColor: s[V / this._interval % l], lineType: o, lineWidth: r } }, this.shapeList.push(new a(e))) }, _buildSplitArea: function() { var e, t = this.option.data, i = this.option.splitArea, n = i.areaStyle.color; if (n instanceof Array) { var a = n.length, r = this.option.data.length, s = "function" == typeof this.option.axisLabel.interval ? this.option.axisLabel.interval : !1, l = i.onGap, h = l ? this.getGap() / 2 : "undefined" == typeof l && this.option.boundaryGap ? this.getGap() / 2 : 0; if (this.isHorizontal()) for (var d, c = this.grid.getY(), m = this.grid.getHeight(), p = this.grid.getX(), u = 0; r >= u; u += this._interval) s && !s(u, t[u]) && r > u || (d = r > u ? this.getCoordByIndex(u) + h : this.grid.getXend(), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: p, y: c, width: d - p, height: m, color: n[u / this._interval % a] } }, this.shapeList.push(new o(e)), p = d); else for (var V, U = this.grid.getX(), g = this.grid.getWidth(), f = this.grid.getYend(), u = 0; r >= u; u += this._interval) s && !s(u, t[u]) && r > u || (V = r > u ? this.getCoordByIndex(u) - h : this.grid.getY(), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: U, y: V, width: g, height: f - V, color: n[u / this._interval % a] } }, this.shapeList.push(new o(e)), f = V) } else e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this.grid.getX(), y: this.grid.getY(), width: this.grid.getWidth(), height: this.grid.getHeight(), color: n } }, this.shapeList.push(new o(e)) }, refresh: function(e) { e && (this.option = this.reformOption(e), this.option.axisLabel.textStyle = this.getTextStyle(this.option.axisLabel.textStyle)), this.clear(), this._buildShape() }, getGap: function() { var e = this.option.data.length, t = this.isHorizontal() ? this.grid.getWidth() : this.grid.getHeight(); return this.option.boundaryGap ? t / e : t / (e > 1 ? e - 1 : 1) }, getCoord: function(e) { for (var t = this.option.data, i = t.length, n = this.getGap(), a = this.option.boundaryGap ? n / 2 : 0, o = 0; i > o; o++) { if (this.getDataFromOption(t[o]) == e) return a = this.isHorizontal() ? this.grid.getX() + a : this.grid.getYend() - a; a += n } }, getCoordByIndex: function(e) { if (0 > e) return this.isHorizontal() ? this.grid.getX() : this.grid.getYend(); if (e > this.option.data.length - 1) return this.isHorizontal() ? this.grid.getXend() : this.grid.getY(); var t = this.getGap(), i = this.option.boundaryGap ? t / 2 : 0; return i += e * t, i = this.isHorizontal() ? this.grid.getX() + i : this.grid.getYend() - i }, getNameByIndex: function(e) { return this.getDataFromOption(this.option.data[e]) }, getIndexByName: function(e) { for (var t = this.option.data, i = t.length, n = 0; i > n; n++) if (this.getDataFromOption(t[n]) == e) return n; return -1 }, getValueFromCoord: function() { return "" }, isMainAxis: function(e) { return e % this._interval === 0 } }, s.inherits(t, i), e("../component").define("categoryAxis", t), t }), define("echarts/component/valueAxis", ["require", "./base", "zrender/shape/Text", "zrender/shape/Line", "zrender/shape/Rectangle", "../config", "../util/date", "zrender/tool/util", "../util/smartSteps", "../util/accMath", "../util/smartLogSteps", "../component"], function(e) { function t(e, t, n, a, o, r, s) { if (!s || 0 === s.length) return void console.err("option.series.length == 0."); i.call(this, e, t, n, a, o), this.series = s, this.grid = this.component.grid; for (var l in r) this[l] = r[l]; this.refresh(a, s) } var i = e("./base"), n = e("zrender/shape/Text"), a = e("zrender/shape/Line"), o = e("zrender/shape/Rectangle"), r = e("../config"); r.valueAxis = { zlevel: 0, z: 0, show: !0, position: "left", name: "", nameLocation: "end", nameTextStyle: {}, boundaryGap: [0, 0], axisLine: { show: !0, onZero: !0, lineStyle: { color: "#48b", width: 2, type: "solid" } }, axisTick: { show: !1, inside: !1, length: 5, lineStyle: { color: "#333", width: 1 } }, axisLabel: { show: !0, rotate: 0, margin: 8, textStyle: { color: "#333" } }, splitLine: { show: !0, lineStyle: { color: ["#ccc"], width: 1, type: "solid" } }, splitArea: { show: !1, areaStyle: { color: ["rgba(250,250,250,0.3)", "rgba(200,200,200,0.3)"] } } }; var s = e("../util/date"), l = e("zrender/tool/util"); return t.prototype = { type: r.COMPONENT_TYPE_AXIS_VALUE, _buildShape: function() { if (this._hasData = !1, this._calculateValue(), this._hasData && this.option.show) { this.option.splitArea.show && this._buildSplitArea(), this.option.splitLine.show && this._buildSplitLine(), this.option.axisLine.show && this._buildAxisLine(), this.option.axisTick.show && this._buildAxisTick(), this.option.axisLabel.show && this._buildAxisLabel(); for (var e = 0, t = this.shapeList.length; t > e; e++) this.zr.addShape(this.shapeList[e]) } }, _buildAxisTick: function() { var e, t = this._valueList, i = this._valueList.length, n = this.option.axisTick, o = n.length, r = n.lineStyle.color, s = n.lineStyle.width; if (this.isHorizontal()) for (var l, h = "bottom" === this.option.position ? n.inside ? this.grid.getYend() - o - 1 : this.grid.getYend() + 1 : n.inside ? this.grid.getY() + 1 : this.grid.getY() - o - 1, d = 0; i > d; d++) l = this.subPixelOptimize(this.getCoord(t[d]), s), e = { _axisShape: "axisTick", zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: l, yStart: h, xEnd: l, yEnd: h + o, strokeColor: r, lineWidth: s } }, this.shapeList.push(new a(e)); else for (var c, m = "left" === this.option.position ? n.inside ? this.grid.getX() + 1 : this.grid.getX() - o - 1 : n.inside ? this.grid.getXend() - o - 1 : this.grid.getXend() + 1, d = 0; i > d; d++) c = this.subPixelOptimize(this.getCoord(t[d]), s), e = { _axisShape: "axisTick", zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: m, yStart: c, xEnd: m + o, yEnd: c, strokeColor: r, lineWidth: s } }, this.shapeList.push(new a(e)) }, _buildAxisLabel: function() { var e, t = this._valueList, i = this._valueList.length, a = this.option.axisLabel.rotate, o = this.option.axisLabel.margin, r = this.option.axisLabel.clickable, s = this.option.axisLabel.textStyle; if (this.isHorizontal()) { var l, h; "bottom" === this.option.position ? (l = this.grid.getYend() + o, h = "top") : (l = this.grid.getY() - o, h = "bottom"); for (var d = 0; i > d; d++) e = { zlevel: this.getZlevelBase(), z: this.getZBase() + 3, hoverable: !1, style: { x: this.getCoord(t[d]), y: l, color: "function" == typeof s.color ? s.color(t[d]) : s.color, text: this._valueLabel[d], textFont: this.getFont(s), textAlign: s.align || "center", textBaseline: s.baseline || h } }, a && (e.style.textAlign = a > 0 ? "bottom" === this.option.position ? "right" : "left" : "bottom" === this.option.position ? "left" : "right", e.rotation = [a * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(r, e))) } else { var c, m; "left" === this.option.position ? (c = this.grid.getX() - o, m = "right") : (c = this.grid.getXend() + o, m = "left"); for (var d = 0; i > d; d++) e = { zlevel: this.getZlevelBase(), z: this.getZBase() + 3, hoverable: !1, style: { x: c, y: this.getCoord(t[d]), color: "function" == typeof s.color ? s.color(t[d]) : s.color, text: this._valueLabel[d], textFont: this.getFont(s), textAlign: s.align || m, textBaseline: s.baseline || (0 === d && "" !== this.option.name ? "bottom" : d === i - 1 && "" !== this.option.name ? "top" : "middle") } }, a && (e.rotation = [a * Math.PI / 180, e.style.x, e.style.y]), this.shapeList.push(new n(this._axisLabelClickable(r, e))) } }, _buildSplitLine: function() { var e, t = this._valueList, i = this._valueList.length, n = this.option.splitLine, o = n.lineStyle.type, r = n.lineStyle.width, s = n.lineStyle.color; s = s instanceof Array ? s : [s]; var l = s.length; if (this.isHorizontal()) for (var h, d = this.grid.getY(), c = this.grid.getYend(), m = 0; i > m; m++) h = this.subPixelOptimize(this.getCoord(t[m]), r), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: h, yStart: d, xEnd: h, yEnd: c, strokeColor: s[m % l], lineType: o, lineWidth: r } }, this.shapeList.push(new a(e)); else for (var p, u = this.grid.getX(), V = this.grid.getXend(), m = 0; i > m; m++) p = this.subPixelOptimize(this.getCoord(t[m]), r), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { xStart: u, yStart: p, xEnd: V, yEnd: p, strokeColor: s[m % l], lineType: o, lineWidth: r } }, this.shapeList.push(new a(e)) }, _buildSplitArea: function() { var e, t = this.option.splitArea.areaStyle.color; if (t instanceof Array) { var i = t.length, n = this._valueList, a = this._valueList.length; if (this.isHorizontal()) for (var r, s = this.grid.getY(), l = this.grid.getHeight(), h = this.grid.getX(), d = 0; a >= d; d++) r = a > d ? this.getCoord(n[d]) : this.grid.getXend(), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: h, y: s, width: r - h, height: l, color: t[d % i] } }, this.shapeList.push(new o(e)), h = r; else for (var c, m = this.grid.getX(), p = this.grid.getWidth(), u = this.grid.getYend(), d = 0; a >= d; d++) c = a > d ? this.getCoord(n[d]) : this.grid.getY(), e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: m, y: c, width: p, height: u - c, color: t[d % i] } }, this.shapeList.push(new o(e)), u = c } else e = { zlevel: this.getZlevelBase(), z: this.getZBase(), hoverable: !1, style: { x: this.grid.getX(), y: this.grid.getY(), width: this.grid.getWidth(), height: this.grid.getHeight(), color: t } }, this.shapeList.push(new o(e)) }, _calculateValue: function() { if (isNaN(this.option.min - 0) || isNaN(this.option.max - 0)) { for (var e, t, i = {}, n = this.component.legend, a = 0, o = this.series.length; o > a; a++) !(this.series[a].type != r.CHART_TYPE_LINE && this.series[a].type != r.CHART_TYPE_BAR && this.series[a].type != r.CHART_TYPE_SCATTER && this.series[a].type != r.CHART_TYPE_K && this.series[a].type != r.CHART_TYPE_EVENTRIVER || n && !n.isSelected(this.series[a].name) || (e = this.series[a].xAxisIndex || 0, t = this.series[a].yAxisIndex || 0, this.option.xAxisIndex != e && this.option.yAxisIndex != t || !this._calculSum(i, a))); var s; for (var a in i) { s = i[a]; for (var l = 0, h = s.length; h > l; l++) if (!isNaN(s[l])) { this._hasData = !0, this._min = s[l], this._max = s[l]; break } if (this._hasData) break } for (var a in i) { s = i[a]; for (var l = 0, h = s.length; h > l; l++) isNaN(s[l]) || (this._min = Math.min(this._min, s[l]), this._max = Math.max(this._max, s[l])) } var d = "log" !== this.option.type ? this.option.boundaryGap : [0, 0], c = Math.abs(this._max - this._min); this._min = isNaN(this.option.min - 0) ? this._min - Math.abs(c * d[0]) : this.option.min - 0, this._max = isNaN(this.option.max - 0) ? this._max + Math.abs(c * d[1]) : this.option.max - 0, this._min === this._max && (0 === this._max ? this._max = 1 : this._max > 0 ? this._min = this._max / this.option.splitNumber != null ? this.option.splitNumber : 5 : this._max = this._max / this.option.splitNumber != null ? this.option.splitNumber : 5), "time" === this.option.type ? this._reformTimeValue() : "log" === this.option.type ? this._reformLogValue() : this._reformValue(this.option.scale) } else this._hasData = !0, this._min = this.option.min - 0, this._max = this.option.max - 0, "time" === this.option.type ? this._reformTimeValue() : "log" === this.option.type ? this._reformLogValue() : this._customerValue() }, _calculSum: function(e, t) { var i, n, a = this.series[t].name || "kener"; if (this.series[t].stack) { var o = "__Magic_Key_Positive__" + this.series[t].stack, l = "__Magic_Key_Negative__" + this.series[t].stack; e[o] = e[o] || [], e[l] = e[l] || [], e[a] = e[a] || [], n = this.series[t].data; for (var h = 0, d = n.length; d > h; h++) i = this.getDataFromOption(n[h]), "-" !== i && (i -= 0, i >= 0 ? null != e[o][h] ? e[o][h] += i : e[o][h] = i : null != e[l][h] ? e[l][h] += i : e[l][h] = i, this.option.scale && e[a].push(i)) } else if (e[a] = e[a] || [], this.series[t].type != r.CHART_TYPE_EVENTRIVER) { n = this.series[t].data; for (var h = 0, d = n.length; d > h; h++) i = this.getDataFromOption(n[h]), this.series[t].type === r.CHART_TYPE_K ? (e[a].push(i[0]), e[a].push(i[1]), e[a].push(i[2]), e[a].push(i[3])) : i instanceof Array ? (-1 != this.option.xAxisIndex && e[a].push("time" != this.option.type ? i[0] : s.getNewDate(i[0])), -1 != this.option.yAxisIndex && e[a].push("time" != this.option.type ? i[1] : s.getNewDate(i[1]))) : e[a].push(i) } else { n = this.series[t].data; for (var h = 0, d = n.length; d > h; h++) for (var c = n[h].evolution, m = 0, p = c.length; p > m; m++) e[a].push(s.getNewDate(c[m].time)) } }, _reformValue: function(t) { var i = e("../util/smartSteps"), n = this.option.splitNumber; !t && this._min >= 0 && this._max >= 0 && (this._min = 0), !t && this._min <= 0 && this._max <= 0 && (this._max = 0); var a = i(this._min, this._max, n); n = null != n ? n : a.secs, this._min = a.min, this._max = a.max, this._valueList = a.pnts, this._reformLabelData() }, _reformTimeValue: function() { var e = null != this.option.splitNumber ? this.option.splitNumber : 5, t = s.getAutoFormatter(this._min, this._max, e), i = t.formatter, n = t.gapValue; this._valueList = [s.getNewDate(this._min)]; var a; switch (i) { case "week": a = s.nextMonday(this._min); break; case "month": a = s.nextNthOnMonth(this._min, 1); break; case "quarter": a = s.nextNthOnQuarterYear(this._min, 1); break; case "half-year": a = s.nextNthOnHalfYear(this._min, 1); break; case "year": a = s.nextNthOnYear(this._min, 1); break; default: 72e5 >= n ? a = (Math.floor(this._min / n) + 1) * n : (a = s.getNewDate(this._min - -n), a.setHours(6 * Math.round(a.getHours() / 6)), a.setMinutes(0), a.setSeconds(0)) } for (a - this._min < n / 2 && (a -= -n), t = s.getNewDate(a), e *= 1.5; e-- >= 0 && (("month" == i || "quarter" == i || "half-year" == i || "year" == i) && t.setDate(1), !(this._max - t < n / 2));) this._valueList.push(t), t = s.getNewDate(t - -n); this._valueList.push(s.getNewDate(this._max)), this._reformLabelData(function(e) { return function(t) { return s.format(e, t) } }(i)) }, _customerValue: function() { var t = e("../util/accMath"), i = null != this.option.splitNumber ? this.option.splitNumber : 5, n = (this._max - this._min) / i; this._valueList = []; for (var a = 0; i >= a; a++) this._valueList.push(t.accAdd(this._min, t.accMul(n, a))); this._reformLabelData() }, _reformLogValue: function() { var t = this.option, i = e("../util/smartLogSteps")({ dataMin: this._min, dataMax: this._max, logPositive: t.logPositive, logLabelBase: t.logLabelBase, splitNumber: t.splitNumber }); this._min = i.dataMin, this._max = i.dataMax, this._valueList = i.tickList, this._dataMappingMethods = i.dataMappingMethods, this._reformLabelData(i.labelFormatter) }, _reformLabelData: function(e) { this._valueLabel = []; var t = this.option.axisLabel.formatter; if (t) for (var i = 0, n = this._valueList.length; n > i; i++) "function" == typeof t ? this._valueLabel.push(e ? t.call(this.myChart, this._valueList[i], e) : t.call(this.myChart, this._valueList[i])) : "string" == typeof t && this._valueLabel.push(e ? s.format(t, this._valueList[i]) : t.replace("{value}", this._valueList[i])); else for (var i = 0, n = this._valueList.length; n > i; i++) this._valueLabel.push(e ? e(this._valueList[i]) : this.numAddCommas(this._valueList[i])) }, getExtremum: function() { this._calculateValue(); var e = this._dataMappingMethods; return { min: this._min, max: this._max, dataMappingMethods: e ? l.merge({}, e) : null } }, refresh: function(e, t) { e && (this.option = this.reformOption(e), this.option.axisLabel.textStyle = l.merge(this.option.axisLabel.textStyle || {}, this.ecTheme.textStyle), this.series = t), this.zr && (this.clear(), this._buildShape()) }, getCoord: function(e) { this._dataMappingMethods && (e = this._dataMappingMethods.value2Coord(e)), e = e < this._min ? this._min : e, e = e > this._max ? this._max : e; var t; return t = this.isHorizontal() ? this.grid.getX() + (e - this._min) / (this._max - this._min) * this.grid.getWidth() : this.grid.getYend() - (e - this._min) / (this._max - this._min) * this.grid.getHeight() }, getCoordSize: function(e) { return Math.abs(this.isHorizontal() ? e / (this._max - this._min) * this.grid.getWidth() : e / (this._max - this._min) * this.grid.getHeight()) }, getValueFromCoord: function(e) { var t; return this.isHorizontal() ? (e = e < this.grid.getX() ? this.grid.getX() : e, e = e > this.grid.getXend() ? this.grid.getXend() : e, t = this._min + (e - this.grid.getX()) / this.grid.getWidth() * (this._max - this._min)) : (e = e < this.grid.getY() ? this.grid.getY() : e, e = e > this.grid.getYend() ? this.grid.getYend() : e, t = this._max - (e - this.grid.getY()) / this.grid.getHeight() * (this._max - this._min)), this._dataMappingMethods && (t = this._dataMappingMethods.coord2Value(t)), t.toFixed(2) - 0 }, isMaindAxis: function(e) { for (var t = 0, i = this._valueList.length; i > t; t++) if (this._valueList[t] === e) return !0; return !1 } }, l.inherits(t, i), e("../component").define("valueAxis", t), t }), define("echarts/util/date", [], function() { function e(e, t, i) { i = i > 1 ? i : 2; for (var n, a, o, r, s = 0, l = d.length; l > s; s++) if (n = d[s].value, a = Math.ceil(t / n) * n - Math.floor(e / n) * n, Math.round(a / n) <= 1.2 * i) { o = d[s].formatter, r = d[s].value; break } return null == o && (o = "year", n = 317088e5, a = Math.ceil(t / n) * n - Math.floor(e / n) * n, r = Math.round(a / (i - 1) / n) * n), { formatter: o, gapValue: r } } function t(e) { return 10 > e ? "0" + e : e } function i(e, i) { ("week" == e || "month" == e || "quarter" == e || "half-year" == e || "year" == e) && (e = "MM - dd\nyyyy"); var n = h(i), a = n.getFullYear(), o = n.getMonth() + 1, r = n.getDate(), s = n.getHours(), l = n.getMinutes(), d = n.getSeconds(); return e = e.replace("MM", t(o)), e = e.toLowerCase(), e = e.replace("yyyy", a), e = e.replace("yy", a % 100), e = e.replace("dd", t(r)), e = e.replace("d", r), e = e.replace("hh", t(s)), e = e.replace("h", s), e = e.replace("mm", t(l)), e = e.replace("m", l), e = e.replace("ss", t(d)), e = e.replace("s", d) } function n(e) { return e = h(e), e.setDate(e.getDate() + 8 - e.getDay()), e } function a(e, t, i) { return e = h(e), e.setMonth(Math.ceil((e.getMonth() + 1) / i) * i), e.setDate(t), e } function o(e, t) { return a(e, t, 1) } function r(e, t) { return a(e, t, 3) } function s(e, t) { return a(e, t, 6) } function l(e, t) { return a(e, t, 12) } function h(e) { return e instanceof Date ? e : new Date("string" == typeof e ? e.replace(/-/g, "/") : e) } var d = [{ formatter: "hh : mm : ss", value: 1e3 }, { formatter: "hh : mm : ss", value: 5e3 }, { formatter: "hh : mm : ss", value: 1e4 }, { formatter: "hh : mm : ss", value: 15e3 }, { formatter: "hh : mm : ss", value: 3e4 }, { formatter: "hh : mm\nMM - dd", value: 6e4 }, { formatter: "hh : mm\nMM - dd", value: 3e5 }, { formatter: "hh : mm\nMM - dd", value: 6e5 }, { formatter: "hh : mm\nMM - dd", value: 9e5 }, { formatter: "hh : mm\nMM - dd", value: 18e5 }, { formatter: "hh : mm\nMM - dd", value: 36e5 }, { formatter: "hh : mm\nMM - dd", value: 72e5 }, { formatter: "hh : mm\nMM - dd", value: 216e5 }, { formatter: "hh : mm\nMM - dd", value: 432e5 }, { formatter: "MM - dd\nyyyy", value: 864e5 }, { formatter: "week", value: 6048e5 }, { formatter: "month", value: 26784e5 }, { formatter: "quarter", value: 8208e6 }, { formatter: "half-year", value: 16416e6 }, { formatter: "year", value: 32832e6 }]; return { getAutoFormatter: e, getNewDate: h, format: i, nextMonday: n, nextNthPerNmonth: a, nextNthOnMonth: o, nextNthOnQuarterYear: r, nextNthOnHalfYear: s, nextNthOnYear: l } }), define("echarts/util/smartSteps", [], function() { function e(e) { return w.log(S(e)) / w.LN10 } function t(e) { return w.pow(10, e) } function i(e) { return e === X(e) } function n(e, t, n, a) { y = a || {}, b = y.steps || v, _ = y.secs || L, n = W(+n || 0) % 99, e = +e || 0, t = +t || 0, x = k = 0, "min" in y && (e = +y.min || 0, x = 1), "max" in y && (t = +y.max || 0, k = 1), e > t && (t = [e, e = t][0]); var o = t - e; if (x && k) return f(e, t, n); if ((n || 5) > o) { if (i(e) && i(t)) return p(e, t, n); if (0 === o) return u(e, t, n) } return h(e, t, n) } function a(e, i, n, a) { a = a || 0; var s = o((i - e) / n, -1), l = o(e, -1, 1), h = o(i, -1), d = w.min(s.e, l.e, h.e); 0 === l.c ? d = w.min(s.e, h.e) : 0 === h.c && (d = w.min(s.e, l.e)), r(s, { c: 0, e: d }), r(l, s, 1), r(h, s), a += d, e = l.c, i = h.c; for (var c = (i - e) / n, m = t(a), p = 0, u = [], V = n + 1; V--;) u[V] = (e + c * V) * m; if (0 > a) { p = U(m), c = +(c * m).toFixed(p), e = +(e * m).toFixed(p), i = +(i * m).toFixed(p); for (var V = u.length; V--;) u[V] = u[V].toFixed(p), 0 === +u[V] && (u[V] = "0") } else e *= m, i *= m, c *= m; return _ = 0, b = 0, y = 0, { min: e, max: i, secs: n, step: c, fix: p, exp: a, pnts: u } } function o(n, a, o) { a = W(a % 10) || 2, 0 > a && (i(n) ? a = ("" + S(n)).replace(/0+$/, "").length || 1 : (n = n.toFixed(15).replace(/0+$/, ""), a = n.replace(".", "").replace(/^[-0]+/, "").length, n = +n)); var r = X(e(n)) - a + 1, s = +(n * t(-r)).toFixed(15) || 0; return s = o ? X(s) : I(s), !s && (r = 0), ("" + S(s)).length > a && (r += 1, s /= 10), { c: s, e: r } } function r(e, i, n) { var a = i.e - e.e; a && (e.e += a, e.c *= t(-a), e.c = n ? X(e.c) : I(e.c)) } function s(e, t, i) { e.e < t.e ? r(t, e, i) : r(e, t, i) } function l(e, t) { t = t || v, e = o(e); for (var i = e.c, n = 0; i > t[n];) n++; if (!t[n]) for (i /= 10, e.e += 1, n = 0; i > t[n];) n++; return e.c = t[n], e } function h(e, t, n) { var s, h = n || +_.slice(-1), u = l((t - e) / h, b), U = o(t - e), f = o(e, -1, 1), y = o(t, -1); if (r(U, u), r(f, u, 1), r(y, u), n ? s = c(f, y, h) : h = d(f, y), i(e) && i(t) && e * t >= 0) { if (h > t - e) return p(e, t, h); h = m(e, t, n, f, y, h) } var v = V(e, t, f.c, y.c); return f.c = v[0], y.c = v[1], (x || k) && g(e, t, f, y), a(f.c, y.c, h, y.e) } function d(e, i) { for (var n, a, o, r, s = [], h = _.length; h--;) n = _[h], a = l((i.c - e.c) / n, b), a = a.c * t(a.e), o = X(e.c / a) * a, r = I(i.c / a) * a, s[h] = { min: o, max: r, step: a, span: r - o }; return s.sort(function(e, t) { var i = e.span - t.span; return 0 === i && (i = e.step - t.step), i }), s = s[0], n = s.span / s.step, e.c = s.min, i.c = s.max, 3 > n ? 2 * n : n } function c(e, i, n) { for (var a, o, r = i.c, s = (i.c - e.c) / n - 1; r > e.c;) s = l(s + 1, b), s = s.c * t(s.e), a = s * n, o = I(i.c / s) * s, r = o - a; var h = e.c - r, d = o - i.c, c = h - d; return c > 1.1 * s && (c = W(c / s / 2) * s, r += c, o += c), e.c = r, i.c = o, s } function m(e, n, a, o, r, s) { var l = r.c - o.c, h = l / s * t(r.e); if (!i(h) && (h = X(h), l = h * s, n - e > l && (h += 1, l = h * s, !a && h * (s - 1) >= n - e && (s -= 1, l = h * s)), l >= n - e)) { var d = l - (n - e); o.c = W(e - d / 2), r.c = W(n + d / 2), o.e = 0, r.e = 0 } return s } function p(e, t, i) { if (i = i || 5, x) t = e + i; else if (k) e = t - i; else { var n = i - (t - e), o = W(e - n / 2), r = W(t + n / 2), s = V(e, t, o, r); e = s[0], t = s[1] } return a(e, t, i) } function u(e, t, i) { i = i || 5; var n = w.min(S(t / i), i) / 2.1; return x ? t = e + n : k ? e = t - n : (e -= n, t += n), h(e, t, i) } function V(e, t, i, n) { return e >= 0 && 0 > i ? (n -= i, i = 0) : 0 >= t && n > 0 && (i -= n, n = 0), [i, n] } function U(e) { return e = (+e).toFixed(15).split("."), e.pop().replace(/0+$/, "").length } function g(e, t, i, n) { if (x) { var a = o(e, 4, 1); i.e - a.e > 6 && (a = { c: 0, e: i.e }), s(i, a), s(n, a), n.c += a.c - i.c, i.c = a.c } else if (k) { var r = o(t, 4); n.e - r.e > 6 && (r = { c: 0, e: n.e }), s(i, r), s(n, r), i.c += r.c - n.c, n.c = r.c } } function f(e, t, i) { var n = i ? [i] : _, s = t - e; if (0 === s) return t = o(t, 3), i = n[0], t.c = W(t.c + i / 2), a(t.c - i, t.c, i, t.e); S(t / s) < 1e-6 && (t = 0), S(e / s) < 1e-6 && (e = 0); var l, h, d, c = [ [5, 10], [10, 2], [50, 10], [100, 2] ], m = [], p = [], u = o(t - e, 3), V = o(e, -1, 1), U = o(t, -1); r(V, u, 1), r(U, u), s = U.c - V.c, u.c = s; for (var g = n.length; g--;) { i = n[g], l = I(s / i), h = l * i - s, d = 3 * (h + 3), d += 2 * (i - n[0] + 2), i % 5 === 0 && (d -= 10); for (var f = c.length; f--;) l % c[f][0] === 0 && (d /= c[f][1]); p[g] = [i, l, h, d].join(), m[g] = { secs: i, step: l, delta: h, score: d } } return m.sort(function(e, t) { return e.score - t.score }), m = m[0], V.c = W(V.c - m.delta / 2), U.c = W(U.c + m.delta / 2), a(V.c, U.c, m.secs, u.e) } var y, b, _, x, k, v = [10, 20, 25, 50], L = [4, 5, 6], w = Math, W = w.round, X = w.floor, I = w.ceil, S = w.abs; return n }), define("echarts/util/smartLogSteps", ["require", "./number"], function(e) { function t(e) { return i(), U = e || {}, n(), a(), [o(), i()][0] } function i() { m = U = f = V = y = b = g = _ = p = u = null } function n() { p = U.logLabelBase, null == p ? (u = "plain", p = 10, V = S) : (p = +p, 1 > p && (p = 10), u = "exponent", V = v(p)), g = U.splitNumber, null == g && (g = E); var e = parseFloat(U.dataMin), t = parseFloat(U.dataMax); isFinite(e) || isFinite(t) ? isFinite(e) ? isFinite(t) ? e > t && (t = [e, e = t][0]) : t = e : e = t : e = t = 1, m = U.logPositive, null == m && (m = t > 0 || 0 === e), y = m ? e : -t, b = m ? t : -e, T > y && (y = T), T > b && (b = T) } function a() { function e() { g > d && (g = d); var e = X(l(d / g)), t = W(l(d / e)), i = e * t, n = (i - m) / 2, a = X(l(r - n)); c(a - r) && (a -= 1), f = -a * V; for (var s = a; o >= s - e; s += e) _.push(L(p, s)) } function t() { for (var e = i(h, 0), t = e + 2; t > e && a(e + 1) + n(e + 1) * C < r;) e++; for (var l = i(s, 0), t = l - 2; l > t && a(l - 1) + n(l - 1) * C > o;) l--; f = -(a(e) * S + n(e) * K); for (var d = e; l >= d; d++) { var c = a(d), m = n(d); _.push(L(10, c) * L(2, m)) } } function i(e, t) { return 3 * e + t } function n(e) { return e - 3 * a(e) } function a(e) { return X(l(e / 3)) } _ = []; var o = l(v(b) / V), r = l(v(y) / V), s = W(o), h = X(r), d = s - h, m = o - r; "exponent" === u ? e() : z >= d && g > z ? t() : e() } function o() { for (var e = [], t = 0, i = _.length; i > t; t++) e[t] = (m ? 1 : -1) * _[t]; !m && e.reverse(); var n = s(), a = n.value2Coord, o = a(e[0]), l = a(e[e.length - 1]); return o === l && (o -= 1, l += 1), { dataMin: o, dataMax: l, tickList: e, logPositive: m, labelFormatter: r(), dataMappingMethods: n } } function r() { if ("exponent" === u) { var e = p, t = V; return function(i) { if (!isFinite(parseFloat(i))) return ""; var n = ""; return 0 > i && (i = -i, n = "-"), n + e + d(v(i) / t) } } return function(e) { return isFinite(parseFloat(e)) ? x.addCommas(h(e)) : "" } } function s() { var e = m, t = f; return { value2Coord: function(i) { return null == i || isNaN(i) || !isFinite(i) ? i : (i = parseFloat(i), isFinite(i) ? e && T > i ? i = T : !e && i > -T && (i = -T) : i = T, i = w(i), (e ? 1 : -1) * (v(i) + t)) }, coord2Value: function(i) { return null == i || isNaN(i) || !isFinite(i) ? i : (i = parseFloat(i), isFinite(i) || (i = T), e ? L(I, i - t) : -L(I, -i + t)) } } } function l(e) { return +Number(+e).toFixed(14) } function h(e) { return Number(e).toFixed(15).replace(/\.?0*$/, "") } function d(e) { e = h(Math.round(e)); for (var t = [], i = 0, n = e.length; n > i; i++) { var a = e.charAt(i); t.push(A[a] || "") } return t.join("") } function c(e) { return e > -T && T > e } var m, p, u, V, U, g, f, y, b, _, x = e("./number"), k = Math, v = k.log, L = k.pow, w = k.abs, W = k.ceil, X = k.floor, I = k.E, S = k.LN10, K = k.LN2, C = K / S, T = 1e-9, E = 5, z = 2, A = { 0: "⁰", 1: "¹", 2: "²", 3: "³", 4: "⁴", 5: "⁵", 6: "⁶", 7: "⁷", 8: "⁸", 9: "⁹", "-": "⁻" }; return t });