Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sithira/flutterradioplayer
Flutter Radio Player, A Plugin to handle streaming audio without a hassle
https://github.com/sithira/flutterradioplayer
flutter flutter-audio flutter-audio-player flutter-background flutter-plugin
Last synced: about 8 hours ago
JSON representation
Flutter Radio Player, A Plugin to handle streaming audio without a hassle
- Host: GitHub
- URL: https://github.com/sithira/flutterradioplayer
- Owner: Sithira
- License: mit
- Created: 2020-03-26T19:08:39.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-11-08T03:33:27.000Z (3 months ago)
- Last Synced: 2025-01-17T17:13:47.482Z (7 days ago)
- Topics: flutter, flutter-audio, flutter-audio-player, flutter-background, flutter-plugin
- Language: Kotlin
- Homepage:
- Size: 12.2 MB
- Stars: 144
- Watchers: 11
- Forks: 66
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
![logo](flutter_radio_player_logo.png)
# Flutter Radio Player
![Pub Version](https://img.shields.io/pub/v/flutter_radio_player?style=plastic)
![Pub Likes](https://img.shields.io/pub/likes/flutter_radio_player)
![Pub Points](https://img.shields.io/pub/points/flutter_radio_player)
![Pub Popularity](https://img.shields.io/pub/popularity/flutter_radio_player)**Flutter Radio Player** is the go-to plugin for playing a single streaming URL effortlessly. With support for background music playback right out of the box, it offers seamless integration with platform-native media controls. Whether it's lock screen media controls or deeper integrations like watchOS, CarPlay, WearOS, or Android Auto, Flutter Radio Player handles it all with no extra configuration needed.
## Features
- **Background Playback**: Plays audio in the background without any configuration.
- **Watch Integration**: Seamlessly integrates with WatchOS and WearOS for native watch control.
- **Automotive Systems**: Supports infotainment systems like Apple CarPlay and Android Auto.
- **Reactive by Default**: Automatically reacts to stream changes.
- **ICY/Metadata Extraction**: Extracts stream metadata if available.## Getting Started
### 1. Install the Player
```bash
flutter pub add flutter_radio_player
```### 2. Import the Library
```dart
import 'package:flutter_radio_player/flutter_radio_player.dart';
```### 3. Configure the Player
```dart
final _flutterRadioPlayerPlugin = FlutterRadioPlayer(); // Create an instance of the player
_flutterRadioPlayerPlugin.initialize(
[
{"url": "https://s2-webradio.antenne.de/chillout?icy=https"},
{
"title": "SunFM - Sri Lanka",
"artwork": "images/sample-cover.jpg", // Image needs to be bundled with the app
"url": "https://radio.lotustechnologieslk.net:2020/stream/sunfmgarden?icy=https",
},
{"url": "http://stream.riverradio.com:8000/wcvofm.aac"}
],
true, // Auto play on load
);
```Once configured, your player is ready to stream music.
### Manipulating the Player
You can control the player using the following methods:
| Method | Action |
|------------------------|------------------------------------------------------------|
| `play()` | Plays the audio from the current source |
| `pause()` | Pauses the audio |
| `playOrPause()` | Toggles play/pause |
| `changeVolume()` | Adjusts the volume |
| `getVolume()` | Retrieves the current volume |
| `nextSource()` | Skips to the next source in the list (if available) |
| `previousSource()` | Goes to the previous source |
| `jumpToSourceIndex()` | Jumps to a specific index in the sources list |### Available Streams
You can also listen to various streams:
| Stream | Returns | Description |
|-----------------------------------|-------------------------------------|------------------------------------------------------|
| `getIsPlayingStream()` | `Stream` | Emits playback status |
| `getNowPlayingStream()` | `Stream` | Emits metadata such as track name |
| `getDeviceVolumeChangedStream()` | `Stream` | Emits device audio level updates |## Platform Configuration
### iOS
To enable background playback, configure background capabilities in Xcode as shown below:
![Xcode Configuration](enabling-xcode-bg-service.png)
### Android
For Android, ensure the following permissions are added to your `AndroidManifest.xml`:
```xml
```
> These permissions are already included in the library.
**Check out the [Flutter Radio Player Example](/example)** to see how to implement action methods and streams in your player.
## Support the Plugin
If you find this plugin useful, show your support by:
- Giving it a ⭐️ on [GitHub](https://github.com/Sithira/FlutterRadioPlayer)
- Leaving a like on Pub
- Showing some ♥️ and buying me a coffee via USDT-TR20 at this address: `TNuTkL1ZJGu2xntmtzHzSiH5YdVqUeAujr`**Enjoy the plugin!**
Sithira ✌️