mirror of
https://github.com/flutter/samples.git
synced 2025-11-08 22:09:06 +00:00
Bumps [fl_chart](https://github.com/imaNNeo/fl_chart) from 0.62.0 to 0.63.0. <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/imaNNeo/fl_chart/releases">fl_chart's releases</a>.</em></p> <blockquote> <h2>0.63.0</h2> <ul> <li><strong>BUGFIX</strong> (by <a href="https://github.com/imaNNeo"><code>@imaNNeo</code></a>) Fix PieChart crash on web-renderer html by ignoring <code>sectionsSpace</code> when <code>Path.combine()</code> does not work (it's flutter engine <a href="https://redirect.github.com/flutter/flutter/issues/44572">issue</a>), <a href="https://redirect.github.com/imaNNeo/fl_chart/issues/955">#955</a></li> <li><strong>BUGFIX</strong> (by <a href="https://github.com/imaNNeo"><code>@imaNNeo</code></a>) Fix ScatterChart long-press interaction bug (disappears when long-pressing on the chart), <a href="https://redirect.github.com/imaNNeo/fl_chart/issues/1318">#1318</a></li> <li><strong>FEATURE</strong> (by <a href="https://github.com/imaNNeo"><code>@imaNNeo</code></a>) Upgrade dart version to <a href="https://dart.dev/resources/dart-3-migration">3.0</a></li> </ul> </blockquote> </details> <details> <summary>Changelog</summary> <p><em>Sourced from <a href="https://github.com/imaNNeo/fl_chart/blob/master/CHANGELOG.md">fl_chart's changelog</a>.</em></p> <blockquote> <h2>0.63.0</h2> <ul> <li><strong>BUGFIX</strong> (by <a href="https://github.com/imaNNeo"><code>@imaNNeo</code></a>) Fix PieChart crash on web-renderer html by ignoring <code>sectionsSpace</code> when <code>Path.combine()</code> does not work (it's flutter engine <a href="https://redirect.github.com/flutter/flutter/issues/44572">issue</a>), <a href="https://redirect.github.com/imaNNeo/fl_chart/issues/955">#955</a></li> <li><strong>BUGFIX</strong> (by <a href="https://github.com/imaNNeo"><code>@imaNNeo</code></a>) Fix ScatterChart long-press interaction bug (disappears when long-pressing on the chart), <a href="https://redirect.github.com/imaNNeo/fl_chart/issues/1318">#1318</a></li> <li><strong>FEATURE</strong> (by <a href="https://github.com/imaNNeo"><code>@imaNNeo</code></a>) Upgrade dart version to <a href="https://dart.dev/resources/dart-3-migration">3.0</a></li> </ul> </blockquote> </details> <details> <summary>Commits</summary> <ul> <li><a href="6c0e43f7e7"><code>6c0e43f</code></a> Bump version to 0.63.0</li> <li><a href="81a2618d1b"><code>81a2618</code></a> Update github publish action</li> <li><a href="3b2188d3f2"><code>3b2188d</code></a> Update line_chart.md</li> <li><a href="872878b0ce"><code>872878b</code></a> Fix analyze issues with Dart 3.0</li> <li><a href="2984262886"><code>2984262</code></a> chore: bump very_good_analysis from 4.0.0+1 to 5.0.0</li> <li><a href="ba1fa734b7"><code>ba1fa73</code></a> docs wrong link fix</li> <li><a href="f91d4bf322"><code>f91d4bf</code></a> Update CHANGELOG.md</li> <li><a href="5db8f6db61"><code>5db8f6d</code></a> Update tests to fix the CI issue</li> <li><a href="6db877acec"><code>6db877a</code></a> Fix analyze issues</li> <li><a href="46ef2c0dc5"><code>46ef2c0</code></a> Upgrade dependencies</li> <li>Additional commits viewable in <a href="https://github.com/imaNNeo/fl_chart/compare/0.62.0...0.63.0">compare view</a></li> </ul> </details> <br /> [](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) </details> --------- Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com> Co-authored-by: Hossein Yousefi <yousefi@google.com>
218 lines
5.7 KiB
Dart
218 lines
5.7 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:intl/intl.dart';
|
|
import 'package:fl_chart/fl_chart.dart';
|
|
|
|
import 'steps_repo.dart';
|
|
|
|
void main() {
|
|
runApp(const MyApp());
|
|
}
|
|
|
|
class MyApp extends StatelessWidget {
|
|
const MyApp({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return MaterialApp(
|
|
title: 'Flutter Demo',
|
|
theme: ThemeData(
|
|
primarySwatch: Colors.blue,
|
|
),
|
|
home: const Home(),
|
|
);
|
|
}
|
|
}
|
|
|
|
class RoundClipper extends CustomClipper<Path> {
|
|
@override
|
|
Path getClip(Size size) {
|
|
final diameter = size.shortestSide * 1.5;
|
|
final x = -(diameter - size.width) / 2;
|
|
final y = size.height - diameter;
|
|
final rect = Offset(x, y) & Size(diameter, diameter);
|
|
return Path()..addOval(rect);
|
|
}
|
|
|
|
@override
|
|
bool shouldReclip(CustomClipper<Path> oldClipper) {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
class Home extends StatefulWidget {
|
|
const Home({
|
|
Key? key,
|
|
}) : super(key: key);
|
|
|
|
@override
|
|
State<Home> createState() => _HomeState();
|
|
}
|
|
|
|
class _HomeState extends State<Home> {
|
|
var hourlySteps = <Steps>[];
|
|
DateTime? lastUpdated;
|
|
|
|
@override
|
|
void initState() {
|
|
runPedometer();
|
|
super.initState();
|
|
}
|
|
|
|
void runPedometer() async {
|
|
final now = DateTime.now();
|
|
hourlySteps = await StepsRepo.instance.getSteps();
|
|
lastUpdated = now;
|
|
setState(() {});
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final textTheme = Theme.of(context).textTheme;
|
|
|
|
final barGroups = hourlySteps
|
|
.map(
|
|
(e) => BarChartGroupData(
|
|
x: int.parse(e.startHour),
|
|
barRods: [
|
|
BarChartRodData(
|
|
color: Colors.blue[900],
|
|
toY: e.steps.toDouble() / 100,
|
|
)
|
|
],
|
|
),
|
|
)
|
|
.toList();
|
|
|
|
return Scaffold(
|
|
body: Stack(
|
|
children: [
|
|
ClipPath(
|
|
clipper: RoundClipper(),
|
|
child: FractionallySizedBox(
|
|
heightFactor: 0.55,
|
|
widthFactor: 1,
|
|
child: Container(color: Colors.blue[300]),
|
|
),
|
|
),
|
|
Align(
|
|
alignment: Alignment.topCenter,
|
|
child: Padding(
|
|
padding: const EdgeInsets.all(80.0),
|
|
child: Column(
|
|
children: [
|
|
lastUpdated != null
|
|
? Padding(
|
|
padding: const EdgeInsets.symmetric(vertical: 50.0),
|
|
child: Text(
|
|
DateFormat.yMMMMd('en_US').format(lastUpdated!),
|
|
style: textTheme.titleLarge!
|
|
.copyWith(color: Colors.blue[900]),
|
|
),
|
|
)
|
|
: const SizedBox(height: 0),
|
|
Text(
|
|
hourlySteps.fold(0, (t, e) => t + e.steps).toString(),
|
|
style: textTheme.displayMedium!.copyWith(color: Colors.white),
|
|
),
|
|
Text(
|
|
'steps',
|
|
style: textTheme.titleLarge!.copyWith(color: Colors.white),
|
|
)
|
|
],
|
|
),
|
|
),
|
|
),
|
|
Align(
|
|
alignment: Alignment.centerRight,
|
|
child: GestureDetector(
|
|
onTap: runPedometer,
|
|
child: Padding(
|
|
padding: const EdgeInsets.all(20.0),
|
|
child: Container(
|
|
decoration: BoxDecoration(
|
|
color: Colors.blue[900],
|
|
shape: BoxShape.circle,
|
|
),
|
|
child: const Padding(
|
|
padding: EdgeInsets.all(8.0),
|
|
child: Icon(
|
|
Icons.refresh,
|
|
color: Colors.white,
|
|
size: 50,
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
Align(
|
|
alignment: Alignment.bottomCenter,
|
|
child: Padding(
|
|
padding:
|
|
const EdgeInsets.symmetric(horizontal: 30.0, vertical: 50.0),
|
|
child: AspectRatio(
|
|
aspectRatio: 1.2,
|
|
child: BarChart(
|
|
BarChartData(
|
|
titlesData: const FlTitlesData(
|
|
show: true,
|
|
// Top titles are null
|
|
topTitles:
|
|
AxisTitles(sideTitles: SideTitles(showTitles: false)),
|
|
rightTitles:
|
|
AxisTitles(sideTitles: SideTitles(showTitles: false)),
|
|
leftTitles: AxisTitles(
|
|
sideTitles: SideTitles(
|
|
showTitles: false,
|
|
),
|
|
),
|
|
bottomTitles: AxisTitles(
|
|
sideTitles: SideTitles(
|
|
showTitles: true,
|
|
reservedSize: 30,
|
|
getTitlesWidget: getBottomTitles,
|
|
),
|
|
),
|
|
),
|
|
borderData: FlBorderData(
|
|
show: false,
|
|
),
|
|
barGroups: barGroups,
|
|
gridData: const FlGridData(show: false),
|
|
alignment: BarChartAlignment.spaceAround,
|
|
),
|
|
),
|
|
),
|
|
),
|
|
),
|
|
],
|
|
));
|
|
}
|
|
}
|
|
|
|
// Axis labels for bottom of chart
|
|
Widget getBottomTitles(double value, TitleMeta meta) {
|
|
String text;
|
|
switch (value.toInt()) {
|
|
case 0:
|
|
text = '12AM';
|
|
break;
|
|
case 6:
|
|
text = '6AM';
|
|
break;
|
|
case 12:
|
|
text = '12PM';
|
|
break;
|
|
case 18:
|
|
text = '6PM';
|
|
break;
|
|
default:
|
|
text = '';
|
|
}
|
|
return SideTitleWidget(
|
|
axisSide: meta.axisSide,
|
|
space: 4,
|
|
child: Text(text, style: TextStyle(fontSize: 14, color: Colors.blue[900])),
|
|
);
|
|
}
|