Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tlenclos/react-native-audio-streaming
iOS & Android react native module to play an audio stream, with background support and media controls
https://github.com/tlenclos/react-native-audio-streaming
android audio ios player react-native shoutcast streaming
Last synced: 1 day ago
JSON representation
iOS & Android react native module to play an audio stream, with background support and media controls
- Host: GitHub
- URL: https://github.com/tlenclos/react-native-audio-streaming
- Owner: tlenclos
- License: mit
- Created: 2016-07-21T15:03:41.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-04-09T01:31:36.000Z (almost 3 years ago)
- Last Synced: 2025-01-04T11:39:23.552Z (8 days ago)
- Topics: android, audio, ios, player, react-native, shoutcast, streaming
- Language: Java
- Homepage:
- Size: 4.47 MB
- Stars: 784
- Watchers: 32
- Forks: 254
- Open Issues: 86
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-react-native - react-native-audio-streaming ★679 - iOS & Android module to play an audio stream, with background support and media controls :speaker: (Components / Media)
- awesome-react-native - react-native-audio-streaming ★679 - iOS & Android module to play an audio stream, with background support and media controls :speaker: (Components / Media)
- awesome-react-native - react-native-audio-streaming ★679 - iOS & Android module to play an audio stream, with background support and media controls :speaker: (Components / Media)
- awesome-react-native - react-native-audio-streaming ★679 - iOS & Android module to play an audio stream, with background support and media controls :speaker: (Components / Media)
- awesome-react-native-ui - react-native-audio-streaming ★262 - iOS & Android module to play an audio stream, with background support and media controls :speaker: (Components / Media)
README
# react-native-audio-streaming
## THIS PROJECT IS NOT MAINTAINED
react-native-audio-streaming is not maintained anymore. The main purpose was to play shoutcast streams with meta data and display a notification while playing.
Please see other projects like
- [jsierles/react-native-audio](https://github.com/jsierles/react-native-audio) to play local audio and record
- [zmxv/react-native-sound](https://github.com/zmxv/react-native-sound) to play local audio with more controls## Features
- Background audio streaming of remote stream
- Control via sticky notification on android and media center on iOS
- Shoutcast/Icy meta data support
- Simple UI player component (if needed, an api to control the sound is available)If you are only looking to play local audio file with app in foreground, please [see other audio libs](https://github.com/tlenclos/react-native-audio-streaming/blob/master/README.md#other-rn-audio-projects).
![Demo iOS](https://raw.githubusercontent.com/tlenclos/react-native-audio-streaming/master/demo_ios.gif)
![Demo android](https://raw.githubusercontent.com/tlenclos/react-native-audio-streaming/master/demo_android.gif)## First installation step (applied for both iOS & Android)
`$ npm install react-native-audio-streaming --save`
### Next installation steps for iOS (choose one of three options below)
#### 1. Cocoapods installation
1. add `pod 'RNAudioStreaming', :path => '../node_modules/react-native-audio-streaming'` to `Podfile`
2. run `pod install`#### 2. Mostly automatic installation
`$ react-native link react-native-audio-streaming`
Go to `node_modules` ➜ `react-native-audio-streaming` => `ios` => `Pods` and drag/drop `Pods.xcodeproj` to the Libraries folder in your XCode project.
In XCode, in the project navigator, select your project. Add `libReactNativeAudioStreaming.a` and `libStreamingKit.a` to your project's `Build Phases` ➜ `Link Binary With Libraries`
#### 3. Manual installation
1. In XCode, in the project navigator, right click `Libraries` ➜ `Add Files to [your project's name]`
2. Go to `node_modules` ➜ `react-native-audio-streaming` => `ios`
- run `pod install` to download StreamingKit dependency
- add `ReactNativeAudioStreaming.xcodeproj` to the Libraries folder in your XCode project
- add `Pods/Pods.xcodeproj` to the Libraries folder in your XCode project
3. In XCode, in the project navigator, select your project. Add `libReactNativeAudioStreaming.a` and `libStreamingKit.a` to your project's `Build Phases` ➜ `Link Binary With Libraries`
4. Run your project (`Cmd+R`)### Final steps for iOS (required after doing any of three options above)
1. Make sure `$(SRCROOT)/../node_modules/react-native-audio-streaming/ios` is added to your project's `Header Search Paths` within the `Build Settings` section.
2. Update Info.plist file of your Xcode project and add audio background mode
```xml
UIBackgroundModes
audio
```### Next installation steps for Android
1. Open up `android/app/src/main/java/[...]/MainApplication.java`
- Add `import com.audioStreaming.ReactNativeAudioStreamingPackage;` to the imports at the top of the file
- Add `new ReactNativeAudioStreamingPackage()` to the list returned by the `getPackages()` method
If you're using Android 23 or above
- Add `new ReactNativeAudioStreamingPackage(MainActivity.class)` to he list returned by the `getPackages()`method instead.
2. Append the following lines to `android/settings.gradle`:
```
include ':react-native-audio-streaming'
project(':react-native-audio-streaming').projectDir = new File(rootProject.projectDir, '../node_modules/react-native-audio-streaming/android')
```
3. Insert the following lines inside the dependencies block in `android/app/build.gradle`:
```
compile project(':react-native-audio-streaming')
```
4. If using Proguard then insert the following rules:
```
-keep class com.spoledge.aacdecoder.** {
*;
}
```
## Usage### Playing sound (similar code used by the player UI)
```javascript
import { ReactNativeAudioStreaming } from 'react-native-audio-streaming';const url = "http://lacavewebradio.chickenkiller.com:8000/stream.mp3";
ReactNativeAudioStreaming.pause();
ReactNativeAudioStreaming.resume();
ReactNativeAudioStreaming.play(url, {showIniOSMediaCenter: true, showInAndroidNotifications: true});
ReactNativeAudioStreaming.stop();
```For more information see the Example app.
### Player UI
```javascript
import { Player } from 'react-native-audio-streaming';class PlayerUI extends Component {
render() {
return (
);
}
}
```## TODO
- [ ] Allow to play local files
- [ ] Allow to specify custom style for the android notification (maybe a custom view ?)
- [ ] Allow to specify custom styles for the player
- [ ] Handle artwork of artist
- [ ] Add tests## Credits
- Android version based on the work of @EstebanFuentealba https://github.com/EstebanFuentealba/react-native-android-audio-streaming-aac
- iOS version based on the work of @jhabdas https://github.com/jhabdas/lumpen-radioSee also the list of [contributors](https://github.com/tlenclos/react-native-audio-streaming/graphs/contributors) who participated in this project.
## Contribute
Since symlink support is [still lacking](https://github.com/facebook/react-native/issues/637) on React Native, I use the [wml](https://github.com/wix/wml) cli tool created by the nice folks at wix.
`wml add ~/react-native-audio-streaming ~/react-native-audio-streaming/Example/node_modules/react-native-audio-streaming`
## [Changelog](https://github.com/tlenclos/react-native-audio-streaming/blob/master/CHANGELOG.md)
## License
This project is licensed under the MIT License - see the LICENSE file for details