123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174 |
- /*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
- var zrUtil = require("zrender/lib/core/util");
- var numberUtil = require("../../util/number");
- /*
- * Licensed to the Apache Software Foundation (ASF) under one
- * or more contributor license agreements. See the NOTICE file
- * distributed with this work for additional information
- * regarding copyright ownership. The ASF licenses this file
- * to you under the Apache License, Version 2.0 (the
- * "License"); you may not use this file except in compliance
- * with the License. You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing,
- * software distributed under the License is distributed on an
- * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
- * KIND, either express or implied. See the License for the
- * specific language governing permissions and limitations
- * under the License.
- */
- function _default(ecModel, api) {
- ecModel.eachSeriesByType('themeRiver', function (seriesModel) {
- var data = seriesModel.getData();
- var single = seriesModel.coordinateSystem;
- var layoutInfo = {}; // use the axis boundingRect for view
- var rect = single.getRect();
- layoutInfo.rect = rect;
- var boundaryGap = seriesModel.get('boundaryGap');
- var axis = single.getAxis();
- layoutInfo.boundaryGap = boundaryGap;
- if (axis.orient === 'horizontal') {
- boundaryGap[0] = numberUtil.parsePercent(boundaryGap[0], rect.height);
- boundaryGap[1] = numberUtil.parsePercent(boundaryGap[1], rect.height);
- var height = rect.height - boundaryGap[0] - boundaryGap[1];
- themeRiverLayout(data, seriesModel, height);
- } else {
- boundaryGap[0] = numberUtil.parsePercent(boundaryGap[0], rect.width);
- boundaryGap[1] = numberUtil.parsePercent(boundaryGap[1], rect.width);
- var width = rect.width - boundaryGap[0] - boundaryGap[1];
- themeRiverLayout(data, seriesModel, width);
- }
- data.setLayout('layoutInfo', layoutInfo);
- });
- }
- /**
- * The layout information about themeriver
- *
- * @param {module:echarts/data/List} data data in the series
- * @param {module:echarts/model/Series} seriesModel the model object of themeRiver series
- * @param {number} height value used to compute every series height
- */
- function themeRiverLayout(data, seriesModel, height) {
- if (!data.count()) {
- return;
- }
- var coordSys = seriesModel.coordinateSystem; // the data in each layer are organized into a series.
- var layerSeries = seriesModel.getLayerSeries(); // the points in each layer.
- var timeDim = data.mapDimension('single');
- var valueDim = data.mapDimension('value');
- var layerPoints = zrUtil.map(layerSeries, function (singleLayer) {
- return zrUtil.map(singleLayer.indices, function (idx) {
- var pt = coordSys.dataToPoint(data.get(timeDim, idx));
- pt[1] = data.get(valueDim, idx);
- return pt;
- });
- });
- var base = computeBaseline(layerPoints);
- var baseLine = base.y0;
- var ky = height / base.max; // set layout information for each item.
- var n = layerSeries.length;
- var m = layerSeries[0].indices.length;
- var baseY0;
- for (var j = 0; j < m; ++j) {
- baseY0 = baseLine[j] * ky;
- data.setItemLayout(layerSeries[0].indices[j], {
- layerIndex: 0,
- x: layerPoints[0][j][0],
- y0: baseY0,
- y: layerPoints[0][j][1] * ky
- });
- for (var i = 1; i < n; ++i) {
- baseY0 += layerPoints[i - 1][j][1] * ky;
- data.setItemLayout(layerSeries[i].indices[j], {
- layerIndex: i,
- x: layerPoints[i][j][0],
- y0: baseY0,
- y: layerPoints[i][j][1] * ky
- });
- }
- }
- }
- /**
- * Compute the baseLine of the rawdata
- * Inspired by Lee Byron's paper Stacked Graphs - Geometry & Aesthetics
- *
- * @param {Array.<Array>} data the points in each layer
- * @return {Object}
- */
- function computeBaseline(data) {
- var layerNum = data.length;
- var pointNum = data[0].length;
- var sums = [];
- var y0 = [];
- var max = 0;
- var temp;
- var base = {};
- for (var i = 0; i < pointNum; ++i) {
- for (var j = 0, temp = 0; j < layerNum; ++j) {
- temp += data[j][i][1];
- }
- if (temp > max) {
- max = temp;
- }
- sums.push(temp);
- }
- for (var k = 0; k < pointNum; ++k) {
- y0[k] = (max - sums[k]) / 2;
- }
- max = 0;
- for (var l = 0; l < pointNum; ++l) {
- var sum = sums[l] + y0[l];
- if (sum > max) {
- max = sum;
- }
- }
- base.y0 = y0;
- base.max = max;
- return base;
- }
- module.exports = _default;
|