Skip to content

Commit

Permalink
fix: fix the transpose color gradient render (#5809)
Browse files Browse the repository at this point in the history
* fix: fix the gradient color render when set transpose

* fix: fix the render deg

* fix: add test case and snapshot

---------

Co-authored-by: root <[email protected]>
  • Loading branch information
Runtus and root authored Nov 17, 2023
1 parent 8b9fe81 commit 291f0af
Show file tree
Hide file tree
Showing 8 changed files with 3,311 additions and 6 deletions.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
2 changes: 2 additions & 0 deletions __tests__/plots/static/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,7 @@ export { temperatureCompareAreaDifference } from './temperature-compare-area-dif
export { populationByStateAreaNormalizeStacked } from './population-by-state-area-normalize-stacked';
export { temperature1LineVarColor } from './temperature1-line-var-color';
export { temperature2LineGradientColor } from './temperature2-line-gradient-color';
export { temperature2LineGradientColorTranspose } from './temperature2-line-gradient-color-transpose';
export { temperature2LineThreshold } from './temperature2-line-threshold';
export { aapl2CandlestickChart } from './aapl2-candlestick-chart';
export { tranLineMultiAxes } from './train-line-multi-axes';
Expand All @@ -89,6 +90,7 @@ export { seasonalWeatherAreaRadial } from './seasonal-weather-area-radial';
export { worldHistoryIntervalMultiTickCount } from './world-history-interval-multi-tick-count';
export { stocksAreaGradient } from './stocks-area-gradient';
export { temperatures3AreaBandGradient } from './temperatures3-area-band-gradient';
export { temperatures3AreaBandGradientTranspose } from './temperatures3-area-band-gradient-transpose';
export { vaccinesCellScaleRelation } from './vaccines-cell-scale-relation';
export { settleWeatherCellGrouped } from './seattle-weather-cell-grouped';
export { commitsPointGrouped } from './commits-point-grouped';
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import { G2Spec } from '../../../src';

export function temperature2LineGradientColorTranspose(): G2Spec {
return {
type: 'line',
height: 1000,
data: {
type: 'fetch',
value: 'data/temperatures2.csv',
},
scale: {
y: { nice: true },
x: { utc: true },
color: { palette: 'turbo' },
},
legend: false,
coordinate: { transform: [{ type: 'transpose' }] },
encode: {
x: 'date',
y: 'value',
shape: 'hvh',
color: 'value',
series: () => undefined,
},
style: {
gradient: 'y',
lineWidth: 2,
lineJoin: 'round',
},
};
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,27 @@
import { G2Spec } from '../../../src';

export function temperatures3AreaBandGradientTranspose(): G2Spec {
return {
type: 'area',
height: 900,
data: {
type: 'fetch',
value: 'data/temperatures3.csv',
},
scale: {
color: { palette: 'reds' },
},
coordinate: { transform: [{ type: 'transpose' }] },
legend: false,
encode: {
x: 'date',
y: ['low', 'high'],
shape: 'hvh',
color: (d) => d.high - d.low,
series: () => undefined,
},
style: {
gradient: 'x',
},
};
}
8 changes: 6 additions & 2 deletions src/shape/area/curve.ts
Original file line number Diff line number Diff line change
Expand Up @@ -89,8 +89,12 @@ export const Curve: SC<CurveOptions> = (options, context) => {
seriesX: sx,
seriesY: sy,
} = value;
const tpShape = isTranspose(coordinate);
const transform = getTransform(coordinate, value);
const fill = gradient && sc ? computeGradient(sc, sx, sy, gradient) : color;
const fill =
gradient && sc
? computeGradient(sc, sx, sy, gradient, undefined, tpShape)
: color;

const finalStyle = {
...defaults,
Expand Down Expand Up @@ -119,7 +123,7 @@ export const Curve: SC<CurveOptions> = (options, context) => {
const areaPath = (points) => {
const Y1 = points.slice(0, points.length / 2);
const Y0 = points.slice(points.length / 2);
return isTranspose(coordinate)
return tpShape
? area()
.y((_, idx) => Y1[idx][1])
.x1((_, idx) => Y1[idx][0])
Expand Down
9 changes: 6 additions & 3 deletions src/shape/line/curve.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { line, lineRadial, CurveFactory, CurveFactoryLineOnly } from 'd3-shape';
import { Vector2 } from '@antv/coord';
import { isPolar } from '../../utils/coordinate';
import { isPolar, isTranspose } from '../../utils/coordinate';
import { select } from '../../utils/selection';
import { ShapeComponent as SC } from '../../runtime';
import { applyStyle, computeGradient, getTransform } from '../utils';
Expand Down Expand Up @@ -89,11 +89,14 @@ export const Curve: SC<CurveOptions> = (options, context) => {
seriesX: sx,
seriesY: sy,
} = value;

const transform = getTransform(coordinate, value);
const tpShape = isTranspose(coordinate);
const stroke =
gradient && sc
? computeGradient(sc, sx, sy, gradient, gradientColor)
? computeGradient(sc, sx, sy, gradient, gradientColor, tpShape)
: color;
const transform = getTransform(coordinate, value);

const finalStyle = {
...rest,
...(stroke && { stroke }),
Expand Down
21 changes: 20 additions & 1 deletion src/shape/utils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -118,10 +118,29 @@ export function computeGradient(
Y: number[],
from: string | boolean = 'y',
mode: 'between' | 'start' | 'end' = 'between',
tpShape = false,
): string {
// The angles of gradients rendering are varies when 'from' and 'tpShape' are different.
const getTheta = (from: string | boolean, tpShape: boolean) => {
if (from === 'y' || from === true) {
if (tpShape) {
return 180;
} else {
return 90;
}
} else {
if (tpShape) {
return 90;
} else {
return 0;
}
}
};

const P = from === 'y' || from === true ? Y : X;
const theta = from === 'y' || from === true ? 90 : 0;
const theta = getTheta(from, tpShape);
const I = indexOf(P);

const [min, max] = extent(I, (i) => P[i]);
// This need to improve for non-uniform distributed colors.
const p = new Linear({
Expand Down

0 comments on commit 291f0af

Please sign in to comment.