Spaces:
Running
Running
| /* | |
| * 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 * as zrUtil from 'zrender/src/core/util'; | |
| import * as graphic from '../../util/graphic'; | |
| import AxisBuilder, {AxisBuilderCfg} from './AxisBuilder'; | |
| import AxisView from './AxisView'; | |
| import * as cartesianAxisHelper from '../../coord/cartesian/cartesianAxisHelper'; | |
| import {rectCoordAxisBuildSplitArea, rectCoordAxisHandleRemove} from './axisSplitHelper'; | |
| import GlobalModel from '../../model/Global'; | |
| import ExtensionAPI from '../../core/ExtensionAPI'; | |
| import CartesianAxisModel from '../../coord/cartesian/AxisModel'; | |
| import GridModel from '../../coord/cartesian/GridModel'; | |
| import { Payload } from '../../util/types'; | |
| import { isIntervalOrLogScale } from '../../scale/helper'; | |
| const axisBuilderAttrs = [ | |
| 'axisLine', 'axisTickLabel', 'axisName' | |
| ] as const; | |
| const selfBuilderAttrs = [ | |
| 'splitArea', 'splitLine', 'minorSplitLine' | |
| ] as const; | |
| class CartesianAxisView extends AxisView { | |
| static type = 'cartesianAxis'; | |
| type = CartesianAxisView.type; | |
| axisPointerClass = 'CartesianAxisPointer'; | |
| private _axisGroup: graphic.Group; | |
| /** | |
| * @override | |
| */ | |
| render(axisModel: CartesianAxisModel, ecModel: GlobalModel, api: ExtensionAPI, payload: Payload) { | |
| this.group.removeAll(); | |
| const oldAxisGroup = this._axisGroup; | |
| this._axisGroup = new graphic.Group(); | |
| this.group.add(this._axisGroup); | |
| if (!axisModel.get('show')) { | |
| return; | |
| } | |
| const gridModel = axisModel.getCoordSysModel(); | |
| const layout = cartesianAxisHelper.layout(gridModel, axisModel); | |
| const axisBuilder = new AxisBuilder(axisModel, zrUtil.extend({ | |
| handleAutoShown(elementType) { | |
| const cartesians = gridModel.coordinateSystem.getCartesians(); | |
| for (let i = 0; i < cartesians.length; i++) { | |
| if (isIntervalOrLogScale(cartesians[i].getOtherAxis(axisModel.axis).scale)) { | |
| // Still show axis tick or axisLine if other axis is value / log | |
| return true; | |
| } | |
| } | |
| // Not show axisTick or axisLine if other axis is category / time | |
| return false; | |
| } | |
| } as AxisBuilderCfg, layout)); | |
| zrUtil.each(axisBuilderAttrs, axisBuilder.add, axisBuilder); | |
| this._axisGroup.add(axisBuilder.getGroup()); | |
| zrUtil.each(selfBuilderAttrs, function (name) { | |
| if (axisModel.get([name, 'show'])) { | |
| axisElementBuilders[name](this, this._axisGroup, axisModel, gridModel); | |
| } | |
| }, this); | |
| // THIS is a special case for bar racing chart. | |
| // Update the axis label from the natural initial layout to | |
| // sorted layout should has no animation. | |
| const isInitialSortFromBarRacing = payload && payload.type === 'changeAxisOrder' && payload.isInitSort; | |
| if (!isInitialSortFromBarRacing) { | |
| graphic.groupTransition(oldAxisGroup, this._axisGroup, axisModel); | |
| } | |
| super.render(axisModel, ecModel, api, payload); | |
| } | |
| remove() { | |
| rectCoordAxisHandleRemove(this); | |
| } | |
| } | |
| interface AxisElementBuilder { | |
| (axisView: CartesianAxisView, axisGroup: graphic.Group, axisModel: CartesianAxisModel, gridModel: GridModel): void | |
| } | |
| const axisElementBuilders: Record<typeof selfBuilderAttrs[number], AxisElementBuilder> = { | |
| splitLine(axisView, axisGroup, axisModel, gridModel) { | |
| const axis = axisModel.axis; | |
| if (axis.scale.isBlank()) { | |
| return; | |
| } | |
| const splitLineModel = axisModel.getModel('splitLine'); | |
| const lineStyleModel = splitLineModel.getModel('lineStyle'); | |
| let lineColors = lineStyleModel.get('color'); | |
| lineColors = zrUtil.isArray(lineColors) ? lineColors : [lineColors]; | |
| const gridRect = gridModel.coordinateSystem.getRect(); | |
| const isHorizontal = axis.isHorizontal(); | |
| let lineCount = 0; | |
| const ticksCoords = axis.getTicksCoords({ | |
| tickModel: splitLineModel | |
| }); | |
| const p1 = []; | |
| const p2 = []; | |
| const lineStyle = lineStyleModel.getLineStyle(); | |
| for (let i = 0; i < ticksCoords.length; i++) { | |
| const tickCoord = axis.toGlobalCoord(ticksCoords[i].coord); | |
| if (isHorizontal) { | |
| p1[0] = tickCoord; | |
| p1[1] = gridRect.y; | |
| p2[0] = tickCoord; | |
| p2[1] = gridRect.y + gridRect.height; | |
| } | |
| else { | |
| p1[0] = gridRect.x; | |
| p1[1] = tickCoord; | |
| p2[0] = gridRect.x + gridRect.width; | |
| p2[1] = tickCoord; | |
| } | |
| const colorIndex = (lineCount++) % lineColors.length; | |
| const tickValue = ticksCoords[i].tickValue; | |
| const line = new graphic.Line({ | |
| anid: tickValue != null ? 'line_' + ticksCoords[i].tickValue : null, | |
| autoBatch: true, | |
| shape: { | |
| x1: p1[0], | |
| y1: p1[1], | |
| x2: p2[0], | |
| y2: p2[1] | |
| }, | |
| style: zrUtil.defaults({ | |
| stroke: lineColors[colorIndex] | |
| }, lineStyle), | |
| silent: true | |
| }); | |
| graphic.subPixelOptimizeLine(line.shape, lineStyle.lineWidth); | |
| axisGroup.add(line); | |
| } | |
| }, | |
| minorSplitLine(axisView, axisGroup, axisModel, gridModel) { | |
| const axis = axisModel.axis; | |
| const minorSplitLineModel = axisModel.getModel('minorSplitLine'); | |
| const lineStyleModel = minorSplitLineModel.getModel('lineStyle'); | |
| const gridRect = gridModel.coordinateSystem.getRect(); | |
| const isHorizontal = axis.isHorizontal(); | |
| const minorTicksCoords = axis.getMinorTicksCoords(); | |
| if (!minorTicksCoords.length) { | |
| return; | |
| } | |
| const p1 = []; | |
| const p2 = []; | |
| const lineStyle = lineStyleModel.getLineStyle(); | |
| for (let i = 0; i < minorTicksCoords.length; i++) { | |
| for (let k = 0; k < minorTicksCoords[i].length; k++) { | |
| const tickCoord = axis.toGlobalCoord(minorTicksCoords[i][k].coord); | |
| if (isHorizontal) { | |
| p1[0] = tickCoord; | |
| p1[1] = gridRect.y; | |
| p2[0] = tickCoord; | |
| p2[1] = gridRect.y + gridRect.height; | |
| } | |
| else { | |
| p1[0] = gridRect.x; | |
| p1[1] = tickCoord; | |
| p2[0] = gridRect.x + gridRect.width; | |
| p2[1] = tickCoord; | |
| } | |
| const line = new graphic.Line({ | |
| anid: 'minor_line_' + minorTicksCoords[i][k].tickValue, | |
| autoBatch: true, | |
| shape: { | |
| x1: p1[0], | |
| y1: p1[1], | |
| x2: p2[0], | |
| y2: p2[1] | |
| }, | |
| style: lineStyle, | |
| silent: true | |
| }); | |
| graphic.subPixelOptimizeLine(line.shape, lineStyle.lineWidth); | |
| axisGroup.add(line); | |
| } | |
| } | |
| }, | |
| splitArea(axisView, axisGroup, axisModel, gridModel) { | |
| rectCoordAxisBuildSplitArea(axisView, axisGroup, axisModel, gridModel); | |
| } | |
| }; | |
| export class CartesianXAxisView extends CartesianAxisView { | |
| static type = 'xAxis'; | |
| type = CartesianXAxisView.type; | |
| } | |
| export class CartesianYAxisView extends CartesianAxisView { | |
| static type = 'yAxis'; | |
| type = CartesianXAxisView.type; | |
| } | |
| export default CartesianAxisView; | |