From db56afeae5bd2cf09c825e7bbd72a67ac8c67e11 Mon Sep 17 00:00:00 2001 From: Liplum Date: Tue, 24 Sep 2024 03:38:04 +0800 Subject: [PATCH] [timetable] fade in wallpaper when the app was resumed after long time on the background --- lib/app.dart | 6 ++++ .../widget/timetable/background.dart | 36 ++++++++++++++++--- 2 files changed, 37 insertions(+), 5 deletions(-) diff --git a/lib/app.dart b/lib/app.dart index 59583a554..f85f4d19f 100644 --- a/lib/app.dart +++ b/lib/app.dart @@ -242,6 +242,12 @@ class _PostServiceRunnerState extends ConsumerState<_PostServiceRunner> { super.dispose(); } + @override + void didChangeDependencies() { + precacheTimetableBackground(); + super.didChangeDependencies(); + } + Future onResume() async { await precacheTimetableBackground(); } diff --git a/lib/timetable/widget/timetable/background.dart b/lib/timetable/widget/timetable/background.dart index 6e44c0ae5..2a833f3b5 100644 --- a/lib/timetable/widget/timetable/background.dart +++ b/lib/timetable/widget/timetable/background.dart @@ -50,23 +50,49 @@ class _TimetableBackgroundImpl extends StatefulWidget { class _TimetableBackgroundImplState extends State<_TimetableBackgroundImpl> with SingleTickerProviderStateMixin { late final AnimationController $opacity; + late final AppLifecycleListener _listener; + + DateTime? lastHiddenTime; @override void initState() { super.initState(); $opacity = AnimationController(vsync: this, value: widget.fade ? 0.0 : widget.background.opacity); + _listener = AppLifecycleListener( + onHide: () { + lastHiddenTime = DateTime.now(); + }, + onShow: () { + final now = DateTime.now(); + if (now.difference(lastHiddenTime ?? now).inSeconds > 15) { + if (widget.fade) { + $opacity.value = 0; + } + } + }, + onResume: () { + if (widget.fade) { + animateOpacity(); + } + }, + ); if (widget.fade) { - $opacity.animateTo( - widget.background.opacity, - duration: widget.fadeDuration, - curve: Curves.easeInOut, - ); + animateOpacity(); } } + void animateOpacity() { + $opacity.animateTo( + widget.background.opacity, + duration: widget.fadeDuration, + curve: Curves.easeInOut, + ); + } + @override void dispose() { $opacity.dispose(); + _listener.dispose(); super.dispose(); }