0.0.4 • Published 6 years ago

rn-live v0.0.4

Weekly downloads
23
License
MIT
Repository
github
Last release
6 years ago

rn-live

Info

This library based rtmp-rtsp-stream-client-java and LFLiveKit

Support iOS and Android

Add it to your project

Run npm install --save rn-live

Android

  1. Add the following lines to android/settings.gradle:

    include ':rn-live'
    project(':rn-live').projectDir = new File(rootProject.projectDir, '../node_modules/rn-live/android')
  2. Add the compile line to the dependencies in android/app/build.gradle:

    dependencies {
        compile project(':rn-live')
    }
  3. Add the required permissions in AndroidManifest.xml:

        <uses-permission android:name="android.permission.INTERNET" />
        <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>
        <uses-permission android:name="android.permission.RECORD_AUDIO" />
        <uses-permission android:name="android.permission.CAMERA" />
        <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
        <uses-feature android:name="android.hardware.camera" />
        <uses-feature android:name="android.hardware.camera2.full" />
        <uses-feature android:name="android.hardware.camera2.autofocus" />
  4. Add the import and link the package in MainApplication.java:

    import com.rnlive.RTMPPackage; // <-- add this import
    
    public class MainApplication extends Application implements ReactApplication {
        @Override
        protected List<ReactPackage> getPackages() {
            return Arrays.<ReactPackage>asList(
                new MainReactPackage(),
                new RTMPPackage() // <-- add this line
            );
        }
    }

iOS

  1. In the XCode's "Project navigator", right click on your project's Libraries folder ➜ Add Files to <...>
  2. Go to node_modulesrn-liveios ➜ select RCTLFLiveKit.xcodeproj
  3. Add libRCTLFLiveKit.a to Build Phases -> Link Binary With Libraries
  4. Go to General -> Embedded Binaries and add LFLiveKit.framework
  5. Linked Frameworks and Libraries add LFLiveKit.framework
  6. Compile and have fun

Usage

    <RNLive
        started={false} // start your stream
        cameraFronted={true} // camera front or back
        url="rtmp://xxx" // your rtmp publish url
        landscape={false} // landscape mode
        onReady={() => {}} // streaming ready
        onPending={() => {}} // streaming ready to start
        onStart={() => {}} // streaming start
        onError={() => {}} // straming error
        onStop={() => {}} // streaming stop
        />

Options

optioniOSAndroid
cameraFrontedOKOK
startedOKOK
urlOKOK
landscapeOK-
onReadyOK-
onPendingOK-
onStartOK-
onStopOK-
onErrorOK-
videoEnabled-OK
audioEnabled-OK

License

MIT https://www.npmjs.com/package/rn-live