名称 最后更新
.github/workflows 正在载入提交数据...
.idea 正在载入提交数据...
gradle 正在载入提交数据...
livekit-android-sdk 正在载入提交数据...
sample-app-common 正在载入提交数据...
sample-app-compose 正在载入提交数据...
sample-app 正在载入提交数据...
.gitignore 正在载入提交数据...
.gitmodules 正在载入提交数据...
LICENSE 正在载入提交数据...
NOTICE 正在载入提交数据...
README.md 正在载入提交数据...
build.gradle 正在载入提交数据...
gradle.properties 正在载入提交数据...
gradlew 正在载入提交数据...
gradlew.bat 正在载入提交数据...
release-instructions.md 正在载入提交数据...
settings.gradle 正在载入提交数据...
protocol @ 1e9063c4

Android Kotlin SDK for LiveKit

Official Android Client SDK for LiveKit. Easily add video & audio capabilities to your Android apps.

Docs

Docs and guides at https://docs.livekit.io

Installation

LiveKit for Android is available as a Maven package.

```groovy title="build.gradle" ... dependencies { implementation "io.livekit:livekit-android:" }


## Usage

LiveKit uses WebRTC-provided `org.webrtc.SurfaceViewRenderer` to render video tracks. Subscribed audio tracks are automatically played.

```kt
class MainActivity : AppCompatActivity(), RoomListener {
    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        ...
        val url = "wss://your_host";
        val token = "your_token"

        launch {
            val room = LiveKit.connect(
                applicationContext,
                url,
                token,
                ConnectOptions(),
                this
            )
            val localParticipant = room.localParticipant
            localParticipant.setMicrophoneEnabled(true)
            localParticipant.setCameraEnabled(true)

            attachVideo(videoTrack)
        }
    }

    override fun onTrackSubscribed(
        track: Track,
        publication: RemoteTrackPublication,
        participant: RemoteParticipant,
        room: Room
    ) {
        if (track is VideoTrack) {
            attachVideo(track)
        }
    }

    private fun attachVideo(videoTrack: VideoTrack) {
        // viewBinding.renderer is a `org.webrtc.SurfaceViewRenderer` in your
        // layout
        videoTrack.addRenderer(viewBinding.renderer)
    }
}

Permissions

LiveKit relies on the RECORD_AUDIO and CAMERA permissions to use the microphone and camera. These permission must be requested at runtime. Reference the sample app for an example.

Dev Environment

To develop the Android SDK itself, you'll need:

Optional (Dev convenience)

  1. Download webrtc sources from https://webrtc.googlesource.com/src
  2. Add sources to Android Studio by pointing at the webrtc/sdk/android folder.