Flutter图表库fl_chart的使用解析(二)-折线图

)

看下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,
),
right: BorderSide(
color: Colors.transparent,
),
top: BorderSide(
color: Colors.transparent,
),
));
}

FlBorderData对应边框信息,有两个参数,show就是显示与隐藏的边框,border是边框数据。

四 坐标轴配置

FlTitlesData可以配置4条坐标轴,也有一个总开关,如果要显示坐标轴,就设为true,然后配置对应位置的数据:

//? 坐标配置
FlTitlesData _buildTitles() {
return FlTitlesData(
//? 下边标题
bottomTitles: _buildBottomTitle(),
//? 左侧标题
leftTitles: _buildLeftTitle(),
);
}

每个位置对应的是SideTitles,设置如下:

SideTitles _buildLeftTitle() {
return SideTitles(
showTitles: showlLeftTitles,
getTextStyles: (value) => const TextStyle(
color: Color(0xff75729e),
fontWeight: FontWeight.bold,
fontSize: 14,
),
getTitles: (value) {
switch (value.toInt()) {
case 1:
return ‘1m’;
case 2:
return ‘2m’;
case 3:
return ‘3m’;
case 4:
return ‘5m’;
case 5:
return ‘6m’;
}
return ‘’;
},
margin: 8,
reservedSize: 30,
);
}

属性名称描述默认值
showTitles确定是显示还是隐藏标题false
getTitles该函数可检索相关轴上具有给定值的标题,如果要通过显示大数字的指示符来设置数字格式器,请不要触摸它。defaultGetTitle
reservedSize保留的标题空间,如果设置axisTitleData,这里要留出空间,不然会重叠22
textStyle文字属性TextStyle the style to use for title textTextStyle(color: Colors.black, fontSize: 11)
margin文字和边框的间距6
interval间隔几个坐标显示null
rotateAngle旋转标题的顺时针角度0.0
checkToShowTitle确定以提供的值显示或不显示标题show all

五 标题配置

标题是显示在坐标轴后面的文字标题,每个轴对应一个。

//? 标题配置
FlAxisTitleData _buildFlAxisTitleData() {
return FlAxisTitleData(
leftTitle: AxisTitle(titleText: “侧轴标题”, showTitle: showAxisLeftTitle),
bottomTitle: AxisTitle(titleText: “底部标题”, showTitle: showAxisBottomTitle),
);
}
六 配置触摸

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

深知大多数初中级安卓工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

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

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Android)
img

题外话

我在一线互联网企业工作十余年里,指导过不少同行后辈。帮助很多人得到了学习和成长。

我意识到有很多经验和知识值得分享给大家,也可以通过我们的能力和经验解答大家在IT学习中的很多困惑,所以在工作繁忙的情况下还是坚持各种整理和分享。但苦于知识传播途径有限,很多程序员朋友无法获得正确的资料得到学习提升,故此将并将重要的Android进阶资料包括自定义view、性能优化、MVC与MVP与MVVM三大框架的区别、NDK技术、阿里面试题精编汇总、常见源码分析等学习资料免费分享出来。
Android学习PDF+学习视频+面试文档+知识点笔记

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

需要的朋友,可以点赞关注+转发”前往免费领取!

et/topics/618156601)】

【Android思维脑图(技能树)】

知识不体系?这里还有整理出来的Android进阶学习的思维脑图,给大家参考一个方向。

[外链图片转存中…(img-Vh4CCHSg-1710659747495)]

需要的朋友,可以点赞关注+转发”前往免费领取!

希望我能够用我的力量帮助更多迷茫、困惑的朋友们,帮助大家在IT道路上学习和发展~

  • 19
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用fl_chart创建饼图的简单示例: ```dart import 'package:flutter/material.dart'; import 'package:fl_chart/fl_chart.dart'; class PieChartSample extends StatefulWidget { @override _PieChartSampleState createState() => _PieChartSampleState(); } class _PieChartSampleState extends State<PieChartSample> { int touchedIndex; @override Widget build(BuildContext context) { return AspectRatio( aspectRatio: 1, child: PieChart( PieChartData( pieTouchData: PieTouchData(touchCallback: (pieTouchResponse) { setState(() { if (pieTouchResponse.touchInput is FlLongPressEnd || pieTouchResponse.touchInput is FlPanEnd) { touchedIndex = -1; } else { touchedIndex = pieTouchResponse.touchedSectionIndex; } }); }), borderData: FlBorderData(show: false), sectionsSpace: 0, centerSpaceRadius: 40, sections: getSections(), ), ), ); } List<PieChartSectionData> getSections() { return List.generate(4, (i) { final isTouched = i == touchedIndex; final double fontSize = isTouched ? 25 : 16; final double radius = isTouched ? 60 : 50; switch (i) { case 0: return PieChartSectionData( color: Colors.red, value: 40, title: '40%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); case 1: return PieChartSectionData( color: Colors.green, value: 30, title: '30%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); case 2: return PieChartSectionData( color: Colors.blue, value: 15, title: '15%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); case 3: return PieChartSectionData( color: Colors.yellow, value: 15, title: '15%', radius: radius, titleStyle: TextStyle( fontSize: fontSize, fontWeight: FontWeight.bold, color: const Color(0xffffffff), ), ); default: return null; } }); } } ``` 在这个例子中,我们创建了一个PieChartSample类,它继承自StatefulWidget。在build()方法中,我们创建了一个AspectRatio小部件,它将PieChart小部件的宽高比设置为1:1。然后,我们创建了一个PieChart小部件,它接收一个PieChartData对象作为参数。PieChartData对象包含所有的饼图数据,包括饼图的颜色、半径、标题、值等。 在PieChartData对象中,我们使用了PieTouchData对象来处理用户的触摸事件。我们还使用FlBorderData对象来隐藏边框,使用sectionsSpace属性来设置饼图部分之间的间距,使用centerSpaceRadius属性来设置中心空间的半径。 在getSections()函数中,我们生成了饼图的各个部分。每个部分都由一个PieChartSectionData对象表示,它包括颜色、半径、值、标题和标题样式等属性。我们返回一个包含所有部分的列表,然后将它们传递给PieChartData对象。 最后,我们在PieTouchData对象的touchCallback属性中处理触摸事件。如果用户停止触摸饼图,我们将touchedIndex设置为-1,否则,我们将touchedIndex设置为当前触摸部分的索引。根据touchedIndex的值,我们可以设置饼图部分的半径和标题样式,以突出显示当前触摸的部分。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值