echarts GeoView 源码
echarts GeoView 代码
文件路径:/src/component/geo/GeoView.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 MapDraw from '../helper/MapDraw';
import ComponentView from '../../view/Component';
import GlobalModel from '../../model/Global';
import ExtensionAPI from '../../core/ExtensionAPI';
import GeoModel from '../../coord/geo/GeoModel';
import { Payload, ZRElementEvent, ECEventData } from '../../util/types';
import { getECData } from '../../util/innerStore';
import { findEventDispatcher } from '../../util/event';
import Element from 'zrender/src/Element';
class GeoView extends ComponentView {
static type = 'geo' as const;
readonly type = GeoView.type;
private _mapDraw: MapDraw;
private _api: ExtensionAPI;
private _model: GeoModel;
focusBlurEnabled = true;
init(ecModel: GlobalModel, api: ExtensionAPI) {
this._api = api;
}
render(
geoModel: GeoModel, ecModel: GlobalModel, api: ExtensionAPI, payload: Payload
): void {
this._model = geoModel;
if (!geoModel.get('show')) {
this._mapDraw && this._mapDraw.remove();
this._mapDraw = null;
return;
}
if (!this._mapDraw) {
this._mapDraw = new MapDraw(api);
}
const mapDraw = this._mapDraw;
mapDraw.draw(geoModel, ecModel, api, this, payload);
mapDraw.group.on('click', this._handleRegionClick, this);
mapDraw.group.silent = geoModel.get('silent');
this.group.add(mapDraw.group);
this.updateSelectStatus(geoModel, ecModel, api);
}
private _handleRegionClick(e: ZRElementEvent) {
let eventData: ECEventData;
findEventDispatcher(e.target, current => {
return (eventData = getECData(current).eventData) != null;
}, true);
if (eventData) {
this._api.dispatchAction({
type: 'geoToggleSelect',
geoId: this._model.id,
name: eventData.name
});
}
}
updateSelectStatus(model: GeoModel, ecModel: GlobalModel, api: ExtensionAPI) {
this._mapDraw.group.traverse((node) => {
const eventData = getECData(node).eventData;
if (eventData) {
this._model.isSelected(eventData.name)
? api.enterSelect(node) : api.leaveSelect(node);
// No need to traverse children.
return true;
}
});
}
findHighDownDispatchers(name: string): Element[] {
return this._mapDraw && this._mapDraw.findHighDownDispatchers(name, this._model);
}
dispose(): void {
this._mapDraw && this._mapDraw.remove();
}
}
export default GeoView;
相关信息
相关文章
0
赞
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦