echarts categoryVisual 源码
echarts categoryVisual 代码
文件路径:/src/chart/graph/categoryVisual.ts
/*
* 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 GlobalModel from '../../model/Global';
import GraphSeriesModel, { GraphNodeItemOption } from './GraphSeries';
import { Dictionary, ColorString } from '../../util/types';
import { extend, isString } from 'zrender/src/core/util';
export default function categoryVisual(ecModel: GlobalModel) {
const paletteScope: Dictionary<ColorString> = {};
ecModel.eachSeriesByType('graph', function (seriesModel: GraphSeriesModel) {
const categoriesData = seriesModel.getCategoriesData();
const data = seriesModel.getData();
const categoryNameIdxMap: Dictionary<number> = {};
categoriesData.each(function (idx) {
const name = categoriesData.getName(idx);
// Add prefix to avoid conflict with Object.prototype.
categoryNameIdxMap['ec-' + name] = idx;
const itemModel = categoriesData.getItemModel<GraphNodeItemOption>(idx);
const style = itemModel.getModel('itemStyle').getItemStyle();
if (!style.fill) {
// Get color from palette.
style.fill = seriesModel.getColorFromPalette(name, paletteScope);
}
categoriesData.setItemVisual(idx, 'style', style);
const symbolVisualList = ['symbol', 'symbolSize', 'symbolKeepAspect'] as const;
for (let i = 0; i < symbolVisualList.length; i++) {
const symbolVisual = itemModel.getShallow(symbolVisualList[i], true);
if (symbolVisual != null) {
categoriesData.setItemVisual(idx, symbolVisualList[i], symbolVisual);
}
}
});
// Assign category color to visual
if (categoriesData.count()) {
data.each(function (idx) {
const model = data.getItemModel<GraphNodeItemOption>(idx);
let categoryIdx = model.getShallow('category');
if (categoryIdx != null) {
if (isString(categoryIdx)) {
categoryIdx = categoryNameIdxMap['ec-' + categoryIdx];
}
const categoryStyle = categoriesData.getItemVisual(categoryIdx, 'style');
const style = data.ensureUniqueItemVisual(idx, 'style');
extend(style, categoryStyle);
const visualList = ['symbol', 'symbolSize', 'symbolKeepAspect'] as const;
for (let i = 0; i < visualList.length; i++) {
data.setItemVisual(
idx, visualList[i],
categoriesData.getItemVisual(categoryIdx, visualList[i])
);
}
}
});
}
});
}
相关信息
相关文章
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦