@antv/scale
Version:
Toolkit for mapping abstract data into visual representation.
57 lines (51 loc) • 1.6 kB
text/typescript
import { isNumber } from '@antv/util';
import { d3Ticks } from '../tick-methods/d3-ticks';
import { ConstantOptions, Domain, Range } from '../types';
import { Base } from './base';
export class Constant extends Base<ConstantOptions> {
/**
* 返回需要覆盖的默认选项
* @returns 需要覆盖的默认选项
*/
protected getDefaultOptions(): ConstantOptions {
return {
range: [0],
domain: [0, 1],
unknown: undefined,
tickCount: 5,
tickMethod: d3Ticks,
};
}
/**
* 输入和输出满足:y = b,其中 b 是一个常量,是 options.range 的第一个元素
* @param _ 输入值
* @returns 输出值(常量)
*/
// eslint-disable-next-line @typescript-eslint/no-unused-vars
public map(_: Domain<ConstantOptions>) {
const [v] = this.options.range;
return v !== undefined ? v : this.options.unknown;
}
/**
* 如果 x 是该比例尺的常量(x === b),返回输入值的范围(即定义域),否者返回 []
* @param x 输出值 (常量)
* @returns 定义域
*/
public invert(x: Range<ConstantOptions>) {
const [v] = this.options.range;
return x === v && v !== undefined ? this.options.domain : [];
}
public getTicks() {
const { tickMethod, domain, tickCount } = this.options;
const [a, b] = domain;
if (!isNumber(a) || !isNumber(b)) return [];
return tickMethod(a, b, tickCount);
}
/**
* 克隆 Constant Scale
* @returns 拥有相同选项且独立的 Constant Scale
*/
public clone() {
return new Constant(this.options);
}
}