npm install @antv/f2
F2 是面向移动端的一套基于可视化图形语法的图表库,具有精简、高性能、易扩展的特性。适用于对性能、大小、扩展性要求很高的场景。站点
- id: 指定对应 canvas 的id
- el: 如果未指定 id 时可以直接传入 canvas 对象
- width:图表的宽度,如果 canvas 上设置了宽度,可以不传入
- height:图表的高度,如果 canvas 上设置了高度,可以不传入
- pixelRatio:画布的像素比,默认读取 Global 上的pixelRatio
- padding: 绘图区域(坐标轴包围的区域)跟画布边缘的边距,可以是数字或者数组[top, right, bottom, left]
var chart = new F2.Chart({
id: 'c1',
width: 500,
height: 500,
padding: [20,10, 50, 40]
});
-
source(data, defs) 设置
- data 图表显示的数据
- defs 图表数据的列定义
chart.source(data, { a: { min: 0, max: 100 } });
-
render() 渲染图表
chart.render();
-
clear() 清除图表内容
chart.clear(); // 清除 chart.line().position('a*b'); chart.render();
-
destroy () 销毁图表,canvas 元素不会销毁
chart.destroy();
-
axis(field, cfg|enable)
- field :坐标轴对应的字段
- cfg 坐标轴的配置信息, 也可以设置成 false
chart.axis('field', false); // 不显示该字段对应的坐标轴 chart.axis('field', { // 设置坐标轴线的样式,如果值为 null,则不显示坐标轴线 图形属性 line: { lineWidth: 1, stroke: '#ccc' }, // 标轴文本距离轴线的距离 labelOffset: 20, // 坐标点对应的线,null 不显示 图形属性 tickLine: { lineWidth: 1, stroke: '#ccc', value: 5,// 刻度线长度 }, // 0%处的栅格线着重显示 grid: function(text,index){ if(text === '0%'){ return { stroke: '#efefef' }; }else{ return { stroke: '#f7f7f7' }; } }, // 第一个点左对齐,最后一个点右对齐,其余居中,只有一个点时左对齐 label: function(text, index, total) { var cfg = { fill: '#979797', font: '14px san-serif', offset: 6 }; if (index === 0) { cfg.textAlign = 'left'; } if (index > 0 && index === total - 1) { cfg.textAlign = 'right'; } cfg.text = text + '%'; cfg.text 支持文本格式化处理 return cfg; }, });
-
guide() 创建辅助元素,详情查看 辅助元素
-
coord(type, cfg)
- type 坐标系类型,目前支持 rect,polar 两种
- cfg 坐标系的配置项,rect(直角坐标系) 和 polar(极坐标)的配置项不完全一样
- transposed 坐标系翻转
- startAngle polar (极坐标)的起始角度
- endAngle polar (极坐标)的结束角度
- innerRadius polar (极坐标)的内环半径
chart.coord('rect') // 直角坐标系 chart.coord('rect', { transposed: true // 坐标系翻转,柱状图会变成条形图 }); chart.coord('polar'); // 极坐标 chart.coord('polar', { startAngle: -Math.PI, endAngle: 0 }); chart.coord('polar', { transposed: true // 饼图一般使用这个坐标系 });
-
geometry() F2 支持的 geometry 有以下类型:
- point 点图
- path 线图
- line 线图
- interval 区间图
- area 面积图
- polygon 多边形
- schema 蜡烛图等特殊的图表
-
animate(cfg|false) 执行动画
- cfg|false 指定动画的配置项或者禁用动画
- type: 动画的类型:
- duration: 动画时间(毫秒),默认1000。
- easing: Function/String 缓动函数或缓动函数名称,默认easeInOut。支持linear、easeIn、easeOut、easeInOut、backIn、backOut、elastic、bounce
- success: Function 动画结束后执行的回调函数。
chart.animate(false);// 禁用动画 chart.animate({ duration: 2000, easing: 'elastic', success: function() { alert('ok'); } });
- cfg|false 指定动画的配置项或者禁用动画
-
getPosition(record) 获取数据对应在画布上的坐标。
var point = chart.getPosition({time: '2010-02-02', value: 20});
-
getRecord(point) 根据画布上的坐标获取对应的数据
var obj = chart.getRecord({x: 100, y: 100});
-
getSnapRecords(point, [field]) 根据画布上的坐标获取附近的数据
- point 画布上的点
- field 用于逼近数据的字段,默认都是x 轴对应的字段,但是饼图情况下需要自己指定对应 y 轴的字段
var records = chart.getSnapRecords({x: 100, y: 100});
-
position(feilds) 设置位置对应的字段
- fields 可以是字符串 'field1*field2' 也可以是 array ['field1', field2]
chart.point().position(['cut', 'price']); chart.interval().position('cut*price');
-
color(field, [colors]) 设置颜色对应的字段
- field 可以一个字段也可以多个,也可以是常量
- colors 可以是数组、回调函数
chart.point().position('x*y').color('x'); // 按照字段x 进行映射,使用内置的颜色 chart.point().position('x*y').color('red') // 设置常量颜色 chart.point().position('x*y').color('x', function(x) { if (x > 100) { return 'red'; } return blue; });
-
size(field, [sizes]) 设置大小对应的字段
- field 可以是一个字段也可以是多个,也可以是常量
- sizes 可以是数组、回调函数
point.size(10); // 常量 point.size('value'); // 使用字段映射到大小,使用内置的大小 point.size('value', [10, 30]); // 指定大小范围 point.size('value', function(value) { // 回调函数 if(type > 50) { return 10; } else { return 5; } });
-
shape(field, shapes)
- field 可以是一个字段也可以是多个,也可以是常量
- shapes 可以是数组、回调函数
point.shape('circle'); // 常量 point.shape('type'); // 使用字段映射到形状,使用内置的形状 point.shape('type', ['circle', 'diamond', 'square']); // 指定形状 point.shape('type', function(type) { // 回调函数 if(type === 'a') { return 'circle'; } else { return 'square'; } });
-
style([field], cfg) 指定图形的样式
- field 映射到样式的字段,可以不设置直接设置配置项 cfg
- cfg 配置项支持的属性,查看:canvas 属性 除此外提供了几个别名
- stroke: 边框, 是 strokeStyle 的简写
- fill: 填充色,是 fillStyle 的简写
- opacity:透明度,是 globalAlpha 的简写
-
adjust(type) 进行数据调整
- F2 目前仅支持 stack(层叠) 和 dodge(分组)的数据调整
- registerShape(geomType, shapeName, cfg)
- geomType 是 geometry 的类型,point,line,path,area,interval,polygon,schema
- shapeName 创建的shape 的名字
- cfg 指定自定义Shape 需要的函数
- getPoints(cfg) 自定义图形需要的点,是映射到0-1区间的值,path 和 line 不需要
- draw(cfg, canvas) 绘制对应的图形
为了方面用户将0-1 范围的值转换到画布上,提供了2个方法:
- parsePoint(point) 将数据点转换到画布坐标
- parsePoints(points) 将多个数据点转换到画布坐标
var drawShape = function(points, canvas, cfg) {
var ctx = canvas.getContext('2d');
ctx.beginPath();
ctx.moveTo(points[0].x,points[0].y);
if(points.length>1){
for (var i = 1; i <= points.length - 1; i++) {
ctx.lineTo(points[i].x,points[i].y);
}
}
ctx.fillStyle = cfg.fill;
ctx.fill();
};
//自定义绘制数据的的形状
var Shape = F2.Shape;
Shape.registerShape('interval', 'polygon', {
getPoints: function(cfg){
var x = cfg.x;
var y = cfg.y;
var y0 = cfg.y0;
var width = cfg.size;
return [
{x: x-width/2, y: y0},
{x: x, y: y},
{x: x+width/2, y: y0}
];
},
draw: function(cfg, canvas){
var points = this.parsePoints(cfg.points);
var style = cfg.style || {};
style.fill = cfg.color;
drawShape(points, canvas, style);
}
});
- drawLine(start, end, canvas, cfg)
- drawText(text, pos, canvas, cfg)
- drawCircle(center, radius, canvas, cfg)
- drawArc(center, radius, startAngle, endAngle, canvas, cfg)
- drawRect(points, canvas, cfg)
- drawShape(canvas, cfg, shapeFn)
- drawLines(points, canvas, cfg)
- drawFan(points, center, canvas, cfg)
- drawSmooth(points, canvas, cfg)
更详细的 API,参考 API详情