AntV移动可视化F2个人使用总结

最近在做移动端App时,用到了AntV移动可视化F2,发现网上对F2使用的资料甚少。
通过F2的文档和自己的摸索,总结了几个常用图表以及常用功能的用法。

安装与引用
安装

打开项目所在的终端,输入以下命令
npm install @antv/f2 --save
在这里插入图片描述

//引用
import F2 from '@antv/f2';
chart对象的创建和基本配置

1、创建一个canvas元素(宽高可以在标签上设置,也可以在之后的chart对象中设置)

<canvas id="myChart" width="400" height="300"></canvas>

2、创建一个chart对象

const chart = new F2.Chart();

3、对chart对象进行自己想要的操作和配置

const chart = new F2.Chart({
				id: 'myChart', //指定canvas元素
				pixelRatio: window.devicePixelRatio, // 设置像素比
				width: 400, //画布的长(也可以直接在canvas标签上设置)
				height: 300, //画布的宽(同理)
				padding: [10, 10, 20, 30], //绘图区和图表边框的距离, 用来显示坐标轴文本、图例 。
				appendPadding: 10, //图表的外边距
			});

在这里插入图片描述
以下是之后渲染图表所用到的数据data

const data = [{
			name: '芳华',
			percent: 0.22,
			a: '1',
			date: '2017-06-04',
			value: 275
		}, {
			name: '妖猫传',
			percent: 0.05,
			a: '1',
			date: '2017-06-05',
			value: 115
		}, {
			name: '机器之血',
			percent: 0.33,
			a: '1',
			date: '2017-06-06',
			value: 120
		}, {
			name: '心理罪',
			percent: 0.17,
			a: '1',
			date: '2017-06-07',
			value: 350
		}, {
			name: '寻梦环游记',
			percent: 0.23,
			a: '1',
			date: '2017-06-08',
			value: 150
		}];
F2各函数介绍(常用的函数与函数中常用的属性)
source数据装载
//参数一: 需要渲染的数据  参数二: 对数据进行处理(Obj)。
chart.source(data, {
	percent: {
		tickCount: 7, //坐标轴刻度个数(具体看数据渲染是X轴还是Y轴, 来操作对应轴的刻度数)
		formatter(val) { //格式化数据
			return val*100 + '%'
		},
		ticks: [80, 100, 120, 140, 160], //指定坐标轴上刻度点的文本信息, 会按照 ticks 的个数和文本来显示(经测试, 仅对数值类字段有效)
	},
	date: {
		type: 'timeCat', //分三种类型: 1、linear: 数值类型; 2、cat: 分类类型(如: 男, 女); 3、timeCat: 时间类型。
		//range: [0, 1], //数据在画布的输出范围, 值为Array, 取值范围为0~1。
		mask: 'YYYY-MM', //用来格式化日期格式(只有type为timeCat时才可以)
	}
});

在这里插入图片描述
在这里插入图片描述

tooltip提示信息
chart.tooltip(false); //关闭提示信息
chart.tooltip({
	alwaysShow: true, //移出触发区域, 是否仍显示提示框内容(false)
	showTooltipMarker: true, //是否显示 tooltipMarker
	tooltipMarkerStyle: { //设置 tooltipMarker 的样式
		fill: 'red', //颜色
	},
	showItemMarker: true, //是否显示每条记录项前面的 marker
	itemMarkerStyle: { //设置每条记录项前面的 marker 的样式
		radius: 10,
		fill: 'green'
	},
	offsetX: 0, //X方向的偏移
	offsetY: 0, //Y方向的偏移
	triggerOn: ['touchstart', 'touchmove'], //tooltip 的触发行为
	triggerOff: 'touchend', //tooltip 消失的触发行为(与alwaysShow 同时设置时, alwaysShow会失效)
	showTitle: true, //是否展示标题(false)
	showCrosshairs: true, //是否显示辅助线
	crosshairsStyle: { //配置辅助线的样式
		stroke: 'rgba(0, 0, 0, 0.25)',
				lineWidth: 2
	},
	background: { //设置 tooltip 背景样式
		radius: 10,
		fill: 'yellow',
		padding: [ 6, 10 ]
	},
	titleStyle: { //tooltip 标题的文本样式
		fontSize: 24,
		fill: 'red',
		textAlign: 'start',
		textBaseline: 'top'
	},
	nameStyle: { //tooltip name 项的文本样式配置
		fontSize: 12,
		fill: 'skyblue',
		textAlign: 'start',
		textBaseline: 'middle'
	},
	valueStyle: { //tooltip value 项的文本样式配置
		fontSize: 24,
		fill: 'red',
		textAlign: 'start',
		textBaseline: 'middle'
	},
	crosshairsType: 'xy', //辅助线的种类 有三个值: 1、x 2、y(默认) 3、xy
	showXTip: true, //是否展示 X 轴的辅助信息
	showYTip: true, //是否展示 Y 轴的辅助信息
	xTip: { //配置 x 轴辅助信息的文本样式
		fontSize: 10, // 字体大小
		fill: '#1890ff', // 字体颜色
	},
	yTip(val) { //配置 y 轴辅助信息的文本样式
		// 返回值必须是对象
		return {
			val: val.toFixed(2),//这里随便写的, 如果是非 Number 类型会报错, 导致图标渲染失败!
		};
	},
	snap: true, //是否将辅助线准确定位至数据点
	onShow: function onShow(ev) { //点击显示详情
		const items = ev.items;
		items[0].name = null;
    	items[0].name = items[0].title;
    	items[0].value = '¥ ' + items[0].value;
	}
	});

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Axis坐标轴配置
chart.axis(false); //不渲染坐标轴
chart.axis('date', { //渲染坐标轴(默认true) 参数一: 选择设置的字段(当前设置的为 x 轴)
	label: function(text, index, total) { //配置坐标轴文本(当值为回调函数时, 返回值必须为对象)
		//console.log(text, index, total);
		const textCfg = {};
		if (index === 0) {
			textCfg.textAlign = 'center'; //textAlign: 设置坐标文本在刻度线的位置
		} else if (index === total - 1) {
			textCfg.textAlign = 'center';
		}
		return textCfg;
	},
	line: { //配置坐标轴线
		top: false,
		stroke: 'red', //轴线颜色
		lineWidth: 1 //轴线粗细
	},
	labelOffset: 20, //坐标文本与轴线的距离
	tickLine: { //配置坐标轴刻度线样式
		lineWidth: 1, //刻度线宽度
		stroke: 'red', //刻度线颜色
		length: 5 //刻度线长度
	},
	grid: function(text, index, totle) { //配置坐标轴网格线(在极坐标下, 可通过配置 type: 'arc'; 绘制圆弧; 当值为回调函数时, 返回值必须为对象)
		console.log(text, index, totle);
		if(text === '2017-06-30') {
			return {
				stroke: 'yellow',
			}
		}
		return {
			stroke: 'green',
		}
	},
	position: 'bottom' //配置坐标轴显示位置(当配置 x 轴时, 默认为 bottom, 无法配置其他值)
})

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Geometry几何标记对象,决定了图表的类型
//绘制线图
chart
.line({ //绘制折线图
	connectNulls: false //设置是否连接空数据(false)
}) 
.position('date*value') //由 date 和 value 两个属性决定图形位置, date 映射至 x 轴, value 映射至 y 轴
.shape('smooth') //设置数据映射到图形的形状(值可以为 String, Object 或带有返回值的 function) 当用在 line 后面时, 值有三个: 1、line: 直线(默认值) 2、dash: 虚线 3、smooth: 平滑线

//绘制填充阴影
chart
.area({ //填充坐标系与线图之间的区域图 (填充颜色的透明度默认不是1)
	startOnZero: true //设置 Y 轴的基线是否从 0 开始(true)
}) 
.position('date*value') //同上
.color('l(90) 0:#1890FF 1:#f7f7f7') //1、color('red'): 将图标渲染成指定颜色(非数据源字段); 2、color('date'): 将指定字段进行映射(使用内置颜色 注: 字段的值必须为字符串); 3、color('date', ['red']): 按指定颜色映射; 4、color('date', 'red-blue-green'): 使用渐变色映射; 5、color('l(0) 0:red 0.5:blue 1:yellow'): 使用渐变色(l中填渐变的角度)
.shape('smooth') //同上 当为用在 area 后面时, 值有两个: 1、area(默认) 2、smooth
.style({ //配置图形渲染的样式
	fillOpacity: 1, //填充颜色的透明度
	lineWidth: 1, //画笔线条的宽度
	//stroke: '#fff' //画笔的颜色
})
.size(10) //配置数据映射到图形的大小(值可以为 Number 或 字段名) (当图形受其他样式影响时, 会被覆盖: 权重不高)

//绘制柱状图与饼图
chart.interval() //笛卡尔坐标系时为柱状图, 极坐标系下为饼图、环图等
.adjust({ //几何标记对象调整数据;
	type: 'dodge', //type有两个值 1、stack: 层叠图 2、dodge: 分组图; 
	marginRatio: 0 //调整分组各柱子间的间距, 取值范围(0 ~ 1), 仅当 type = 'dodge' 时生效
})
.style({
    lineWidth: 2,
    stroke: '#fff',
    lineJoin: 'round',
    lineCap: 'round'
  });

注:chart.interval() 等返回的不是 chart 对象,而是一个 geom 几何标记对象 Geom。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Coordinate配置坐标系
chart.coord('polar', { //设置坐标系: 1、笛卡尔坐标系(rect即直角坐标系)(默认); 2、极坐标系(polar)
transposed: true, //坐标系翻转
startAngle: Math.PI, //极坐标的起始角度(值为弧度制)
endAngle: 2*Math.PI, //极坐标的结束角度(值为弧度制)
innerRadius: 0.5, //内圈的半径(绘制圆环时用到)
radius: 0.8, //圆的半径
})

在这里插入图片描述
在这里插入图片描述

Legend图例

注: color, size 这两个图形属性如果判断接收的参数是数据源的字段时,会自动生成不同的图例

chart.legend({ //设置图例 值为 false 关闭图例 当 color 映射某个字段时, 设置字段无效
	position: 'right', //设置图例的位置 'top'(默认)、 'right'、 'bottom'、 'left'
	align: 'center', //当 position 为 'top' 或 'bottom' 时生效, 值可设置为 'left'(默认)、 'center'、 'right'
	verticalAlign: 'top', //当 position 为 'left' 或 'right' 时生效, 值可设置为 'top'、 'middle'、 'bottom'
	itemWidth: 5, //设置每个图例的宽度(Number), 默认 auto
	showTitle: true, //是否显示图例标题(false)
	titleStyle: { //设置图例标题的样式
		textAlign: 'left', //文本对齐方式 
		fill: 'pink', // 文本的颜色
		fontSize: 18, // 文本大小
		fontWeight: 'bold', // 文本粗细
		textBaseline: 'middle' //文本基准线
	},
	offsetX: 5, //图例 x 方向的整体偏移(0)
	offsetY: 5, //图例 y 方向的整体偏移(0)
	titleGap: 15, //标题与图例的距离(12) 显示标题时生效
	itemMarginBottom: 15, //每个图例的下方留白(12)
	wordSpace: 5, //marker 与文本之间的距离(6)
	unCheckStyle: { //设置取消选中的图例 marker 以及文本的样式
		fill: 'red'
	},
	clickable: true, //是否允许点击(true)
	itemFormatter: function(val) { //格式化每项的文本
		return val.slice(0, 4)
	},
	marker: {
		symbol: 'circle', // marker 的形状
		radius: 5 // 半径大小
	}, //设置图例 marker 的样式 值为 String 类型时, 可选 square 或 circle(默认), 值为 Object 类型时, 可配置一些绘图属性
	nameStyle: { //设置图例项的文本样式
		fill: 'skyblue',
		fontSize: 12
	},
	selectedMode: 'single', //设置图例的选中模式 multiple(多选默认) 或 single(单选)
})

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Animate动画机制
chart.animate({ //配置动画效果 值为 false 时, 关闭动画效果
	appear: { //出场动画配置
		animation: 'fadeIn', //执行的具体动画(内置的动画名或 Function)
		easing: 'bounceOut', //动画缓动函数(内置的动画名或 Function)
		delay: 0.5, //动画延迟执行时间 单位 ms
		duration: 1200 //动画执行时间 单位 ms
	},
	update: {}, //更新动画配置(参数同appear)
	enter: {}, //图表发生数据变更时,新进场的元素动画配置(参数同appear)
	leave: {} //离场动画配置(参数同appear)
	});

具体动画效果请参考F2文档

pieLabel用于绘制饼图文本的插件
chart.pieLabel({ //绘制饼图文本的插件
	sidePadding: 30, //文本与画布左右的距离(Number)
	anchorOffset: 2, //锚点的偏移量
	anchorStyle: { //锚点的样式
		fill: '', //锚点的颜色(String)
	},
	inflectionOffset: 2, //拐点的偏移量
	skipOverlapLabels: true, //是否忽略重叠文本(false)
	activeShape: true, //图形被选中的时, 是否激活图形(false)
	activeStyle: { //激活图形的样式
		offset: -1, //激活光环偏移距离
		fillOpacity: 1, //激活光环的填充透明度
		appendRadius: 4 //激活光环大小
	},
	lineStyle: { //连接线的样式
		stroke: 'rgba(255,0,0,0.3)', //设置画笔的颜色(#000)
	},
	lineHeight: 2, //文本的行高(Number)
	label1: function (data) { //默认连接线上方的文本(带返回值的函数, 返回值必须为 Object), 位置可通过 label1OffsetY 调整
		return {
			text: '¥' + data.money, //展示的文本
			fill: '#343434', //文本颜色
			fontWeight: 'bold' //字体样式
			textAlign: 'end' //字体位置
		}
	},
	label1OffsetY: 10, //label1与连接线垂直方向的偏移, 位置可通过 label2OffsetY 调整
	label2: function(data) { //默认连接线下方的文本(配置与label1相同)
		return {
	      text: data.type,
	      fill: '#999',
	      offset: 10, //会被外部的 label2OffsetY 覆盖
	      textAlign: 'end',
		};
	},
	label2OffsetY: 10, //label2与连接线垂直方向的偏移
	onClick: function(ev) { //点击事件 ev(事件对象)       ev: { chart: {}, dat: {}, native: {}, type: 'click', x: 339, y: 67}
		const data = ev.data; //被点击图形的原始数据
		if (data) {
			$('#title').text(data.type);
			$('#money').text(data.money);
		}
	}
});

在这里插入图片描述
注: 当锚点的偏移量和拐点的偏移量相等时,连接线会变成一条直线
在这里插入图片描述
在这里插入图片描述

Guide绘制图表的辅助元素
data.forEach(function(obj) {
	chart.guide().text({
	    position: [ obj.action, 2.5 ],
	    content: (obj.percent * 100).toFixed(0) + '%',
	    style: {
	      textBaseline: 'middle',
	      textAlign: 'center',
	      fill: '#fff'
	    }
	  });
	 chart.guide().html({
	   position: [ '41%', obj.total*19+ 2 +'%'],
	   alignX: 'left',
	   alignY: 'bottom',
	   offsetX: 25,
	   html: `<div style="flex-direction: row;align-items: center;display: flex;"><div style="height:0.5px;background-color:#999999;width:150px;"></div><div style="margin-left:0px;font-size: 12px;color:#666666;text-align: left;white-space:nowrap;flex-direction: row;align-items: center;display: flex;"><div style="margin-left:10px;padding-right: 0px;width:80px">${obj.action}</div></div></div>`,
	 });
 }

在这里插入图片描述

结尾

由于项目中只用到了这几个常用的图标,所以才看了看,顺便总结了一下。
如果有描述不准确的地方,欢迎留言指正!

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值