交互 - Interaction
交互(Interaction)是 G2 中的重要 API,通过这个方法可以加载 G2 内置的交互,或者基于交互语法形式自定义的 Interaction 交互。G2 4.0 在交互方面做了非常大的调整,所有的交互代码都是插入式的,通过交互语法进行组织。使用交互的方式也非常简单,仅需要设置交互的名称即可。关于交互语法可以阅读 交互语法 。
(name: string, cfg?: object) => View;
chart.interaction('my-interaction', { extra: 'hello world' });
配置交互类型,可以传入 G2 默认支持的交互类型,也可以通过
registerInteraction
自己注册交互方式。第二个参数是用来给自定义交互传入参数的,目前 G2 默认支持的交互类型无需传入第二个参数。
内置交互
为了便于用户的使用,G2 在 Chart 中内置了几种交互:
- tooltip:鼠标在 chart 上移动时显示提示信息
- legend-active:鼠标移动到图例选项时,图例项高亮,对应的图形高亮
- legend-filter:分类图例的勾选
- continuous-filter: 连续图例的过滤
- chart.interaction(name, [cfg]) 添加或者修改交互
- chart.removeInteraction(name) 移除交互
- showEnable:标识交互可以发生
- start: 交互开始
- processing: 交互持续
- end: 交互结束
- rollback: 回滚
- trigger 触发一个交互环节的事件名,是所有 Chart 支持的事件
- 字符串由 ’actionName:method‘ 组成
- 列表时可以使用相同的 action ,也可以使用不同的 action ,例如: ['element-active:clear', 'element-active:active', 'mask:clear']
- isEnable(context): 是否可以触发
- callback(context): 触发后执行完所有 action 的方法后会调用回调函数
- once: boolean, 是否在一个环节内仅能执行一次
- wait: 等待时间
- immediate: 是否马上执行
- wait: 等待时间
- leading: 是否马上执行
- trailing: 执行完毕后再执行一次 debounce 和 throttle 的机制参考: https://css-tricks.com/debouncing-throttling-explained-examples/
- 可以通过 context.isInPlot() 判定事件触发时,事件发生的位置是否在绘图区域内
- 可以通过 context.isInComponent('legend') 判定是否发生在 legend 的包围盒内
- 可以通过 context.event.target 或者 context.getCurrentShape() 获取触发的图形
可以通过 Chart 上的配置项 defaultInteractions 更改内置的交互
new Chart({
container: 'container',
width: 500,
height: 500,
defaultInteractions: ['tooltip'], // 仅保留 tooltip
});
配置交互
除了通过 defaultInteractions 来配置交互外,你可以通过 Chart 上的两个接口来添加和移除交互:
添加或者修改交互时的第二个参数 cfg 是来修改已经定义好的交互的行为,G2 4.0 中的交互全部由交互语法组装而成,可以参考 交互语法 ,我们在这里不对交互语法进行详细的介绍。
chart.interaction('tooltip'); // 使用交互
chart.interaction('element-active');
chart.interaction('legend-visible-filter');
chart.removeInteraction('element-active'); // 移除某个交互
在交互语法中一个交互可以由多个交互环节组成,每个交互环节可以有多个触发和反馈,所以在配置交互时可以配置每个环节,每个环节都是数组,都有 trigger 和 action
修改交互的默认交互
我们以修改 tooltip 的交互为例来说明如何修改默认交互的行为,tooltip 交互的原始的配置项是:
{
start: [{ trigger: 'plot:mousemove', action: 'tooltip:show' }],
end: [{ trigger: 'plot:mouseleave', action: 'tooltip:hide' }],
}
我们可以修改 tooltip 的触发,改成点击绘图区域内部时显示 tooltip
chart.interaction('tooltip', {
start: [{ trigger: 'plot:click', action: 'tooltip:show' }],
});
其中:
action 触发的反馈,可以是字符串也可以是数组,是所有内置和用户自定义的 Action,参考 交互反馈 Action 列表 。
除了 trigger 和 action 之外还有其他几个可选属性:
debounce: 延迟执行,有两个参数:
throttle 增加阈值,控制执行的频率
context 交互的上下文
交互的上下文提供了一系列进行判定条件的函数,帮助用户在 isEnable 中方便的判断,以上面 tooltip 的为示例,如果我们不使用 'plot:click' 事件而仅使用 'click' 事件时需要判定是否在绘图区域内判定:
chart.interaction('tooltip', {
start: [
trigger: 'click',
isEnable(context) {
return context.isInPlot();
action: 'tooltip:show',
});
context 的接口定义如下:
/** 交互上下文的接口定义 */
export interface IInteractionContext {
* 当前触发的事件对象
event: Record<string, any>;
* 当前的 view
view: View;
/** 交互相关的 Actions */
actions: IAction[];
* 缓存属性,用于上下文传递信息
* @param key 键名
* @param value 值
cache(key: string, value?: any);
* 获取 action
* @param name - action 的名称
* @returns 指定 name 的 Action
getAction(name): IAction;
* 获取当前的点
* @returns 返回当前的点
getCurrentPoint(): Point;
* 获取当前的图形
getCurrentShape(): IShape;
* 添加 action
* @param action 指定交互 action
addAction(action: IAction);
* 移除 action
* @param action 移除的 action
removeAction(action: IAction);
* 事件触发时是否在 view 内部
isInPlot();
* 是否在组件的包围盒内
* @param name 组件名,可省略
isInComponent(name?: string);
* 是否在指定的图形内
* @param name shape 的名称
isInShape(name);
destroy();
所有的交互列表
G2 种的所有的交互都是通过 registerInteraction 方法注册的:
G2.registerInteraction(name, cfg);
我们用这个方法来说明各个交互,同时指出触发的对象和反馈的 Action
tooltip
控制 Tooltip 的显示隐藏,其定义:
// 注册 tooltip 的 interaction
registerInteraction('tooltip', {
start: [{ trigger: 'plot:mousemove', action: 'tooltip:show' }],
end: [{ trigger: 'plot:mouseleave', action: 'tooltip:hide' }],
});
- 触发对象 plot,图表的绘图区域
- action 是 tooltip
active-region
鼠标在画布上移动时对应位置的分类出现背景框
// 出现背景框
registerInteraction('active-region', {
start: [{ trigger: 'plot:mousemove', action: 'active-region:show' }],
end: [{ trigger: 'plot:mouseleave', action: 'active-region:hide' }],
});
-
触发对象 plot,图表的绘图区域
-
action 是 active-region
view-zoom
鼠标滚动时,图表内部缩放,由于 mousewheel 触发的非常频繁,所以需要增加 throttle
function isWheelDown(event) {
event.gEvent.preventDefault();
return event.gEvent.originalEvent.deltaY > 0;
registerInteraction('view-zoom', {
start: [
trigger: 'plot:mousewheel',
isEnable(context) {
return isWheelDown(context.event);
action: 'scale-zoom:zoomOut',
throttle: { wait: 100, leading: true, trailing: false },
trigger: 'plot:mousewheel',
isEnable(context) {
return !isWheelDown(context.event);
action: 'scale-zoom:zoomIn',
throttle: { wait: 100, leading: true, trailing: false },
});
element-active
鼠标移入图表元素(柱状图的柱子、点图的点等)时触发 active
// 移动到 elment 上 active
registerInteraction('element-active', {
start: [{ trigger: 'element:mouseenter', action: 'element-active:active' }],
end: [{ trigger: 'element:mouseleave', action: 'element-active:reset' }],
});
-
触发对象是图表元素 Element
-
action 是 element-active
element-selected
点击选中图表元素、再次点击取消,允许多选
// 点击选中,允许取消
registerInteraction('element-selected', {
start: [{ trigger: 'element:click', action: 'element-seleted:toggle' }],
});
element-single-selected
单选图表元素,下次点击允许取消
// 点击选中,允许取消
registerInteraction('element-single-selected', {
start: [{ trigger: 'element:click', action: 'element-single-selected:toggle' }],
});
element-highlight
图表元素的高亮,是一部分图表元素高亮,另一部分变暗
registerInteraction('element-highlight', {
start: [{ trigger: 'element:mouseenter', action: 'element-highlight:highlight' }],
end: [{ trigger: 'element:mouseleave', action: 'element-highlight:reset' }],
});
-
触发对象是图表元素 element
-
action 是 element-highlight
element-highlight-by-x
高亮 x 值相同的 element,适用于分组的场景
registerInteraction('element-highlight-by-x', {
start: [{ trigger: 'element:mouseenter', action: 'element-highlight-by-x:highlight' }],
end: [{ trigger: 'element:mouseleave', action: 'element-highlight-by-x:reset' }],
});
element-highlight-by-color
高亮所有同颜色的 element,适用于层叠的场景
registerInteraction('element-highlight-by-color', {
start: [{ trigger: 'element:mouseenter', action: 'element-highlight-by-color:highlight' }],
end: [{ trigger: 'element:mouseleave', action: 'element-highlight-by-color:reset' }],
});
legend-filter
分类图例的数据过滤
// 筛选数据
registerInteraction('legend-filter', {
showEnable: [
{ trigger: 'legend-item:mouseenter', action: 'cursor:pointer' },
{ trigger: 'legend-item:mouseleave', action: 'cursor:default' },
start: [
{ trigger: 'legend-item:click', action: 'list-unchecked:toggle' },
{ trigger: 'legend-item:click', action: 'data-filter:filter' },
});
-
触发的对象:图例项 legend-item
action 有 4 个
-
鼠标 cursor
-
列表取消选中:list-unchecked
-
列表选中:list-checked (✨ 新增)
-
数据过滤:data-filter
legend-visible-filter
分类图例的图形过滤,点击图例对应的图形隐藏/显示,这个交互不会引起坐标轴的变化
// 筛选图形
registerInteraction('legend-visible-filter', {
showEnable: [
{ trigger: 'legend-item:mouseenter', action: 'cursor:pointer' },
{ trigger: 'legend-item:mouseleave', action: 'cursor:default' },
start: [
{ trigger: 'legend-item:click', action: 'list-unchecked:toggle' },
{ trigger: 'legend-item:click', action: 'element-filter:filter' },
});
-
触发的对象:图例项 legend-item
action 有 3 个
-
鼠标 cursor
-
列表取消选中:list-unchecked
-
数据过滤:data-filter
注意:由于内置了 legend-filter 交互,所以使用该交互时移除掉 legend-filter 交互
chart.removeInteraction('legend-filter');
chart.interaction('legend-visible-filter');
continuous-filter
连续图例的数据过滤,数据过滤会导致坐标轴的变化
// 筛选数据
registerInteraction('continuous-filter', {
start: [{ trigger: 'legend:valuechanged', action: 'data-filter:filter' }],
});
-
触发的对象:图例 legend
-
触发事件:valuechanged
-
action 是数据过滤的 data-filter
continuous-visible-filter
仅仅过滤图形,而不引起坐标轴的变化
// 筛选数据
registerInteraction('continuous-visible-filter', {
start: [{ trigger: 'legend:valuechanged', action: 'element-filter:filter' }],
});
-
action 是数据过滤的 element-filter
注意:由于内置了 continuous-filter 交互,所以使用该交互时移除掉 continuous-filter 交互
chart.removeInteraction('continuous-filter');
chart.interaction('continuous-visible-filter');
legend-active
图例项 active,对应的图表元素也 active
// legend hover,element active
registerInteraction('legend-active', {
start: [{ trigger: 'legend-item:mouseenter', action: ['list-active:active', 'element-active:active'] }],
end: [{ trigger: 'legend-item:mouseleave', action: ['list-active:reset', 'element-active:reset'] }],
});
legend-highlight
图例项高亮,对应的图表元素也高亮
// legend hover,element active
registerInteraction('legend-highlight', {
start: [{ trigger: 'legend-item:mouseenter', action: ['list-highlight:highlight', 'element-highlight:highlight'] }],
end: [{ trigger: 'legend-item:mouseleave', action: ['list-highlight:reset', 'element-highlight:reset'] }],
});
axis-label-highlight
坐标轴文本高亮,对应的图表元素也高亮
// legend hover,element active
registerInteraction('axis-label-highlight', {
start: [{ trigger: 'axis-label:mouseenter', action: ['list-highlight:highlight', 'element-highlight:highlight'] }],
end: [{ trigger: 'axis-label:mouseleave', action: ['list-highlight:reset', 'element-highlight:reset'] }],
});
element-list-highlight
鼠标触发图表元素高亮,同时对应的列表组件(图例、坐标轴文本)都高亮
// legend hover,element active
registerInteraction('element-list-highlight', {
start: [{ trigger: 'element:mouseenter', action: ['list-highlight:highlight', 'element-highlight:highlight'] }],
end: [{ trigger: 'element:mouseleave', action: ['list-highlight:reset', 'element-highlight:reset'] }],
});
brush
框选过滤图形
registerInteraction('brush', {
showEnable: [
{ trigger: 'plot:mouseenter', action: 'cursor:crosshair' },
{ trigger: 'plot:mouseleave', action: 'cursor:default' },
start: [
trigger: 'plot:mousedown',
action: ['brush:start', 'rect-mask:start', 'rect-mask:show'],
processing: [
trigger: 'plot:mousemove',
action: ['rect-mask:resize'],
end: [
trigger: 'plot:mouseup',
action: ['brush:filter', 'brush:end', 'rect-mask:end', 'rect-mask:hide'],
rollback: [{ trigger: 'dblclick', action: ['brush:reset'] }],
});
-
触发对象都是 plot
-
相关的 Action 有 cursor, brush, rect-mask
brush-x
把上面 brush Action 换成 brush-x 即成为新的交互,仅框选 x 轴相关的数据
brush-y
把上面 brush Action 换成 brush-y 即成为新的交互,仅框选 y 轴相关的数据
brush-visible
框选过滤时仅仅是过滤图形,而不是过滤数据
registerInteraction('brush-visible', {
showEnable: [
{ trigger: 'plot:mouseenter', action: 'cursor:crosshair' },
{ trigger: 'plot:mouseleave', action: 'cursor:default' },
start: [
trigger: 'plot:mousedown',
action: ['rect-mask:start', 'rect-mask:show', 'element-range-highlight:start'],
processing: [
trigger: 'plot:mousemove',
action: ['rect-mask:resize', 'element-range-highlight:highlight'],
{ trigger: 'mask:end', action: ['element-filter:filter'] },
end: [
trigger: 'plot:mouseup',
action: ['rect-mask:end', 'rect-mask:hide', 'element-range-highlight:end', 'element-range-highlight:clear'],
rollback: [
trigger: 'dblclick',
action: ['element-filter:clear'],
});
交互反馈 Action 列表
上面的交互语法中,我们使用大量的 Action,每个 Action 都是对某个触发的响应,G2 提供几个大类别的 Action
-
鼠标的 Action
-
Chart/View 上的 Action
-
图表元素 Element 的 Action
-
组件的 Action
-
数据操作的 Action
-
辅助交互图形的 Action
鼠标的 Action
鼠标的 Action 只有一个: cursor
cursor
鼠标的 Action
cursor
用于显示各种鼠标的形状,每种形状有一个方法:
-
default() 默认的鼠标形状
-
pointer() 光标呈现为指示链接的指针(一只手)
-
move() 此光标指示某对象可被移动。
-
crosshair() 光标呈现为十字线。
-
wait() 此光标指示程序正忙(通常是一只表或沙漏)。
-
help() 此光标指示可用的帮助(通常是一个问号或一个气球)。
-
text() 此光标指示文本。
-
eResize() 此光标指示矩形框的边缘可被向右(东)移动。
-
wResize() 此光标指示矩形框的边缘可被向左(西)移动。
-
nResize() 此光标指示矩形框的边缘可被向上(北)移动。
-
sResize() 此光标指示矩形框的边缘可被向下(南)移动。
-
neResize() 光标指示可移动的方向 右上方(东北)
-
nwResize() 光标指示可移动的方向 左上方(西北)
-
seResize() 光标指示可移动的方向右下方(东南)
-
swResize() 光标指示可移动的方向左下方(西南)
-
nsResize() 光标指示可以在上下方向移动
-
ewResize() 光标指示可以在左右方向移动
-
zoomIn() 光标显示可以被放大
-
zoomOut() 光标显示可以缩小尺寸
Chart/View 的 Action
Chart 和 View 上的 Action 用户控制视图的变化,目前支持的有:
-
view-move
-
scale-translate
-
scale-zoom
view-move
用于移动 View 的位置,支持以下几个方法:
-
start() 开始移动
-
end() 结束移动
-
move() 移动
-
reset() 回滚,恢复初始位置
scale-translate
通过改变 scale 的位移,改变整个视图的位置变化,可以实现图表内部绘制区域的变化
-
start() 开始移动
-
end() 结束移动
-
translate() 修改 scale 的值
-
reset() 回滚,恢复初始状态
scale-zoom
-
zoomIn() 缩小
-
zoomOut() 放大
-
reset() 恢复
mousewheel-scroll
-
scroll() 鼠标滚轮
chart.interaction("plot-mousewheel-scroll");
chart.option('scrollbar', {
type: 'horizontal',
});
在鼠标滚动事件(向下滚动或向上滚动)上滚动的图表数据项的数量可以通过如下设置
wheelDelta
参数来自定义:
chart.interaction("plot-mousewheel-scroll", {
start: [{ trigger: 'plot:mousewheel', action: 'mousewheel-scroll:scroll', arg: { wheelDelta: 5 } }],
});
chart.option('scrollbar', {
type: 'horizontal',
});
Element 的 Action
图表元素 Element 的 Action 大都与状态相关,支持的 Action 有:
-
element-active
-
element-single-active
-
element-range-active
-
element-selected
-
element-single-selected
-
element-range-selected
-
element-highlight
-
element-single-highlight
-
element-range-highlight
-
element-filter
-
element-sibling-filter
-
element-sibling-highlight
-
element-link-by-color
Element 的 Action 可以响应的触发源:
-
直接在图表元素 Element 上的事件,例如:element:mousedown, element:mouseenter 等
-
来自组件的事件, 例如: 'legend-item:mouseenter'
element-active
用于设置和取消图表元素的 active,支持多个元素一起 active 有以下方法:
-
active() 设置当前触发事件相关元素的 active
-
toggle() 设置/取消当前触发事件相关元素的 active
-
reset() 取消当前触发事件相关元素的 active
-
clear() 取消所有元素的 active
element-single-active
用于设置和取消图表元素的 active,只允许单个元素 active 有以下方法:
-
active() 设置当前触发事件相关元素的 active
-
toggle() 设置/取消当前触发事件相关元素的 active
-
reset() 取消当前触发事件相关元素的 active
element-selected
用于设置和取消图表元素的 selected,支持多个元素一起 selected 有以下方法:
-
selected() 设置当前触发事件相关元素的 selected
-
toggle() 设置/取消当前触发事件相关元素的 selected
-
reset() 取消当前触发事件相关元素的 selected
-
clear() 取消所有元素的 selected
element-single-selected
用于设置和取消图表元素的 selected ,只允许单个元素 selected 有以下方法:
-
selected() 设置当前触发事件相关元素的 selected
-
toggle() 设置/取消当前触发事件相关元素的 selected
-
reset() 取消当前触发事件相关元素的 selected
element-highlight
用于设置和取消图表元素的 highlight,支持多个元素一起 highlight 有以下方法:
-
highlight() 设置当前触发事件相关元素的 highlight
-
toggle() 设置/取消当前触发事件相关元素的 highlight
-
reset() 取消当前触发事件相关元素的 highlight
-
clear() 取消所有元素的 highlight
在 element-highlight 的基础上额外增加了两个 action :
-
element-highlight-by-x,在 一个 element 上高亮时,同时高亮 x 值相同的 elements
-
element-highlight-by-color, 在 一个 element 上高亮时,同时高亮 color 相同的 elements
element-single-highlight
用于设置和取消图表元素的 highlight ,只允许单个元素 highlight 有以下方法:
-
highlight() 设置当前触发事件相关元素的 highlight
-
toggle() 设置/取消当前触发事件相关元素的 highlight
-
reset() 取消当前触发事件相关元素的 highlight
element-range-highlight
用于设置和取消图表元素的 highlight ,允许框选 highlight 有以下方法:
-
start() 开始框选
-
end() 结束框选
-
highlight() 高亮框选内部的元素
-
clear() 清理框选的元素
注意
:如果事件由 mask 触发,则可以直接调用 highlight,而不需要 start 和 end
element-sibling-highlight
图表元素高亮时,对应的其他 view 的图形也同时高亮,这个 Action 是从 element-range-highlight 扩展出来的,可以配合 element-range-highlight 一起使用:
-
highlight() 设置当前触发事件相关元素对应的其他 View 上的元素的 highlight
-
clear() 取消相关元素的 highlight
element-filter
图表元素的过滤,支持来自图例(分类和连续)、坐标轴文本的触发,有以下方法:
-
filter() 过滤
-
reset() 取消过滤
element-link-by-color
用于连接相同颜色的图表元素,一般用于层叠柱状图,有以下方法:
-
link() 连接
-
unlink() 取消连接
-
clear() 清除所有连接
数据操作的 Action
当前仅提供了数据过滤的 Action:
-
data-filter
-
brush
-
brush-x
-
brush-y
-
sibling-filter
-
sibling-x-filter
-
sibling-y-filter
data-filter
数据过滤的触发同 element-filter 一样支持图例和坐标文本的事件,但仅支持一个 filter 方法
-
filter() 过滤
brush
数据的范围过滤,同时支持 x,y 的过滤,需要理解范围过滤的周期:
-
start() 指定范围过滤的起始位置
-
filter() 过滤
-
end() 结束过滤
-
reset() 取消当前 brush 导致的过滤
如果未指定 start() 无法进行 filter(),如果不结束 end() 则容易引起错误,看一个框选过滤的示例:
registerInteraction('element-brush', {
showEnable: [
{ trigger: 'plot:mouseenter', action: 'cursor:crosshair' },
{ trigger: 'plot:mouseleave', action: 'cursor:default' },
start: [
trigger: 'plot:mousedown',
action: ['brush:start', 'rect-mask:start', 'rect-mask:show'],
processing: [
trigger: 'plot:mousemove',
action: ['rect-mask:resize'],
end: [
trigger: 'plot:mouseup',
action: ['brush:filter', 'brush:end', 'rect-mask:end', 'rect-mask:hide'],
rollback: [{ trigger: 'dblclick', action: ['brush:reset'] }],
});
-
mousedown 是开始过滤 start()
-
mouseup 时对数据进行过滤 filter() ,同时设置结束 end()
如果不设置结束 end ,则用户在外部 mousedown,移动到画布上时 mouseup 会直接触发 filter
brush-x
数据的范围过滤,仅支持 x 坐标轴范围的过滤,同样有四个方法:
-
start() 指定范围过滤的起始位置
-
filter() 过滤
-
end() 结束过滤
-
reset() 取消当前 brush 导致的过滤
brush-y
数据的范围过滤,仅支持 y 坐标轴范围的过滤,同样有四个方法:
-
start() 指定范围过滤的起始位置
-
filter() 过滤
-
end() 结束过滤
-
reset() 取消当前 brush 导致的过滤
sibling-filter
数据范围过滤,但不在当前的 view 上生效,而在当前的 view 同一层级的其他 views 上生效,用于实现联动过滤
-
start() 指定范围过滤的起始位置
-
filter() 过滤
-
end() 结束过滤
-
reset() 取消当前 brush 导致的过滤
sibling-x-filter
仅作用于 x 轴的过滤
sibling-y-filter
仅作用于 y 轴的过滤
组件 Action
组件允许的交互都需要通过 Action 来体现,目前支持的 Action 有:
-
tooltip
-
list-active
-
list-highlight
-
list-unchecked
-
list-selected
为了用户使用方面我们还从 list-highlight 中扩展出两个 Action
-
legend-item-highlight
-
axis-label-highlight
tooltip
显示隐藏 tooltip 的 Action 提供了两个方法:
-
show()
-
hide()
list-active
分类图例项和坐标轴文本高亮的 Action,有下面几个方法:
-
active() 设置 active
-
reset() 取消 active
-
toggle() 设置或者取消 active
-
clear() 取消所有的 active
list-highlight
分类图例项和坐标轴文本高亮的 highlight , 有下面几个方法:
-
highlight() 设置 highlight
-
reset() 取消 highlight
-
toggle() 设置或者取消 highlight
-
clear() 取消所有的 highlight
legend-item-highlight
是从 list-highlight 扩展出来的 Action,在 Element 上触发时仅高亮对应图例的选项,而不会影响坐标轴文本,同样有 4 个方法:
-
highlight() 设置 highlight
-
reset() 取消 highlight
-
toggle() 设置或者取消 highlight
-
clear() 取消所有的 highlight
axis-label-highlight
是从 list-highlight 扩展出来的 Action,在 Element 上触发时仅高亮对应坐标轴文本,而不会影响图例项,同样有 4 个方法:
-
highlight() 设置 highlight
-
reset() 取消 highlight
-
toggle() 设置或者取消 highlight
-
clear() 取消所有的 highlight
list-unchecked
由于图例项和坐标轴文本默认状态都是 checked ,所以我们实现了 list-unchecked 的 Action,支持的方法:
-
unchecked() 设置 unchecked
-
reset() 取消 unchecked
-
toggle() 设置或者取消 unchecked
-
clear() 取消所有的 unchecked
list-selected
分类图例项和坐标轴文本高亮的 selected , 有下面几个方法:
-
selected() 设置 selected
-
reset() 取消 selected
-
toggle() 设置或者取消 selected
-
clear() 取消所有的 selected
辅助交互的 Action
在交互过程中辅助出现的图形,目前仅实现了几种常见的:
-
active-region
mask 遮罩层,内置了几种 mask
-
rect-mask
-
circle-mask
-
path-mask
button 按钮
-
reset-button 恢复按钮
active-region
鼠标在画布上移动是,对应的区域出现背景框,有两个方法:
-
show() 显示背景框
-
hide() 隐藏背景框
rect-mask
在画布上进行框选,出现矩形的遮罩层:
-
start() 开始框选
-
show() 显示遮罩层
-
resize() 改变大小
-
hide() 隐藏遮罩层
-
end() 结束框选
circle-mask
在画布上进行框选,出现圆形的遮罩层,有以下方法:
-
start() 开始框选
-
show() 显示遮罩层
-
resize() 改变大小
-
hide() 隐藏遮罩层
-
end() 结束框选
path-mask
在画布上进行框选,在多个点上形成 path,有以下方法
-
start() 开始框选
-
show() 显示遮罩层
-
addPoint() 添加一个点