UNPKG

@antv/g2

Version:

the Grammar of Graphics in Javascript

31 lines (27 loc) 989 B
import { deepMix } from '@antv/util'; import { TransformComponent as TC } from '../runtime'; import { JitterXTransform } from '../spec'; import { column, columnOf } from './utils/helper'; import { rangeOf, interpolate } from './jitter'; export type JitterXOptions = Omit<JitterXTransform, 'type'>; /** * The JitterX transform produce dy channels for marks (especially for point) * with ordinal x and y dimension, say to make them jitter in their own space. */ export const JitterX: TC<JitterXOptions> = (options = {}) => { const { padding = 0, random = Math.random } = options; return (I, mark) => { const { encode, scale } = mark; const { x: scaleX } = scale; const [X] = columnOf(encode, 'x'); const rangeX = rangeOf(X, scaleX, padding); const DX = I.map(() => interpolate(random(), ...rangeX)); return [ I, deepMix({ scale: { x: { padding: 0.5 } } }, mark, { encode: { dx: column(DX) }, }), ]; }; }; JitterX.props = {};