216 lines
7.2 KiB
JavaScript
216 lines
7.2 KiB
JavaScript
|
||
/*
|
||
* 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.
|
||
*/
|
||
|
||
|
||
/**
|
||
* AUTO-GENERATED FILE. DO NOT MODIFY.
|
||
*/
|
||
|
||
/*
|
||
* 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.
|
||
*/
|
||
import { __extends } from "tslib";
|
||
import createSeriesDataSimply from '../helper/createSeriesDataSimply.js';
|
||
import * as zrUtil from 'zrender/lib/core/util.js';
|
||
import * as modelUtil from '../../util/model.js';
|
||
import { getPercentSeats } from '../../util/number.js';
|
||
import { makeSeriesEncodeForNameBased } from '../../data/helper/sourceHelper.js';
|
||
import LegendVisualProvider from '../../visual/LegendVisualProvider.js';
|
||
import SeriesModel from '../../model/Series.js';
|
||
var innerData = modelUtil.makeInner();
|
||
var PieSeriesModel = /** @class */function (_super) {
|
||
__extends(PieSeriesModel, _super);
|
||
function PieSeriesModel() {
|
||
return _super !== null && _super.apply(this, arguments) || this;
|
||
}
|
||
/**
|
||
* @overwrite
|
||
*/
|
||
PieSeriesModel.prototype.init = function (option) {
|
||
_super.prototype.init.apply(this, arguments);
|
||
// Enable legend selection for each data item
|
||
// Use a function instead of direct access because data reference may changed
|
||
this.legendVisualProvider = new LegendVisualProvider(zrUtil.bind(this.getData, this), zrUtil.bind(this.getRawData, this));
|
||
this._defaultLabelLine(option);
|
||
};
|
||
/**
|
||
* @overwrite
|
||
*/
|
||
PieSeriesModel.prototype.mergeOption = function () {
|
||
_super.prototype.mergeOption.apply(this, arguments);
|
||
};
|
||
/**
|
||
* @overwrite
|
||
*/
|
||
PieSeriesModel.prototype.getInitialData = function () {
|
||
return createSeriesDataSimply(this, {
|
||
coordDimensions: ['value'],
|
||
encodeDefaulter: zrUtil.curry(makeSeriesEncodeForNameBased, this)
|
||
});
|
||
};
|
||
/**
|
||
* @overwrite
|
||
*/
|
||
PieSeriesModel.prototype.getDataParams = function (dataIndex) {
|
||
var data = this.getData();
|
||
// update seats when data is changed
|
||
var dataInner = innerData(data);
|
||
var seats = dataInner.seats;
|
||
if (!seats) {
|
||
var valueList_1 = [];
|
||
data.each(data.mapDimension('value'), function (value) {
|
||
valueList_1.push(value);
|
||
});
|
||
seats = dataInner.seats = getPercentSeats(valueList_1, data.hostModel.get('percentPrecision'));
|
||
}
|
||
var params = _super.prototype.getDataParams.call(this, dataIndex);
|
||
// seats may be empty when sum is 0
|
||
params.percent = seats[dataIndex] || 0;
|
||
params.$vars.push('percent');
|
||
return params;
|
||
};
|
||
PieSeriesModel.prototype._defaultLabelLine = function (option) {
|
||
// Extend labelLine emphasis
|
||
modelUtil.defaultEmphasis(option, 'labelLine', ['show']);
|
||
var labelLineNormalOpt = option.labelLine;
|
||
var labelLineEmphasisOpt = option.emphasis.labelLine;
|
||
// Not show label line if `label.normal.show = false`
|
||
labelLineNormalOpt.show = labelLineNormalOpt.show && option.label.show;
|
||
labelLineEmphasisOpt.show = labelLineEmphasisOpt.show && option.emphasis.label.show;
|
||
};
|
||
PieSeriesModel.type = 'series.pie';
|
||
PieSeriesModel.defaultOption = {
|
||
// zlevel: 0,
|
||
z: 2,
|
||
legendHoverLink: true,
|
||
colorBy: 'data',
|
||
// 默认全局居中
|
||
center: ['50%', '50%'],
|
||
radius: [0, '75%'],
|
||
// 默认顺时针
|
||
clockwise: true,
|
||
startAngle: 90,
|
||
endAngle: 'auto',
|
||
padAngle: 0,
|
||
// 最小角度改为0
|
||
minAngle: 0,
|
||
// If the angle of a sector less than `minShowLabelAngle`,
|
||
// the label will not be displayed.
|
||
minShowLabelAngle: 0,
|
||
// 选中时扇区偏移量
|
||
selectedOffset: 10,
|
||
// 选择模式,默认关闭,可选single,multiple
|
||
// selectedMode: false,
|
||
// 南丁格尔玫瑰图模式,'radius'(半径) | 'area'(面积)
|
||
// roseType: null,
|
||
percentPrecision: 2,
|
||
// If still show when all data zero.
|
||
stillShowZeroSum: true,
|
||
// cursor: null,
|
||
left: 0,
|
||
top: 0,
|
||
right: 0,
|
||
bottom: 0,
|
||
width: null,
|
||
height: null,
|
||
label: {
|
||
// color: 'inherit',
|
||
// If rotate around circle
|
||
rotate: 0,
|
||
show: true,
|
||
overflow: 'truncate',
|
||
// 'outer', 'inside', 'center'
|
||
position: 'outer',
|
||
// 'none', 'labelLine', 'edge'. Works only when position is 'outer'
|
||
alignTo: 'none',
|
||
// Closest distance between label and chart edge.
|
||
// Works only position is 'outer' and alignTo is 'edge'.
|
||
edgeDistance: '25%',
|
||
// Works only position is 'outer' and alignTo is not 'edge'.
|
||
bleedMargin: 10,
|
||
// Distance between text and label line.
|
||
distanceToLabelLine: 5
|
||
// formatter: 标签文本格式器,同 tooltip.formatter,不支持异步回调
|
||
// 默认使用全局文本样式,详见 textStyle
|
||
// distance: 当position为inner时有效,为label位置到圆心的距离与圆半径(环状图为内外半径和)的比例系数
|
||
},
|
||
|
||
// Enabled when label.normal.position is 'outer'
|
||
labelLine: {
|
||
show: true,
|
||
// 引导线两段中的第一段长度
|
||
length: 15,
|
||
// 引导线两段中的第二段长度
|
||
length2: 15,
|
||
smooth: false,
|
||
minTurnAngle: 90,
|
||
maxSurfaceAngle: 90,
|
||
lineStyle: {
|
||
// color: 各异,
|
||
width: 1,
|
||
type: 'solid'
|
||
}
|
||
},
|
||
itemStyle: {
|
||
borderWidth: 1,
|
||
borderJoin: 'round'
|
||
},
|
||
showEmptyCircle: true,
|
||
emptyCircleStyle: {
|
||
color: 'lightgray',
|
||
opacity: 1
|
||
},
|
||
labelLayout: {
|
||
// Hide the overlapped label.
|
||
hideOverlap: true
|
||
},
|
||
emphasis: {
|
||
scale: true,
|
||
scaleSize: 5
|
||
},
|
||
// If use strategy to avoid label overlapping
|
||
avoidLabelOverlap: true,
|
||
// Animation type. Valid values: expansion, scale
|
||
animationType: 'expansion',
|
||
animationDuration: 1000,
|
||
// Animation type when update. Valid values: transition, expansion
|
||
animationTypeUpdate: 'transition',
|
||
animationEasingUpdate: 'cubicInOut',
|
||
animationDurationUpdate: 500,
|
||
animationEasing: 'cubicInOut'
|
||
};
|
||
return PieSeriesModel;
|
||
}(SeriesModel);
|
||
export default PieSeriesModel; |