Flutter图表库fl_chart的使用解析(二)-折线图,带你一步一步深入Handler源码

),

LineChart的构造参数是一个LineChartData,其属性如下:

属性名称描述默认值
lineBarsData图表要展示的线的数组,数组的每一位代表一条线。[]
betweenBarsData填充2条图表线之间的区域[]
titlesData坐标,可以设置四个方向的标题FlTitlesData()
axisTitleData标题FlAxisTitleData()
extraLinesData额外的水平和垂直线的图形细节
lineTouchData触摸交互详细信息LineTouchData()
rangeAnnotations在图表后面显示范围注释,请检查RangeAnnotationsRangeAnnotations()
showingTooltipIndicators根据提供的位置(x)显示工具提示,以及LineBarSpot的列表[]
gridData网格数据FlGridData()
borderData边框数据FlBorderData()
minX获取x轴的最小值x,如果为null,从lineBars中读取值null
maxX获取x轴的最大x,如果为null,从lineBars中读取值null
minY获取y轴的最小y,如果为null,从lineBars中读取值null
maxY获取y轴的最大y,如果为null,从lineBars中读取值null
clipData将图表裁剪到边框(防止绘图超出边框)FlClipData.none()
backgroundColor图表后面绘制的背景色null

/// 配置文件
LineChartData sampleData() {
return LineChartData(
//? 是否可以点击
lineTouchData: LineTouchData(
enabled: enableLineTouchData,
),
//? 网格线配置
gridData: FlGridData(
show: showGridData,
),
axisTitleData: _buildFlAxisTitleData(),
//? 标题
titlesData: _buildTitles(),
//? 边框
borderData: _buildBorderData(),
minX: 0,
maxX: 14,
maxY: 6,
minY: 0,
//? 线条数据
lineBarsData: linesBarDatas(),
);
}

二 线条配置

配置了三条线,所以lineBarsData对应的数组有三个元素。

//? 绿线的配置
LineChartBarData(
//? 取样点
spots: [
FlSpot(1, 1),
FlSpot(3, 4),
FlSpot(5, 1.8),
FlSpot(7, 5),
FlSpot(10, 2),
FlSpot(12, 2.2),
FlSpot(13, 1.8),
],
//? 是否是曲线
isCurved: isCurved1,
// curveSmoothness: 0,
colors: const [
Color(0x444af699),
],
//? 线的宽度
barWidth: 4,
//? 线头是否是圆形
isStrokeCapRound: true,
//? 是否显示数据点
dotData: FlDotData(
show: false,
),
//? 是否显示线上区域
aboveBarData: BarAreaData(show: showAboveBarData, colors: [
const Color(0x444af699),
]),
)

看下LineChartBarData属性:

属性名称描述默认值
show是否显示或隐藏线条True
spots要展示的线条数据点,参考 FlSpot[]
colors线条颜色,如果提供了多种颜色,则将为渐变色[Colors.redAccent]
colorStops获取渐变颜色的停止位置,了解更多null
gradientFrom确定渐变梯度的开始,每个数字应介于0和1之间。阅读更多Offset(0,0)
gradientTo确定渐变的结束,每个数字应介于0和1之间。阅读更多Offset(1,0)
barWidth线条的宽度2.0
isCurved是平滑曲线还是折线false
curveSmoothness曲线角的平滑度半径(当isCurved为true时起作用)0.35
preventCurveOverShooting防止在线性序列点上绘制曲线时出现过冲,请检查此问题false
preventCurveOvershootingThreshold应用防止过冲算法的阈值10.0
isStrokeCapRound确定条形线的起点和终点是直角头还是圆头false
belowBarData线条下面填充,参考BarAreaDataBarAreaData
aboveBarData线条上面填充,参考BarAreaData](github.com/imaNNeoFigh…)BarAreaData
dotData数据点,参考FlDotDataFlDotData()
showingIndicators根据提供的索引显示坐标[]
dashArray破折号偏移量和长度的圆形数组。例如,该数组[5, 10]将导致长5像素的短划线,然后是10像素长的空白。该阵列[5, 10, 5]将导致5像素破折号,10像素破折号,5像素破折号,5像素破折号,10像素破折号等。Null
shadow线条阴影,参见“阴影”阴影()
isStepLineChart如果设置为true,则使用绘制“折线图”样式的图表lineChartStepDatafalse
lineChartStepData保存用于表示步骤折线图的数据,并且仅在[isStepChart]为true时才有效。LineChartStepData()

三 边框配置

图表四个方向的边框,有总显示开关,决定是否显示和隐藏所有,如果开启,又想隐藏个别边框,需要设置透明色。

//? 边框信息
FlBorderData _buildBorderData() {
return FlBorderData(
show: showBorderData,
border: Border(
bottom: showBottomBorder
? BorderSide(
color: Color(0xff4e4965),
width: 4,
)
: BorderSide(
color: Colors.transparent,
),
left: showLeftBorder
? BorderSide(
color: Color(0xff4e4965),
width: 2,
)
: BorderSide(
color: Colors.transparent,

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip204888 (备注Android)
img

写在最后

本次我的分享也接近尾声了,感谢你们在百忙中花上一下午来这里聆听我的宣讲,希望在接下来的日子,我们共同成长,一起进步!!!

最后放上一个大概的Android学习方向及思路(详细的内容太多了~),提供给大家:

对于程序员来说,要学习的知识内容、技术有太多太多,这里就先放上一部分,其他的内容有机会在后面的文章向大家呈现出来,不过我自己所有的学习资料都整理成了一个文档,一直在不断学习,希望能帮助到大家,也节省大家在网上搜索资料的时间来学习,也可以分享动态给身边好友一起学习!

为什么某些人会一直比你优秀,是因为他本身就很优秀还一直在持续努力变得更优秀,而你是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!

Android架构师之路很漫长,一起共勉吧!

如果你觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

是不是还在满足于现状内心在窃喜!希望读到这的您能点个小赞和关注下我,以后还会更新技术干货,谢谢您的支持!**

Android架构师之路很漫长,一起共勉吧!

如果你觉得文章写得不错就给个赞呗?如果你觉得那里值得改进的,请给我留言,一定会认真查询,修正不足,谢谢。

[外链图片转存中…(img-oisJcHAX-1711747708650)]

本文已被CODING开源项目:《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》收录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值