This Flutter plugin is a wapper for Agora Video SDK.
Agora.io provides building blocks for you to add real-time voice and video communications through a simple and powerful SDK. You can integrate the Agora SDK to enable real-time communications in your own application quickly.
Note: This plugin is still under development, and some APIs might not be available yet.
To use this plugin, add agora_rtc_engine
as a dependency in your pubspec.yaml file.
- See the example directory for a sample app using AgoraRtcEngine.
- Or checkout this tutorial for a simple video call app using Agora Flutter SDK.
Agora Video SDK requires camera and microphone permission to start video call.
Open the AndroidManifest.xml file and add the required device permissions to the file.
..
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.MODIFY_AUDIO_SETTINGS" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<!-- The Agora SDK requires Bluetooth permissions in case users are using Bluetooth devices.-->
<uses-permission android:name="android.permission.BLUETOOTH" />
..
Open the info.plist and add:
- Privacy - Microphone Usage Description, and add a note in the Value column.
- Privacy - Camera Usage Description, and add a note in the Value column.
Your application can still run the voice call when it is switched to the background if the background mode is enabled. Select the app target in Xcode, click the Capabilities tab, enable Background Modes, and check Audio, AirPlay, and Picture in Picture.
if your flutter channel is stable, PlatformView
will cause memory leak, you can run flutter channel beta
you can refer to this pull request
Tips: please make sure your all configurations are correct, but still black screen
if your MainActivity extends io.flutter.embedding.android.FlutterActivity
and override the configureFlutterEngine
function
please don't forget add super.configureFlutterEngine(flutterEngine)
please don't add GeneratedPluginRegistrant.registerWith(flutterEngine)
, plugins will be registered auto now
you can refer to the official documents
it causes by code obfuscation because of flutter set android.enableR8=true
by the default
Add the following line in the app/proguard-rules.pro file to prevent code obfuscation:
-keep class io.agora.**{*;}
To help work on this sdk, see our contributor guide.