mirror of
				https://github.com/johrpan/musicus_mobile.git
				synced 2025-10-26 10:47:25 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			59 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
	
		
			1.3 KiB
		
	
	
	
		
			Dart
		
	
	
	
	
	
| import 'dart:async';
 | |
| 
 | |
| import 'package:flutter/material.dart';
 | |
| 
 | |
| import '../backend.dart';
 | |
| 
 | |
| class PlayPauseButton extends StatefulWidget {
 | |
|   @override
 | |
|   _PlayPauseButtonState createState() => _PlayPauseButtonState();
 | |
| }
 | |
| 
 | |
| class _PlayPauseButtonState extends State<PlayPauseButton>
 | |
|     with SingleTickerProviderStateMixin {
 | |
|   AnimationController playPauseAnimation;
 | |
|   BackendState backend;
 | |
|   StreamSubscription<bool> playingSubscription;
 | |
| 
 | |
|   @override
 | |
|   void initState() {
 | |
|     super.initState();
 | |
| 
 | |
|     playPauseAnimation = AnimationController(
 | |
|       vsync: this,
 | |
|       duration: Duration(milliseconds: 300),
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void didChangeDependencies() {
 | |
|     super.didChangeDependencies();
 | |
| 
 | |
|     backend = Backend.of(context);
 | |
|     playPauseAnimation.value = backend.player.playing.value ? 1.0 : 0.0;
 | |
| 
 | |
|     if (playingSubscription != null) {
 | |
|       playingSubscription.cancel();
 | |
|     }
 | |
| 
 | |
|     playingSubscription = backend.player.playing.listen((playing) =>
 | |
|         playing ? playPauseAnimation.forward() : playPauseAnimation.reverse());
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   Widget build(BuildContext context) {
 | |
|     return IconButton(
 | |
|       icon: AnimatedIcon(
 | |
|         icon: AnimatedIcons.play_pause,
 | |
|         progress: playPauseAnimation,
 | |
|       ),
 | |
|       onPressed: backend.player.playPause,
 | |
|     );
 | |
|   }
 | |
| 
 | |
|   @override
 | |
|   void dispose() {
 | |
|     super.dispose();
 | |
|     playingSubscription.cancel();
 | |
|   }
 | |
| }
 | 
