| 
									
										
										
										
											2020-04-19 19:08:50 +02:00
										 |  |  | import 'package:flutter/services.dart'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  | /// A simple music player.
 | 
					
						
							| 
									
										
										
										
											2020-04-21 18:01:09 +02:00
										 |  |  | ///
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  | /// Give it an URI using [setUri] and it will start playing.
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:08:50 +02:00
										 |  |  | class MusicusPlayer { | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  |   /// Called, when the player reaches the end of the audio file.
 | 
					
						
							|  |  |  |   final void Function() onComplete; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:08:50 +02:00
										 |  |  |   final _channel = MethodChannel('de.johrpan.musicus_player/platform'); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  |   /// Create a new player.
 | 
					
						
							| 
									
										
										
										
											2020-04-21 18:01:09 +02:00
										 |  |  |   ///
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  |   /// This will do nothing, until [setUri] was called. If the player reaches
 | 
					
						
							|  |  |  |   /// the end of the current audio file, [onComplete] will be called.
 | 
					
						
							| 
									
										
										
										
											2020-04-21 18:01:09 +02:00
										 |  |  |   MusicusPlayer({ | 
					
						
							|  |  |  |     this.onComplete, | 
					
						
							|  |  |  |   }) { | 
					
						
							| 
									
										
										
										
											2020-04-19 19:08:50 +02:00
										 |  |  |     _channel.setMethodCallHandler(_handleMethodCall); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  |   Future<void> _handleMethodCall(MethodCall call) async { | 
					
						
							|  |  |  |     if (call.method == 'onComplete' && onComplete != null) { | 
					
						
							|  |  |  |       onComplete(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /// Set URI of the audio file to play.
 | 
					
						
							| 
									
										
										
										
											2020-04-21 18:01:09 +02:00
										 |  |  |   ///
 | 
					
						
							|  |  |  |   /// The player will always stop doing, what it did before, and start
 | 
					
						
							|  |  |  |   /// playing from the provided URI if possible. The return value is the
 | 
					
						
							|  |  |  |   /// duration of the new track in milliseconds.
 | 
					
						
							|  |  |  |   Future<int> setUri(String uri) async { | 
					
						
							|  |  |  |     return await _channel.invokeMethod('setUri', {'uri': uri}); | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /// Play from the current URI and resume playback if previously paused.
 | 
					
						
							|  |  |  |   Future<void> play() async { | 
					
						
							|  |  |  |     await _channel.invokeMethod('play'); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-21 18:01:09 +02:00
										 |  |  |   /// Get the current playback position in milliseconds.
 | 
					
						
							|  |  |  |   Future<int> getPosition() async { | 
					
						
							|  |  |  |     return await _channel.invokeMethod('getPosition'); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-21 19:47:11 +02:00
										 |  |  |   /// Seek to a new position, which should be provided in milliseconds.
 | 
					
						
							|  |  |  |   Future<void> seekTo(int positionMs) async { | 
					
						
							|  |  |  |     await _channel.invokeMethod('seekTo', {'positionMs': positionMs}); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-19 19:33:23 +02:00
										 |  |  |   /// Pause playback.
 | 
					
						
							|  |  |  |   Future<void> pause() async { | 
					
						
							|  |  |  |     await _channel.invokeMethod('pause'); | 
					
						
							| 
									
										
										
										
											2020-04-19 19:08:50 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-04-21 17:33:16 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   /// Stop the player.
 | 
					
						
							|  |  |  |   Future<void> stop() async { | 
					
						
							|  |  |  |     await _channel.invokeMethod('stop'); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-04-19 19:08:50 +02:00
										 |  |  | } |