Skip to content

Latest commit

 

History

History
365 lines (302 loc) · 10.6 KB

chart.md

File metadata and controls

365 lines (302 loc) · 10.6 KB

Chart

图表组件,内部生成了一个 G2 chart 实例,同时控制着其他子组件的加载和更新。

子组件

<Chart height={400} data={dv} scale={cols} forceFit>
  <Axis name="month" />
  <Axis name="temperature" label={{formatter: val => `${val}°C`}}/>
  <Tooltip crosshairs={{type : "y"}}/>
  <Geom type="line" position="month*temperature" size={2} color={'city'} />
  <Geom type='point' position="month*temperature" size={4} shape={'circle'} color={'city'} style={{ stroke: '#fff', lineWidth: 1}} />
</Chart>

在线编辑

图表布局

e9d103b3-1707-446e-b5fe-b535f7048c8b.png 有时候坐标轴、图例等绘图区域外的组件显示不全时,可以通过调整图表各个方向的 padding 来调整最终效果

属性

1、forceFit * Boolean *

设置图表的宽度是否自适应,设置为 true,则图表 chart 会继承父元素的宽度,用户设置的 width 则不生效。 默认值: false

2、width * Number *

指定图表的宽度,默认单位为 'px',当 forceFit: true 是宽度不生效。

3、height * Number(必填) *

指定图表的高度,默认单位为 'px'。

4、data * Array/DataSet *

图表数据源,是一个包含 JSON 对象的数组或者 DataView 对象。 具体参见 数据

5、scale * Object *

(fieldName: string, scaleConfig: object) | (scaleConfig: object) 图表数据源相关的比例尺信息,scaleConfig 可配置属性如下。

scale={{
  fieldName:'sales',
  //scaleConfig
  {
	type: 'identity' | 'linear' | 'cat' | 'time' | 'timeCat' | 'log' | 'pow', // 指定数据类型
	alias: string, // 数据字段的别名
	formatter: function, // 格式化文本内容
	range: array, // 输出数据的范围,默认[0, 1],格式为 [min, max],min 和 max 均为 0 至 1 范围的数据。
	tickCount: number, // 设置坐标轴上刻度点的个数
	ticks: array, // 用于指定坐标轴上刻度点的文本信息,当用户设置了 ticks 就会按照 ticks 的个数和文本来显示
	sync: boolean // 当 chart 存在不同数据源的 view 时,用于统一相同数据属性的值域范围
  }
}}

!注意:除了以上属性外,不同的 type 还对应有各自的可配置属性,详见 Scale 度量 API;

6、placeholder * string *

图表source为空时显示的内容。 默认值: <div style={{ position: 'relative', top: '48%', textAlign: 'center' }}>暂无数据</div> ;会在图表区域的中间显示 "暂无数据" 。

7、padding * Object/Number/Array *

图表内边距。 有如下三种配置格式。

//有时候坐标轴、图例等绘图区域外的组件显示不全时,可以通过调整图表各个方向的 padding 来调整最终效果
padding={[ 20, 30, 20, 30]}
padding={20}
padding={{ top: 20, right: 30, bottom: 20, left: 30 }}

8、animate * Boolean *

是否执行动画。 默认值: true

9、background * Object *

图表背景样式设置。

//可配置样式有
{
  fill: string, // 图表背景色
  fillOpacity: number, // 图表背景透明度
  stroke: string, // 图表边框颜色
  strokeOpacity: number, // 图表边框透明度
  opacity: number, // 图表整体透明度
  lineWidth: number, // 图表边框粗度
  radius: number // 图表圆角大小
}

10、plotBackground * Object *

图表背景样式设置。

//可配置样式有
{
  fill: string, // 图表背景色
  fillOpacity: number, // 图表背景透明度
  stroke: string, // 图表边框颜色
  strokeOpacity: number, // 图表边框透明度
  opacity: number, // 图表整体透明度
  lineWidth: number, // 图表边框粗度
  radius: number // 图表圆角大小
}

11、pixelRatio * Number *

设置设备像素比,默认取浏览器的值 window.devicePixelRatio

12、filter Array

过滤数据,如果存在对应的图例,则过滤掉的字段置灰。 Array:[[fieldString1, callback1], [fieldString2, callback2]]

<Chart filter={[['x', (val) => {return val > 20;}]]}/>

13、className String

设置图标最外层div的类名。

<Chart className="chart1" />

14、style Object

设置图标最外层div的样式。

const style={fontSize: '12'}
<Chart style={style} />

事件属性

<chart/>组件提供了各种事件,方便用户扩展交互。基本的事件用法如下:

<chart
  onEvent={e => {
    //do something
  }}
/>

更新属性时,如果某事件不指定监听函数,表示删除该事件。

下面列出了 <chart/> 支持的所有事件属性。

1、onGetG2Instance

获取 chart 实例的回调。每当生成一个新 chart 时就会调用该函数,并以新生成的 chart 作为回调参数。

<chart
  onGetG2Instance={g2Chart => {
	g2Chart.animate(false);
	console.log(g2Chart);
  }}
/>

2、onPlotMove

鼠标在绘图区域移动时触发,在图表的绘图区域外不触发。

  • ev 表示事件触发时返回的对象,包含以下属性
    • x:当前鼠标所在的画布上的 x 坐标;
    • y:当前鼠标所在的画布上的 y 坐标;
    • target:canvas 对象;
    • toElement:当前 dom 元素;
    • shape: 当前鼠标所在的 shape 对象;
    • views: Array,当前鼠标所在的视图。
<chart
  onPlotMove={ev => {
	var point = {
	  x: ev.x,
	  y: ev.y
	};
	var items = chart.getTooltipItems(point);
	console.log(items);
  }}
/>

3、onPlotEnter

鼠标进入绘图区域时触发。

  • ev 表示事件触发时返回的对象,包含以下属性
    • x:当前鼠标所在的画布上的 x 坐标;
    • y:当前鼠标所在的画布上的 y 坐标;
    • target:canvas 对象;
    • toElement:当前 dom 元素;
    • views: Array,当前鼠标所在的视图。
<chart
  onPlotEnter={ev => {
	var point = {
	  x: ev.x,
	  y: ev.y
	};
	var items = chart.getTooltipItems(point);
	console.log(items);
  }}
/>

4、onPlotLeave

当鼠标移出绘图区域时触发。

  • ev 表示事件触发时返回的对象,包含以下属性
    • x:当前鼠标所在的画布上的 x 坐标;
    • y:当前鼠标所在的画布上的 y 坐标;
    • target:canvas 对象;
    • toElement:当前 dom 元素;
    • views: Array,当前鼠标所在的视图。
<chart
  onPlotEnter={ev => {
	var point = {
	  x: ev.x,
	  y: ev.y
	};
	var items = chart.getTooltipItems(point);
	console.log(items);
  }}
/>

5、onPlotClick

鼠标点击绘图区域时触发的事件。

  • ev 表示事件触发时返回的对象,包含以下属性
    • x:当前鼠标所在的画布上的 x 坐标;
    • y:当前鼠标所在的画布上的 y 坐标;
    • target:canvas 对象;
    • toElement:当前 dom 元素;
    • views: Array,当前鼠标所在的视图;
    • shape:点击的图表 shape,可能为空;
    • data:选中图形代表的数据,可能为空;
    • geom:选中的图形,可能为空。

6、onPlotDblClick

鼠标双击绘图区域时触发的事件。

  • ev: 事件触发时返回的对象,包含以下属性
    • x:当前鼠标所在的画布上的 x 坐标;
    • y:当前鼠标所在的画布上的 y 坐标;
    • target:canvas 对象;
    • toElement:当前 dom 元素;
    • views: Array,当前鼠标所在的视图;
    • shape:点击的图表 shape,可能为空;
    • data:选中图形代表的数据,可能为空;
    • geom:选中的图形,可能为空。

7、onItemSelected

图表元素被选中时触发。

  • ev: 事件触发时返回的对象,包含以下属性
    • shape:选中的图形;
    • data:选中图形中的数据;
    • geom:所选中的图表图层。

8、onItemUnselected

图表元素取消选中时触发。

  • ev: 事件触发时返回的对象,包含以下属性
    • shape:取消选中的图形;
    • data:取消选中图形代表的数据;
    • geom:所选中的图表图层。

9、onItemSelectedChange

图表元素选中发生改变时触发。

  • ev: 事件触发时返回的对象,包含以下属性
    • shape:选中的图形;
    • data:选中图形代表的数据;
    • preShape:之前选中的图形;
    • preData:选中图形代表的数据;
    • geom:所选中的图表图层。

10、onTooltipChange

tooltip 信息更新改变的时候触发。

  • ev:事件触发时返回的对象,包含以下属性:
    • tooltip: 当前生成的 tooltip 对象;
    • x: 画布上的 x 坐标;
    • y: 画布上的 y 坐标;
    • items: 当前 tooltip 中的数据项。

可以通过该事件回调函数,改变 items 中的内容来动态调整 tooltip 的显示内容。 示例代码:

<Chart
  onTooltipChange={(ev)=>{
    var items = ev.items; // tooltip显示的项
	var origin = items[0]; // 将一条数据改成多条数据
	var range = origin.point._origin.range;
	items.splice(0); // 清空
	items.push({
	  name: '开始值',
	  title: origin.title,
	  marker: true,
	  color: origin.color,
	  value: range[0]
	});
	items.push({
	  name: '结束值',
	  marker: true,
	  title: origin.title,
	  color: origin.color,
	  value: range[1]
	});
  }}
/>

11、onTooltipShow

tooltip 显示时触发。

  • ev:事件触发时返回的对象,包含以下属性:
    • tooltip: 当前生成的 tooltip 对象;
    • x: 画布上的 x 坐标;
    • y: 画布上的 y 坐标。

12、onTooltipHide

tooltip 隐藏或者消失时触发。

  • ev:事件触发时返回的对象,包含以下属性:
    • tooltip: 当前生成的 tooltip 对象。

13、图形元素事件

图形元素事件属性名 = on + 图形元素名称 + 基础事件名。

  • 图形元素名称有:
Point, Area, Line, Path, Interval, Schema, Polygon, Edage, AxisTitle, AxisLabel, AxisTicks, AxisLine, AxisGrid, LegendTitle, LegendItem, LegendMarker, LegendText, GuideText, GuideLine, GuideRegion, GuideImage, Label
  • 基础事件名有:
Mouseenter, Mousemove, Mouseleave, Click, Dblclick, Mousedown, Mouseup, Touchstart, Touchmove, Touchend

代码示例:

<Chart onPointMouseenter={function(ev){//some code}}/>