/RtmpPublisher

Rtmp client on Android. Live Video Streaming.

Primary LanguageJavaApache License 2.0Apache-2.0

RtmpPublisher

alt text

Platform Download License API

Gradle

dependencies {
    compile 'com.github.takusemba:rtmppublisher:x.x.x'
}

Usage

usage is simple. RtmpPublisher does everything.

create a Publisher

val publisher: Publisher = Publisher.Builder(this)
  .setGlView(glView)
  .setUrl(rtmpUrl)
  .setSize(Publisher.Builder.DEFAULT_WIDTH, Publisher.Builder.DEFAULT_HEIGHT)
  .setAudioBitrate(Publisher.Builder.DEFAULT_AUDIO_BITRATE)
  .setVideoBitrate(Publisher.Builder.DEFAULT_VIDEO_BITRATE)
  .setCameraMode(Publisher.Builder.DEFAULT_MODE)
  .setListener(this)
  .build()

start RTMP Streaming

// start publishing!
publisher.startPublishing()

// switch camera between front and back
publisher.switchCamera()

// stop publishing!
publisher.stopPublishing()


publisher.setOnPublisherListener(object: PublisherListener {
  override fun onStarted() {
    // do something
  }
    override fun onStopped() {
    // do something
  }
    override fun onFailedToConnect() {
    // do something
  }
    override fun onDisconnected() {
    // do something
  }
})

Quick Start

alt text

Try this sample here, but this is just a RTMP android clinet. You also need RTMP server and player to do publish and play them.

You can either make the server and player yourself or use the ones below that i prepared.

Server

https://github.com/TakuSemba/docker-nginx-rtmp

RTMP Player

https://github.com/TakuSemba/RtmpPlayer

HLS Player

https://github.com/TakuSemba/HlsPlayer

Change Log

Version: 1.0.3

  • camera switcher added

Version: 1.0.0

  • first release

Author

Licence

Copyright 2017 Taku Semba.

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.