!!!###!!!title=VChart——VisActor/VChart 接口文档!!!###!!!!!!###!!!description=全局 `VChart` 对象,也作为图表的总入口,用于图表的创建、更新和销毁。!!!###!!!

VChart

全局 VChart 对象,也作为图表的总入口,用于图表的创建、更新和销毁。

静态属性

ThemeManager

主题管理器。可用于全局主题的注册、设置以及获取等,详见theme

globalConfig

VChart 的全局配置项。这个对象里的属性可以直接修改,配置的生效时机依具体配置项而定。

uniqueTooltip(number) = true

是否全局显示唯一 tooltip。如果置为 true,当某个图表触发 tooltip 时,同一页面的所有其他图表的 tooltip 将自动消失。

此配置修改后即时生效。

静态方法

useRegisters

  /**
   *  按需注册图表和组件
   * @param comps
   * @since 1.5.1
   */
  static useRegisters(comps: (() => void)[]) {
    comps.forEach((fn: () => void) => {
      fn();
    });
  }

1.5.1 版本开始支持。 用于按需加载图表、系列、组件、环境兼容代码等。具体使用请参考 按需引入教程

useChart

/**
 * 注册自定义图表
 * @param charts 图表类
 */
useChart: (charts: IChartConstructor[]) => void;

用于注册扩展的自定义图表 Chart。

useSeries

/**
 * 注册自定义系列
 * @param series 系列类
 */
useSeries: (series: ISeriesConstructor[]) => void;

用于注册扩展的自定义系列 Series。

useComponent

/**
 * 注册自定义组件
 * @param components 组件类
 */
useComponent: (components: IComponentConstructor[]) => void;

用于注册扩展的自定义组件 Component。

useMark

/**
 * 注册自定义 Mark
 * @param  marks Mark 图元类
 */
useMark: (marks: MarkConstructor[]) => void;

用于注册扩展的自定义 组件 Mark。

useLayout

/**
 * 注册自定义的布局
 * @param layouts 布局类
 */
useLayout: (layouts: ILayoutConstructor[]) => void;

用于注册扩展的自定义布局 Layout。

registerDataSetTransform

  /**
   * 注册 DataSet 数据方法
   * @param name 数据 transform 方法名称
   * @param transform 具体的 Transform 执行方法
   */
  registerDataSetTransform: (name: string, transform: Transform) => void;

用于注册 DataSet 数据方法,常用于按需加载。

registerMap

/**
 * 注册地图数据
 * @param key 地图名称
 * @param source 地图数据
 * @param option 地图数据配置
 */
registerMap: (key: string, source: GeoSourceType, option?: GeoSourceOption) => void;

注册地图数据。

export interface GeoSourceOption {
  type: 'geojson';
  /** 计算中心点 */
  /** @default true */
  centroid?: boolean;
  /** 地图简化 */
  /** @default false */
  simplify?:
    | boolean
    | {
        /**
         * 一个以度为单位的数字(例如,纬度/经度距离)。
         * 1度大约相当于69英里。默认值是0.001,大约是一个城市街区的长度。
         * @default 0.01
         * @since 1.11.0
         */
        tolerance: number;
      };
  /** 逆时针回绕(Multi)LineString或(Multi)Polygon的外部环,内部环顺时针。*/
  /** @default false */
  rewind?:
    | boolean
    | {
        /** 启用反向绕行 */
        /** @default false */
        reverse?: boolean;
      };
}

unregisterMap

/**
 * 卸载地图数据
 * @param key 地图名称
 */
unregisterMap: (key: string) => void;

用于卸载地图数据。

getMap

/**
 * 根据地图名称获取地图数据
 * @param key 地图名称
 * @returns 地图数据
 */
getMap: (key: string) => GeoSourceType;

根据注册的地图名称获取对应的地图数据。

初始化(new VChart)

new VChart(spec: ISpec, options: IInitOption);

用于创建 VChart 实例。

参数说明

spec

图表的 spec 配置,详见配置项页面。

options

图表配置,包含渲染容器等,详见的配置如下表:

属性名类型必选描述
domstring|HTMLElement仅生效于浏览器环境。 图表挂载的父容器,可以直接指定容器 id,也可以传入 dom 对象
renderCanvasstring|HTMLCanvasElement除去选择 dom 属性进行挂载父容器,也可以使用 renderCanvas 属性直接传入 canvas 实例/ canvasId,小程序/小组件环境请直接传入 id
dataSetDataSet数据集
autoFitboolean是否自适应容器大小,默认为 true
animationboolean是否开启动画,默认为 true
options3dsrIOption3DType3d 配置
layoutLayoutCallBack自定义布局函数
modestring配置渲染环境,默认为 'desktop-browser',当需要在非浏览器环境渲染 VChart 时,需要配置该属性。 'desktop-browser': 默认模式,适用于 PC 及 H5; 'mobile-browser': H5 模式; 'node': Node 渲染; 'worker': worker 模式; 'miniApp': 小程序模式; 'lynx': lynx 渲染
modeParamsany配置 mode 参数一起使用,用于配置 mode 参数对应的环境的一些特殊配置
dprnumber设置屏幕分辨率
interactiveboolean图表交互全局开关,默认为 true,开启。
viewBoxobject指定绘制的矩形区域,如 { x1: 100, y1: 100, x2: 300, y2: 300 }
canvasControledboolean用于告诉底层的渲染引擎 VRender,图表的 Canvas 是否是受控制的 canvas,如果不是的话,不会进行 resize 等操作。
stageStage外部传入的 VRender stage
layerLayer外部传入的 VRender layer
beforeRenderFunction绘制之前的钩子函数,(stage: IStage) => void
afterRenderFunction绘制之后的钩子函数,(stage: IStage) => void
backgroundstring\object绘图区域背景色设置,可以配置渐变色
logLevelnumber日志类型,用于开发调试
disableDirtyBoundsboolean是否关闭 dirtyBounds
enableView3dTransformboolean是否开启 view3d 的变换模式
poptipboolean是否开启省略文本的 poptip,用于查看完整的文本内容,默认开启
disableTriggerEventboolean是否关闭交互效果;从1.9.0版本开始支持
themestring | ITheme默认主题(支持完整主题对象或者主题名称,主题名称需要提前在 ThemeManager 中注册)
enableHtmlAttributeboolean底层 vrender 图形节点是否支持html属性; 从1.8.3版本开始支持
supportsTouchEventsboolean是否支持 touch 事件,不支持就不监听 touch 事件; 从1.8.9版本开始支持
supportsPointerEventsboolean是否支持 pointer 事件,不支持就监听 mouse 事件; 从1.8.9版本开始支持
ReactDOMobjectreact-dom包导出产物,用于开启 vrender 渲染 react 元素; 从1.11.0版本开始支持
  • srIOption3DType 类型定义如下
export interface srIOption3DType extends IOption3D {
  enable?: boolean;
  enableView3dTransform?: boolean;
}
export interface IOption3D {
  alpha?: number;
  beta?: number;
  gama?: number;
  center?: IPointLike;
  fieldRatio?: number;
  fieldDepth?: number;
  light?: {
    dir?: vec3;
    color?: string;
    ambient?: number;
  };
  camera?: any;
}
  • LayoutCallBack 类型定义如下:
export type LayoutCallBack = (
  chart: IChart,
  item: ILayoutItem[],
  chartLayoutRect: IRect,
  chartViewBox: IBoundsLike
) => void;

示例

import VChart from '@visactor/vchart';

const spec = {
  //  chart spec
};
// create an instance of VChart
const chart = new VChart(spec, {
  dom: 'chart' // the id of chart container
});

属性

id

只读属性,VChart 实例的 id,内部生成。

方法

renderSync

同步渲染图表。

/**
 * **同步**渲染图表。
 * @param morphConfig 图表 morph 动画配置,可选
 * @returns VChart 实例
 */
renderSync: (morphConfig?: IMorphConfig) => IVChart;

renderAsync

1.9.0 版本以后不推荐使用,后续会废弃异步渲染/异步更新相关 API

异步渲染图表。

/**
 * **异步**渲染图表。
 * @async
 * @param morphConfig 图表 morph 动画配置,可选
 * @returns VChart 实例
 */
renderAsync: (morphConfig?: IMorphConfig) => Promise<IVChart>;

updateData

异步更新数据。参数 id 对应在 spec 中 data 属性上的 id 字段,会自动渲染图表不需要再调用 renderAsync() 等渲染方法。

/**
 * **异步**更新数据。
 * @param id 数据 id
 * @param data 数据值
 * @param options 数据参数
 * @returns VChart 实例
 */
updateData: (id: StringOrNumber, data: DataView | Datum[] | string, options?: IParserOptions) => Promise<IVChart>;

updateDataInBatches

异步批量更新数据,会自动渲染图表不需要再调用 renderAsync() 等渲染方法。

/**
 * **异步**批量更新数据。
 * @param list 待更新的数据列表
 * @returns VChart 实例
 */
updateDataInBatches: (list: { id: string; data: DataView | Datum[]; options?: IParserOptions }[]) => Promise<IVChart>;

updateDataSync

同步更新数据。参数 id 对应在 spec 中 data 属性上的 id 字段,会自动渲染图表不需要再调用 renderAsync() 等渲染方法。

/**
 * **同步**更新数据。
 * @param id 数据 id
 * @param data 数据值
 * @param options 数据参数
 * @returns VChart 实例
 */
updateDataSync: (id: StringOrNumber, data: DataView | Datum[], options?: IParserOptions) => IVChart;

updateFullData

更新数据接口。参数为完整的数据项配置,可以通过此接口更新数据的 fields 配置,默认会自动渲染图表不需要再调用 renderAsync() 等渲染方法。

/**
 * 更新数据。
 * @param data 数据配置
 * @param reRender 是否重新绘制
 * @returns VChart 实例
 * @since 1.3.0
 */
updateFullData: (data: IDataValues | IDataValues[], reRender: boolean = true) => IVChart;

updateFullDataSync

同步更新数据。参数为完整的数据项配置,可以通过此接口更新数据的 fields 配置,默认会自动渲染图表不需要再调用 renderAsync() 等渲染方法。

/**
 * **同步**更新数据。
 * @param data 数据配置
 * @param reRender 是否重新绘制
 * @returns VChart 实例
 * @since 1.3.0
 */
updateFullDataSync: (data: IDataValues | IDataValues[], reRender: boolean = true) => IVChart;

updateSpec

异步spec 更新,会自动渲染图表不需要再调用 renderAsync() 等渲染方法。

/**
 * spec 更新
 * @param spec
 * @param forceMerge 是否强制合并,默认为 false
 * @param morphConfig morph 动画配置
 * @returns
 */
updateSpec: (spec: ISpec, forceMerge?: boolean, morphConfig?: IMorphConfig) => Promise<IVChart>;

updateModelSpec

异步模块 spec 更新,可以通过 filter 指定更新某一个图表模块的配置,会自动渲染图表不需要再调用 renderAsync() 等渲染方法。

/**
 * 模块 spec 更新
 * @param filter
 * @param spec
 * @param forceMerge
 * @returns
 * @sync 1.4.0
 */
updateModelSpec: (
  filter: string | { type: string; index: number },
  spec: unknown,
  forceMerge?: boolean,
  morphConfig?: IMorphConfig
) => Promise<IVChart>;

updateViewBox

更新绘制区域。viewBox 为绘制区域,格式为 { x1: number; x2: number; y1: number; y2: number }

/**
 * 更新绘制区域。
 * @param viewBox 绘制区域
 * @param reRender 是否重新渲染,默认为 true
 * @returns
 */
updateViewBox: (viewBox: IBoundsLike, reRender?: boolean) => IVChart;

resize

异步方法,图表尺寸更新方法。

/**
 * **异步方法**,图表尺寸更新方法。
 * @param width 宽度
 * @param height 高度
 * @returns VChart 当前实例
 */
resize: (width: number, height: number) => Promise<IVChart>;

release

销毁图表。

  /**
   * 销毁图表。
   */
  release: () => void;

on

on(event: string, callback: (params: EventParams) => void): void;
on(event: string, query: EventQuery, callback: (params: EventParams) => void): void;

事件绑定。更加具体的使用,请移步event

off

off(event: string, callback: (params: EventParams) => void): void;

事件卸载。

updateState

更新或设置图元状态。

  /**
   * 更新或设置图元状态。
   * @param state 状态筛选器
   * @param filter 筛选器
   */
  updateState: (
    state: Record<string, Omit<IMarkStateSpec<unknown>, 'style'>>,
    filter?: (series: ISeries, mark: IMark, stateKey: string) => boolean //series + mark 筛选
  ) => void;

下方例子展示了如何更新状态的筛选条件,当我们点击图中的一个点,与这个点 type 值不同的点都变为半透明, 使用示例:

const spec = {
  type: 'scatter',
  data: [
    {
      id: 'data1',
      values: [
        { x: 1, y: 80, type: 'a' },
        { x: 2, y: 10, type: 'a' },
        { x: 1, y: 10, type: 'b' },
        { x: 2, y: 20, type: 'b' }
      ]
    }
  ],
  xField: 'x',
  yField: 'y',
  seriesField: 'type',
  point: {
    style: {
      // 默认情况下透明的设置为1
      fillOpacity: 1
    }
    state: {
      // 先设置好状态对应的属性
      custom_unSelected: {
        fillOpacity: 0.5
      }
    }
  }
};

const vchart = new VChart(spec);
vchart.renderSync();
// 监听点击事件
vchart.on('click', { level: 'mark' }, ctx => {
  vchart.updateState({
    // 名称与上方配置要对应
    custom_unSelected: {
      filter: datum => {
        // 数据 type 不相等的进入这个状态
        return datum.type !== ctx.datum.type;
      }
    }
  });
});

setSelected

更新图元选中状态。

  /**
   * 更新图元选中状态。
   * @param datum hover 图元数据
   * @param filter 筛选器 用来筛选系列与mark
   * @param region region 筛选器
   */
  setSelected: (
    datum: MaybeArray<any> | null,
    filter?: (series: ISeries, mark: IMark) => boolean,
    region?: IRegionQuerier
  ) => void;

设置一组数据为选中状态,也可以直接设置 null 来取消选中状态。

/**
 * 假定图表数据如下
   [
    {x: 'US' , y: 10, type: 'A'}
    {x: 'NZ' , y: 20, type: 'A'}
    {x: 'US' , y: 30, type: 'B'}
    {x: 'NZ' , y: 40, type: 'B'}
   ]
 */
// 选定 type === 'A' 的数据
vchart.setSelected({ type: 'A' });
// 选定数据  {x: 'US' , y: 10, type: 'A'}
vchart.setSelected({ x: 'US', y: 10, type: 'A' });
// 取消当前的选中数据
vchart.setSelected(null);

setHovered

更新图元 hover 状态。

  /**
   * 更新图元 hover 状态
   * @param datum hover 图元数据
   * @param filter 筛选器 用来筛选系列与mark
   * @param region region 筛选器
   */
  setHovered: (
    datum: MaybeArray<Datum> | null,
    filter?: (series: ISeries, mark: IMark) => boolean,
    region?: IRegionQuerier
  ) => void;

设置一个数据为 hover 状态,也可以直接设置 null 来取消 hover 状态。

setHovered 效果类似 setSelected,支持一次将多条数据设置为 hover 状态。

/**
 * 假定图表数据如下
   [
    {x: 'US' , y: 10, type: 'A'}
    {x: 'NZ' , y: 20, type: 'A'}
    {x: 'US' , y: 30, type: 'B'}
    {x: 'NZ' , y: 40, type: 'B'}
   ]
 */
// 选定 type === 'A' 的数据
vchart.setHovered({ type: 'A' });
// 选定数据  {x: 'US' , y: 10, type: 'A'}
vchart.setHovered({ x: 'US', y: 10, type: 'A' });
// 取消当前的选中数据
vchart.setHovered(null);

clearState

清除图元的状态

 /**
   * 清除所有图元的状态
   * @param state 状态名
   *
   * @since 1.11.0
   */
  clearState: (state: string) => void;

clearSelected

清除图元的选中状态

/**
   * 清除所有图元的选中状态
   *
   * @since 1.11.0
   */
  clearSelected: () => void;

clearHovered

清除图元的 hover 状态

/**
   * 清除所有图元的hover状态
   *
   * @since 1.11.0
   */
  clearHovered: () => void;

getCurrentTheme

获取当前主题,会返回完整的主题配置。

getCurrentTheme: () => ITheme;

getCurrentThemeName

获取当前主题名称(只能获取用户通过 setCurrentTheme 方法设置过的主题,默认值为 ThemeManager 统一设置的主题)。

getCurrentThemeName: () => string;

setCurrentTheme

异步方法, 设置当前主题。

注意:如果在图片的 spec 中配置了 theme 属性,则 spec.theme 的优先级更高。

/**
 * **异步方法**, 设置当前主题。
 * @param name 主题名称
 * @returns
 */
setCurrentTheme: (name: string) => Promise<IVChart>;

setTooltipHandler

当配置项无法满足 tooltip 的展示需求时,我们还提供了自定义 tooltip 的能力。可以通过配置 TooltipHandler 来覆盖默认 tooltip 展示逻辑。

  /**
   * 自定义 TooltipHandler。
   * @param tooltipHandler
   */
  setTooltipHandler: (tooltipHandler: ITooltipHandler) => void;

注意:

  • 当给图表设置了自定义TooltipHandler后,内置的 tooltip 将不再起作用。
  • VChart 不感知、不托管自定义 tooltip 的渲染,请按照需要自行实现 tooltip 渲染,包括处理原始数据tooltip 内容设计,以及根据项目环境创建组件并设置样式
  • 当图表删除时会调用当前TooltipHandlerrelease函数,请按照需要删除。
  • 由于自定义TooltipHandler会覆盖内置 tooltip 逻辑,图表spec中的部分 tooltip 配置项便不再起作用。但以下配置项作用于所有自定义TooltipHandler
    • tooltip.visible
    • tooltip.activeType
    • tooltip.trigger
    • tooltip.triggerOff

ITooltipHandler接口定义如下:

interface ITooltipHandler {
  /** 显示 tooltip,可以选择返回是否遇到异常 */
  showTooltip: (
    activeType: TooltipActiveType,
    data: TooltipData,
    params: TooltipHandlerParams
  ) => TooltipResult | null | undefined;

  /** 隐藏 tooltip */
  hideTooltip: (params: TooltipHandlerParams) => void;

  /** 释放 tooltip */
  release: () => void;
}

其中ITooltipHandler.showTooltip有三个参数,意义分别为:

  • activeType: 透出本次触发的 tooltip 类型,值为'mark''dimension'
  • data: 透出本次触发的 tooltip 原始数据
  • params: 透出本次触发的 tooltip 的鼠标事件

data参数的类型为TooltipData,类型定义为:

type TooltipData = IDimensionInfo[] | IDimensionData[];

如果用户触发了 mark tooltip,TooltipData 便为 IDimensionData[] 类型。IDimensionData的类型定义为:

interface IDimensionData {
  /** 图元上的原始数据(考虑到有多个图元的情况,实际为数组类型) */
  datum: Datum[];
  /** 图元所在的系列实例 */
  series: ISeries;
}

而如果用户触发了 dimension tooltip,TooltipData 便为 IDimensionInfo[] 类型。IDimensionInfo承载了鼠标所在整个维度项的信息,类型定义为:

interface IDimensionInfo {
  /** 维度项索引 */
  index?: number;
  /** 维度项标题 */
  value: string;
  /** 维度项所在轴 */
  axis?: AxisComponent;
  /** 维度项对应数据 */
  data: IDimensionData[];
}

用户可以选择使ITooltipHandler.showTooltip方法返回一个状态TooltipResult,用来表示 tooltip 是否成功显示(如果不返回,则默认当做成功)。这个返回值和缓存策略有关。TooltipResult是个枚举类型,定义为:

enum TooltipResult {
  /** tooltip 显示成功 */
  success = 0,
  /** tooltip 未成功显示 */
  failed = 1
}

ITooltipHandler.showTooltip方法的最后一个参数为params,其类型定义为:

type TooltipHandlerParams = (BaseEventParams | DimensionEventParams) & {
  changePositionOnly?: boolean;
};

其中暴露了一个很有用的参数:changePositionOnly代表这个 tooltip 是否仅仅是上一个 tooltip 挪用了下位置,而数据相同。这个参数将帮助用户对 tooltip 渲染进行优化。

示例:在控制台打出用户鼠标 hover 的维度项标题、以及系列图元的填充颜色:

vchart.setTooltipHandler({
  showTooltip: (activeType, data, params) => {
    if (params.changePositionOnly) {
      return;
    }
    if (activeType === 'dimension' && data?.length) {
      console.log(data[0].value);
    } else if (activeType === 'mark') {
      const { datum, series } = data[0];
      const color = series.getSeriesStyle(datum[0])('fill');
      console.log(color);
    }
  }
});

getTooltipHandler

获取TooltipHandler

getTooltipHandler: () => ITooltipHandler | undefined;

showTooltip

手动调用展示 tooltip。

/**
 * 手动调用展示 tooltip
 * @param datum 原始数据
 * @param options
 * @returns
 */
showTooltip: (datum: Datum, options: IShowTooltipOption) => boolean;

interface IRegionQuerier {
  regionId?: StringOrNumber;
  regionIndex?: number;
}

interface IShowTooltipOption extends IRegionQuerier {
  /* tooltip预期显示的x坐标(为空则在图元附近) */
  x?: number;
  /* tooltip预期显示的y坐标(为空则在图元附近) */
  y?: number;
  /* 是否常显(如果为false或空的话,手动触发tooltip之后,tooltip可能被自动触发的别的tooltip替代) */
  alwaysShow?: boolean;
  /* tooltip类型(为空则自动判断) */
  activeType?: TooltipActiveType;
}

hideTooltip

手动调用,关闭 tooltip

hideTooltip: () => boolean;

getLegendDataById

根据图例组件 id 获取图例数据,该 id 来源于在 spec 的 legends 字段中配置的 id。如: legends: { id: 'bottom' } 或者 legends: [{ id: 'left' }]

  /**
   * 根据图例组件 id 获取图例数据
   * @param id 组件 id
   * @returns
   */
  getLegendDataById: (id: string) => Datum[];

图例数据类型:

type LegendDatum = {
  key: string; // 图例项分组
  shapeType?: string; // 图例 symbol 形状
  style?: (channel: string) => any; // 图例样式函数,接收视觉通道名称并返回视觉通道样式,例如 'fill'
};

getLegendDataByIndex

根据图例组件索引获取图例数据。

  /**
   * 根据图例组件索引获取图例数据
   * @param index 图例索引,默认为 0
   * @returns
   */
  getLegendDataByIndex: (index?: number) => Datum[];

图例数据类型:

type LegendDatum = {
  key: string; // 图例项分组
  shapeType?: string; // 图例 symbol 形状
  style?: (channel: string) => any; // 图例样式函数,接收视觉通道名称并返回视觉通道样式,例如 'fill'
};

getLegendSelectedDataById

根据图例组件 id 获取当前图例的选中项,该 id 来源于在 spec 的 legends 字段中配置的 id。如: legends: { id: 'bottom' } 或者 legends: [{ id: 'left' }]

  /**
   * 根据图例组件 id 获取当前图例的选中项
   * @param id 组件 id
   * @returns
   */
  getLegendSelectedDataById: (id: string) => StringOrNumber[];

getLegendSelectedDataByIndex

根据图例组件索引获取当前图例的选中项。

  /**
   * 根据图例组件索引获取当前图例的选中项
   * @param index 图例索引,默认为 0
   * @returns
   */
  getLegendSelectedDataByIndex: (index?: number) => StringOrNumber[];

setLegendSelectedDataById

根据图例组件 id 更新图例选中数据,该 id 来源于在 spec 的 legends 字段中配置的 id。如: legends: { id: 'bottom' } 或者 legends: [{ id: 'left' }]

  /**
   * 根据图例组件 id 更新图例选中数据
   * @param id
   * @returns
   */
  setLegendSelectedDataById: (id: string, selectedData: StringOrNumber[]) => void;

setLegendSelectedDataByIndex

根据图例组件索引更新图例选中数据。

  /**
   * 根据图例组件索引更新图例选中数据
   * @param index 图例索引,默认为 0
   * @returns
   */
  setLegendSelectedDataByIndex: (index: number, selectedData: StringOrNumber[]) => void;

getDataURL

异步方法返回一个包含图片展示的 data URI。

getDataURL: () => Promise<any>;

exportImg

异步方法 导出图表图片,只支持浏览器端,同时参数 name 可以为图片进行命名。

/**
 * **异步方法** 导出图表图片,只支持浏览器端。
 * @param name 保存的图片名称
 * @returns
 */
exportImg: (name?: string) => Promise<void>;

exportCanvas

导出绘制有图表内容的 canvas ,只支持浏览器端。可以使用这个 canvas 进行二次处理,比如添加水印等。

/**
 * 导出绘制了图表内容的 canvas
 * @returns HTMLCanvasElement
 * @since 1.5.2
 */
exportCanvas: () => HTMLCanvasElement | undefined;

getImageBuffer

目前仅支持 node 环境,用于 node 端的图片导出。

 getImageBuffer: () => void;

setLayout

设置自定义布局。

/**
 * 设置自定义布局
 */
setLayout: (layout: LayoutCallBack) => void;

type LayoutCallBack = (
  chart: IChart,
  item: ILayoutItem[],
  chartLayoutRect: IRect,
  chartViewBox: IBoundsLike
) => void;

reLayout

强制重新布局。

 reLayout: () => void;

getCompiler

获取编译器实例。

getCompiler: () => Compiler;

getChart

获取 Chart 图表实例。

getChart: () => IChart;

getStage

获取渲染引擎实例。

getStage: () => Stage;

getCanvas

获取 canvas dom。

getCanvas: () => HTMLCanvasElement | undefined;

getContainer

获取图表的 dom 容器。

getContainer: () => Maybe<HTMLElement>;

getComponents

获取图表所有的组件实例。

getComponents: () => IComponent[];

getDataSet

获取图表的 DataSet 实例。

getDataSet: () => DataSet;

getScale

自版本 1.10.4开始支持;

获取图表的 Scale 实例。

getScale: (scaleId: string) => IBaseScale;

setDimensionIndex

手动调用触发 dimension 交互效果。

/**
 * 手动调用触发 dimension 交互效果。
 * @param datum dimension 值
 * @param options
 * @returns
 */
setDimensionIndex: (value: StringOrNumber, options: DimensionIndexOption = {}) => void;

type DimensionIndexOption = {
  // 当存在多个数轴时,通过 filter 筛选要触发 dimension 效果的轴
  // 目前只有离散数轴可以触发 dimension 效果
  filter?: (cmp: IComponent) => boolean;
  // 是否触发 tooltip , default is true
  tooltip?: boolean;
  // tooltip 触发时的 showTooltipOption 参数,请参考上方 api-showTooltip 中的说明
  showTooltipOption?: IShowTooltipOption;
  // 是否触发 crosshair , default is true
  crosshair?: boolean;
};

相关示例

convertDatumToPosition

根据数据集中的数据获取对应的图表坐标位置。该数据需要从传入图表的数据集中获取,如果数据不存在数据集中,可以使用 convertValueToPosition 方法。

/**
 * 将图形对应的数据转换为坐标,该数据需要从传入图表的数据集中获取,如果数据不存在数据集中,可以使用 `convertValueToPosition` 方法
 * @param datum 要转化的数据 the datum(from data source)to convert
 * @param dataLinkInfo 数据的绑定信息,the data link info, could be seriesId or seriesIndex, default is { seriesIndex: 0 }
 * @param isRelativeToCanvas 是否相对画布坐标 Whether relative to canvas coordinates
 * @param checkInViewData 是否检查数据对应的图元是否在视图中,如果不在视图中,返回 null
 * @returns
 */
convertDatumToPosition: (
  datum: Datum,
  dataLinkInfo?: DataLinkSeries,
  isRelativeToCanvas?: boolean,
  checkInViewData?: boolean
) => IPoint | null;

convertValueToPosition

将数值转换为对应的 canvas 坐标点。

/**
 * 将数值转换为对应的 canvas 坐标点。
 * @param value number | [number, number], 需要转换的数值,可以是单个数值,也可以是数组,如果是数组,则会转换为对应的 x y 坐标点
 * @param dataLinkInfo 数据绑定的信息,可以是 `seriesId` `seriesIndex` `axisId` `axisIndex`
 * @param isRelativeToCanvas 是否相对画布坐标,默认为 false Whether relative to canvas coordinates, default is false
 * returns
 */
convertValueToPosition: ((value: StringOrNumber, dataLinkInfo: DataLinkAxis, isRelativeToCanvas?: boolean) =>
  number | null) &
  ((value: [StringOrNumber, StringOrNumber], dataLinkInfo: DataLinkSeries, isRelativeToCanvas?: boolean) =>
    IPoint | null);