Skip to content

Commit

Permalink
Merge pull request #16589 from apache/master
Browse files Browse the repository at this point in the history
Merge master into release for 5.3.1
  • Loading branch information
Ovilia authored Feb 28, 2022
2 parents 0878d30 + fdf5490 commit d2b73b9
Show file tree
Hide file tree
Showing 37 changed files with 1,241 additions and 164 deletions.
4 changes: 2 additions & 2 deletions src/chart/bar/BarSeries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ import {
SeriesSamplingOptionMixin,
SeriesLabelOption,
SeriesEncodeOptionMixin,
DefaultStatesMixinEmpasis,
DefaultStatesMixinEmphasis,
CallbackDataParams
} from '../../util/types';
import type Cartesian2D from '../../coord/cartesian/Cartesian2D';
Expand All @@ -49,7 +49,7 @@ export interface BarStateOption<TCbParams = never> {
}

interface BarStatesMixin {
emphasis?: DefaultStatesMixinEmpasis
emphasis?: DefaultStatesMixinEmphasis
}

export interface BarItemStyleOption<TCbParams = never> extends ItemStyleOption<TCbParams> {
Expand Down
2 changes: 1 addition & 1 deletion src/chart/bar/PictorialBarView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -416,7 +416,7 @@ function prepareLineWidth(
valueLineWidth *= symbolScale[opt.valueDim.index];
}

outputSymbolMeta.valueLineWidth = valueLineWidth;
outputSymbolMeta.valueLineWidth = valueLineWidth || 0;
}

function prepareLayoutInfo(
Expand Down
4 changes: 2 additions & 2 deletions src/chart/funnel/FunnelSeries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ import {
VerticalAlign,
SeriesLabelOption,
SeriesEncodeOptionMixin,
DefaultStatesMixinEmpasis,
DefaultStatesMixinEmphasis,
CallbackDataParams
} from '../../util/types';
import GlobalModel from '../../model/Global';
Expand All @@ -49,7 +49,7 @@ type FunnelLabelOption = Omit<SeriesLabelOption, 'position'> & {
};

interface FunnelStatesMixin {
emphasis?: DefaultStatesMixinEmpasis
emphasis?: DefaultStatesMixinEmphasis
}

export interface FunnelCallbackDataParams extends CallbackDataParams {
Expand Down
4 changes: 2 additions & 2 deletions src/chart/gauge/GaugeSeries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@ import {
OptionDataValueNumeric,
StatesOptionMixin,
SeriesEncodeOptionMixin,
DefaultStatesMixinEmpasis,
DefaultStatesMixinEmphasis,
CallbackDataParams
} from '../../util/types';
import GlobalModel from '../../model/Global';
Expand Down Expand Up @@ -105,7 +105,7 @@ interface DetailOption extends LabelOption {
}

interface GaugeStatesMixin {
emphasis?: DefaultStatesMixinEmpasis
emphasis?: DefaultStatesMixinEmphasis
}
export interface GaugeStateOption<TCbParams = never> {
itemStyle?: ItemStyleOption<TCbParams>
Expand Down
8 changes: 5 additions & 3 deletions src/chart/heatmap/HeatmapSeries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ import {
StatesOptionMixin,
SeriesEncodeOptionMixin,
SeriesOnCalendarOptionMixin,
DefaultStatesMixinEmpasis,
DefaultStatesMixinEmphasis,
CallbackDataParams
} from '../../util/types';
import GlobalModel from '../../model/Global';
Expand All @@ -43,12 +43,14 @@ type HeatmapDataValue = OptionDataValue[];

export interface HeatmapStateOption<TCbParams = never> {
// Available on cartesian2d coordinate system
itemStyle?: ItemStyleOption<TCbParams>
itemStyle?: ItemStyleOption<TCbParams> & {
borderRadius?: number | number[]
}
label?: SeriesLabelOption
}

interface FunnelStatesMixin {
emphasis?: DefaultStatesMixinEmpasis
emphasis?: DefaultStatesMixinEmphasis
}
export interface HeatmapDataItemOption extends HeatmapStateOption,
StatesOptionMixin<HeatmapStateOption, FunnelStatesMixin> {
Expand Down
13 changes: 11 additions & 2 deletions src/chart/heatmap/HeatmapView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,7 @@ class HeatmapView extends ChartView {
let emphasisStyle = seriesModel.getModel(['emphasis', 'itemStyle']).getItemStyle();
let blurStyle = seriesModel.getModel(['blur', 'itemStyle']).getItemStyle();
let selectStyle = seriesModel.getModel(['select', 'itemStyle']).getItemStyle();
let borderRadius = seriesModel.get(['itemStyle', 'borderRadius']);
let labelStatesModels = getLabelStatesModels(seriesModel);
const emphasisModel = seriesModel.getModel('emphasis');
let focus = emphasisModel.get('focus');
Expand Down Expand Up @@ -268,22 +269,30 @@ class HeatmapView extends ChartView {
});
}

const itemModel = data.getItemModel<HeatmapDataItemOption>(idx);

// Optimization for large datset
if (data.hasItemOption) {
const itemModel = data.getItemModel<HeatmapDataItemOption>(idx);
const emphasisModel = itemModel.getModel('emphasis');
emphasisStyle = emphasisModel.getModel('itemStyle').getItemStyle();
blurStyle = itemModel.getModel(['blur', 'itemStyle']).getItemStyle();
selectStyle = itemModel.getModel(['select', 'itemStyle']).getItemStyle();

// Each item value struct in the data would be firstly
// {
// itemStyle: { borderRadius: [30, 30] },
// value: [2022, 02, 22]
// }
borderRadius = itemModel.get(['itemStyle', 'borderRadius']);

focus = emphasisModel.get('focus');
blurScope = emphasisModel.get('blurScope');
emphasisDisabled = emphasisModel.get('disabled');

labelStatesModels = getLabelStatesModels(itemModel);
}

rect.shape.r = borderRadius;

const rawValue = seriesModel.getRawValue(idx) as OptionDataValue[];
let defaultText = '-';
if (rawValue && rawValue[2] != null) {
Expand Down
64 changes: 34 additions & 30 deletions src/chart/helper/EffectLine.ts
Original file line number Diff line number Diff line change
Expand Up @@ -117,8 +117,6 @@ class EffectLine extends graphic.Group {
return;
}

const self = this;

const points = lineData.getItemLayout(idx);

let period = effectModel.get('period') * 1000;
Expand All @@ -138,42 +136,48 @@ class EffectLine extends graphic.Group {
}

if (period !== this._period || loop !== this._loop) {

symbol.stopAnimation();

if (period > 0) {
let delayNum: number;
if (zrUtil.isFunction(delayExpr)) {
delayNum = delayExpr(idx);
}
else {
delayNum = delayExpr;
}
if (symbol.__t > 0) {
delayNum = -period * symbol.__t;
}
symbol.__t = 0;
const animator = symbol.animate('', loop)
.when(period, {
__t: 1
})
.delay(delayNum)
.during(function () {
self._updateSymbolPosition(symbol);
});
if (!loop) {
animator.done(function () {
self.remove(symbol);
});
}
animator.start();
let delayNum: number;
if (zrUtil.isFunction(delayExpr)) {
delayNum = delayExpr(idx);
}
else {
delayNum = delayExpr;
}
if (symbol.__t > 0) {
delayNum = -period * symbol.__t;
}

this._animateSymbol(
symbol, period, delayNum, loop
);
}

this._period = period;
this._loop = loop;
}

private _animateSymbol(symbol: ECSymbolOnEffectLine, period: number, delayNum: number, loop: boolean) {
if (period > 0) {
symbol.__t = 0;
const self = this;
const animator = symbol.animate('', loop)
.when(period, {
__t: 1
})
.delay(delayNum)
.during(function () {
self._updateSymbolPosition(symbol);
});
if (!loop) {
animator.done(function () {
self.remove(symbol);
});
}
animator.start();
}
}

protected _getLineLength(symbol: ECSymbolOnEffectLine) {
// Not so accurate
return (vec2.dist(symbol.__p1, symbol.__cp1)
Expand Down
10 changes: 3 additions & 7 deletions src/chart/helper/Symbol.ts
Original file line number Diff line number Diff line change
Expand Up @@ -23,14 +23,15 @@ import {getECData} from '../../util/innerStore';
import { enterEmphasis, leaveEmphasis, toggleHoverEmphasis } from '../../util/states';
import {getDefaultLabel} from './labelHelper';
import SeriesData from '../../data/SeriesData';
import { ColorString, BlurScope, AnimationOption, ZRColor } from '../../util/types';
import { ColorString, BlurScope, AnimationOption, ZRColor, AnimationOptionMixin } from '../../util/types';
import SeriesModel from '../../model/Series';
import { PathProps } from 'zrender/src/graphic/Path';
import { SymbolDrawSeriesScope, SymbolDrawItemModelOption } from './SymbolDraw';
import { extend } from 'zrender/src/core/util';
import { setLabelStyle, getLabelStatesModels } from '../../label/labelStyle';
import ZRImage from 'zrender/src/graphic/Image';
import { saveOldStyle } from '../../animation/basicTrasition';
import Model from '../../model/Model';

type ECSymbol = ReturnType<typeof createSymbol>;

Expand All @@ -43,8 +44,6 @@ interface SymbolOpts {

class Symbol extends graphic.Group {

private _seriesModel: SeriesModel;

private _symbolType: string;

/**
Expand Down Expand Up @@ -201,8 +200,6 @@ class Symbol extends graphic.Group {
// Must stop leave transition manually if don't call initProps or updateProps.
this.childAt(0).stopAnimation('leave');
}

this._seriesModel = seriesModel;
}

_updateCommon(
Expand Down Expand Up @@ -353,12 +350,11 @@ class Symbol extends graphic.Group {
this.scaleX = this.scaleY = scale;
}

fadeOut(cb: () => void, opt?: {
fadeOut(cb: () => void, seriesModel: Model<AnimationOptionMixin>, opt?: {
fadeLabel: boolean,
animation?: AnimationOption
}) {
const symbolPath = this.childAt(0) as ECSymbol;
const seriesModel = this._seriesModel;
const dataIndex = getECData(this).dataIndex;
const animationOpt = opt && opt.animation;
// Avoid mistaken hover when fading out
Expand Down
7 changes: 4 additions & 3 deletions src/chart/helper/SymbolDraw.ts
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ import Model from '../../model/Model';
import { ScatterSeriesOption } from '../scatter/ScatterSeries';
import { getLabelStatesModels } from '../../label/labelStyle';
import Element from 'zrender/src/Element';
import SeriesModel from '../../model/Series';

interface UpdateOpt {
isIgnore?(idx: number): boolean
Expand All @@ -51,7 +52,7 @@ interface UpdateOpt {

interface SymbolLike extends graphic.Group {
updateData(data: SeriesData, idx: number, scope?: SymbolDrawSeriesScope, opt?: UpdateOpt): void
fadeOut?(cb: () => void): void
fadeOut?(cb: () => void, seriesModel: SeriesModel): void
}

interface SymbolLikeCtor {
Expand Down Expand Up @@ -252,7 +253,7 @@ class SymbolDraw {
const el = oldData.getItemGraphicEl(oldIdx) as SymbolLike;
el && el.fadeOut(function () {
group.remove(el);
});
}, seriesModel as SeriesModel);
})
.execute();

Expand Down Expand Up @@ -319,7 +320,7 @@ class SymbolDraw {
data.eachItemGraphicEl(function (el: SymbolLike) {
el.fadeOut(function () {
group.remove(el);
});
}, data.hostModel as SeriesModel);
});
}
else {
Expand Down
Loading

0 comments on commit d2b73b9

Please sign in to comment.