Back to Blog

Creating a Flutter Video Streaming App with Three Lines of Code

Using your favorite video streaming API just got easier with the introduction of the Agora Low Code Initiative, which enables users to build their video streaming application with just a few lines of code.

When you’re setting up your own streaming application with Agora, a few technical steps might slow you down. Now with Agora UIKit for Flutter, you can create a video streaming application with just a few lines of code.

In this tutorial, we will be going over how to use the Agora UIKit for Flutter to build your video streaming application and add some customizations.

Default Functionality

By default, the Agora Flutter UIKit library includes the following functionality before any customization:

  • Automatically laying out all video streams
  • Displaying the active speaker in the larger display in the floating layout
  • Allowing you to swap any stream to the larger display in the floating layout
  • Buttons for disabling the camera or the microphone, switching cameras for the local user, and disconnecting the call
  • Lots of visual customization
  • Live streaming mode with user role as a broadcaster or as an audience member
  • Two default layouts: floating and grid

Prerequisites

  • An Agora developer account (see How to Get Started with Agora)
  • Flutter SDK
  • VS Code or Android Studio
  • An iOS or Android device for testing the application
  • A basic understanding of Flutter development

Setup

Create a Flutter project and add agora_uikit as a dependency in your pubspec.yaml file:

dependencies:
 flutter:
  sdk: flutter
 agora_uikit:

Open your Android-level build.gradle and add jitpack to the end of the repositories:

allprojects {         
  repositories { 
     ...
     maven { url 'https://www.jitpack.io' }
  }     
}

Adding Video Streaming to Your App

In this module, the main class type is AgoraClient. This class has two required parameters, agoraConnectionData and enabledPermission, which help in creating an instance of the RtcEngine and requesting the list of user permissions, respectively:

final AgoraClient client = AgoraClient(
agoraConnectionData: AgoraConnectionData(appId: "<--App Id-->", channelName: "test"),
enabledPermission: [Permission.camera, Permission.microphone],
);

Initializing the Agora Flutter UIKit

Once you have initialized the UIKit, place the AgoraVideoViewer inside the MaterialApp. The AgoraVideoViewer class is used to display the user video layout. This class requires an object of AgoraClient as an argument:

Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: AgoraVideoViewer(client: client),
),
);
}

Build Method

With this, you have integrated Agora video calling into your application in no time.

In addition, you can add the AgoraVideoButtons class in your build method to add, remove, or customize buttons:

Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: SafeArea(
child: Stack(
children: [
AgoraVideoViewer(client: client),
AgoraVideoButtons(client: client),
]
),
),
),
);
}

Add Video and Buttons Layout

Putting it all together:

final AgoraClient client = AgoraClient(
agoraConnectionData: AgoraConnectionData(appId: "<--App Id-->", channelName: "test"),
enabledPermission: [Permission.camera, Permission.microphone],
);
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
body: SafeArea(
child: Stack(
children: [
AgoraVideoViewer(client: client),
AgoraVideoButtons(client: client)
],
),
),
),
);
}

AgoraClient Class

AgoraClient is the main class that is used to initialize the Agora RtcEngine. As of the date of writing, agora_uikit is built using v4.0.1 of the Agora Flutter SDK.

Agora UIKit for Flutter takes two required parameters: agoraConnectionData and enabledPermissions. You can also provide the agoraChannelData and agoraEventHandler parameters:

  • agoraConnectionData is used to initialize the Agora RtcEngine that takes an argument of type AgoraConnectionData(), through which you can pass your App Id, channel name, UID, temporary token, and/or token URL and thus set up your video call.
  • enabledPermissions takes a list of permissions that needs to be triggered before building any application. This list can contain permissions for camera, microphone, storage, location, etc.
  • agoraChannelData is used to define the properties of your channel and the user behavior in that particular channel. It takes arguments such as channel profile, client role, remote mic state, remote video state, dual-stream mode, stream fallback options, and much more.
  • agoraEventHandler extends the RtcEngineEventHandler class through which we can add functions that are executed from the given list of event handlers.

All this can be summarized by:

final AgoraClient client = AgoraClient(
agoraConnectionData: AgoraConnectionData(
appId: "<--App Id-->",
channelName: "test",
),
enabledPermission: [
Permission.camera,
Permission.microphone,
],
agoraChannelData: AgoraChannelData(
channelProfile: ChannelProfile.LiveBroadcasting,
clientRole: ClientRole.Broadcaster,
),
agoraEventHandlers: AgoraEventHandlers(
userJoined: (uid, elapsed) => print("CUSTOM USER JOIN: $uid"),
userOffline: (uid, reason) => print("CUSTOM USER OFFLINE REASON $reason"),
),
);

AgoraClient methods

Agora UIKit for Flutter automatically generates tokens for you such that you just have to provide the link to your deployed server. Have a look at this guide to follow the steps on how to generate your own token server. This can be summarized in your AgoraClient class as:

AgoraClient(
agoraConnectionData: AgoraConnectionData(
appId: '<--App Id--->',
channelName: 'test',
tokenUrl: 'https://example-agora-token-server.com'
),
enabledPermission: [Permission.camera, Permission.microphone],
);

Using a token server

AgoraVideoViewer Class

AgoraVideoViewer is a customizable user video class for local and remote views that adjusts dynamically for the number of users. As of now, there are two default layouts Grid and Floating.

Creating a Flutter Video Streaming App with Three Lines of Code - Screenshot #1
Agora Flutter UIKit

Features of the AgoraVideoViewerClass :

  • Adjust the UI dynamically as the user joins or leaves.
  • Focus on the active speaker (Floating layout).
  • Pin local and remote users to the main screen (Floating layout).
  • Show the state of the camera and the microphone of local and remote users.
  • Customize the view that should be displayed when the remote video is turned off.
Creating a Flutter Video Streaming App with Three Lines of Code - Screenshot #2
AgoraVideoViewer Class sample

Here is a sample code to sum it up:

AgoraVideoViewer(
client: client,
layoutType: Layout.Floating,
floatingLayoutContainerHeight: 100,
floatingLayoutContainerWidth: 100,
showNumberOfUsers: true,
showAVState: true,
),

AgoraVideoViewer

To have a look at other methods and their usage, see the documentation.

AgoraVideoButtons Class

The AgoraVideoButtons class is a completely customizable class to add, remove, and customize the buttons in your layout. By default, the AgoraVideoButtons class has four built-in buttons : disconnect, switch camera, toggle camera, and toggle microphone button. You can use the enabledButtons method to remove any or all of the default buttons or change the order of these buttons.

In addition, you can use the extraButtons method to provide a list of buttons that you want to add according to your styling.

Creating a Flutter Video Streaming App with Three Lines of Code - Screenshot #3
AgoraVideoButtonClass sample

Here is a way to implement this:

AgoraVideoButtons(
client: client,
enabledButtons: [
BuiltInButtons.ToggleMic,
BuiltInButtons.CallEnd,
BuiltInButtons.SwitchCamera
],
extraButtons: [
RawMaterialButton(
onPressed: () {
setState(() {
isVisible = !isVisible;
});
},
child: Container(
padding: const EdgeInsets.all(12.0),
decoration: BoxDecoration(
shape: BoxShape.circle,
color: isVisible ? Colors.white : Colors.blue),
child: isVisible
? Icon(
Icons.visibility,
color: Colors.blue,
size: 20,
)
: Icon(
Icons.visibility_off,
color: Colors.white,
size: 20,
),
),
)
],
)

Conclusion

Congratulations! You can now go ahead and build your own video calling and live video streaming application with just a few lines of code.

If there are features you think would be good to add to the Agora UIKit for Flutter that users would benefit from, feel free to fork the repository and add a pull request. Or open an issue on the repository with a feature request.

The plan is to grow this library and have similar offerings across all supported platforms. There are already similar libraries for Android, React Native, and iOS, so be sure to check those out.

Other Resources

The Agora UIKit library is available on pub.dev so make sure to go ahead and check it out. You can find the documentation for the library here.

For more information about building applications using Agora SDKs, take a look at the Agora Video Call Quickstart Guide and Agora API Reference.

And I invite you to join the Agora Developer Slack community.

RTE Telehealth 2023
Join us for RTE Telehealth - a virtual webinar where we’ll explore how AI and AR/VR technologies are shaping the future of healthcare delivery.

Try Agora for Free

Sign up and start building! You don’t pay until you scale.
Try for Free
Get Started with Agora thumbnail