Mesibo Video & Voice Conferencing

Quick Start with Mesibo Video Conferencing API for Android

{{ define "dev_setup" }}

  1. Start Android Studio.
  2. Create a new project with a minimum SDK version 16 or higher.
  3. Android Studio starts Gradle and builds your project. This may take a few seconds. For more information about creating a project in Android Studio, see https://developer.android.com/training/basics/firstapp/creating-project.htmlopen_in_new
  4. Add the following dependencies in the /app/build.gradle file of your project and perform gradle sync as explained in Installation Instructions.
dependencies {
    ...	
    implementation "com.mesibo.api:calls:${project.MesiboVersion_Calls}"
    ...
}
  1. You can then import Mesibo Call API as follows.
import com.mesibo.calls.api.MesiboCall;

{{ end }}

{% capture create_groupcall %} {% endcapture %}

{% capture on_publisher %}

public void MesiboGroupcall_OnPublisher(MesiboParticipant participant, boolean joined) {
  if (joined) {
    // call the publisher to view their stream
    // Add participant to list of publishers
  } else {
    // Remove participant from list of publishers
  }
}

{% endcapture %}

{% capture on_subscriber %}

public void MesiboGroupcall_OnSubscriber(MesiboCall.MesiboParticipant participant, boolean joined) {
  // This participant has subscribed to your stream
}

{% endcapture %}

{% capture join_room %}

For example, If you implement the GroupCallListener in your fragment like this

public class GroupCallFragment extends Fragment implements MesiboCall.GroupCallListener{

    @Override
    public void MesiboGroupcall_OnPublisher(MesiboCall.MesiboParticipant participant, boolean joined) {
    ...
    }

    @Override
    public void MesiboGroupcall_OnSubscriber(MesiboCall.MesiboParticipant p, boolean joined) {
        ...
    }

...
}

then, you can call join in the context of "this" fragment like this

If you have implemented the GroupCallListener in a separate class like this

public class MyGroupCallListener implements MesiboCall.GroupCallListener {

    @Override
    public void MesiboGroupcall_OnPublisher(MesiboCall.MesiboParticipant participant, boolean joined) {
    ...
    }

    @Override
    public void MesiboGroupcall_OnSubscriber(MesiboCall.MesiboParticipant p, boolean joined) {
        ...
    }

 ...
}

then, you can create an instance of the listener and pass it like this

MyGroupCallListener listener = new MyGroupCallListener();
mGroupCall.join(listener);

{% endcapture %}

{% capture on_mute %} {% endcapture %}

{% capture get_mute_status %} {% endcapture %}

{% capture toggle_mute %} {% endcapture %}

{% capture on_talking %} {% endcapture %}

{% capture is_talking %} {% endcapture %}

{% capture hangup%} {% endcapture %}

{% capture on_hangup %} {% endcapture %}

{% capture on_publisher_multiple %}

public void MesiboGroupcall_OnPublisher(MesiboCall.MesiboParticipant participant, boolean joined) {
   if (joined) {
        // participant object for front cam 
        // or participant object for rear cam
        // or participant object for screen, ..etc.
        
        // subscribe to each stream
        participant.call(true, true, this); 
    } 
}

{% endcapture %}

{% capture display_streams%} {% endcapture %}

{% capture leave_room %} {% endcapture %}

Prerequisites

Before we dive into the various concepts and APIs for conferencing & streaming, you need to go through the following to familiarize yourself with mesibo APIs.

Key Terms

In this document, we will use the following terms

  • Conference - Any group communication session such as a group call, webinar, or live stream. We will refer to all use cases as a "conference".
  • Room - The mesibo group used to hold the conference. Conference participants are members of this group.
  • Participant - Any user taking part in the conference. A participant can be a publisher, subscriber, or both.
  • Host - The participant who created the room. The host controls who can join and participate in the room, by setting permissions.
  • Stream - Audio, video (camera, screen share, etc.)
  • Publishing - Sending video/voice stream to the conference. A participant can publish any number of streams. For example, they can stream from their camera and share their screen, they can also stream from multiple cameras to build a 360 view!
  • Subscribing - Receiving streams of other participants
  • Publisher - The participant sending voice/video streams
  • Subscriber - The participant listening to other participant's voice or viewing video streams

Quick Start with Conferencing API

As explained before, to create a conference room, the host needs to create a mesibo group and add participants as members using the Group Management APIs. Once a room is created, participants can join the room, publish and view streams using the Conferencing APIs available for Android, iOS, or Javascript.

In this section, we will learn how to use mesibo conferencing APIs to perform typical operations in a conference room such as joining conference rooms, publishing streams, viewing streams, etc. By the end of this document, you will be ready to build a fully functional conferencing app.

We recommend that you go through the source code for the open-source conferencing app at https://github.com/mesibo/conferencingopen_in_new to learn more.

Follow the steps below to create a conferencing/streaming app:

Create a Room and add Participants

You need to Create a Room and add participants using Group Management APIs.

For example, to create a basic meeting app with four participants - Alice, Bob, Carol and Dave, Create a mesibo group, Office Meeting and add four users Alice, Bob, Carol and Dave, as members to this group.

Set permissions for Alice and Bob to publish and view streams. Set permissions for Carol and Dave to only view streams. You can learn more about adding participants and setting permissions in the previous section.

Once you create the room, the Participants - Alice, Bob, Carol, and Dave can join through mobile or web apps using the Conferencing APIs.

Create a Group Call Object

The first step in joining a group call is to create a Group Call object - An instance of MesiboGroupCall. This global object represents the conference and holds all the participants & streams in the room.


// Create a group call object
MesiboCall.MesiboGroupCall mGroupcall = 
MesiboCall.getInstance().groupCall((MesiboCallActivity) getActivity(), mGid);
// Create a group call object
MesiboCall.MesiboGroupCall *MesiboGroupCallInstance =  
[MesiboCallInstance groupCall:self groupid:mGid];  
// Create a group call object
//
let mGroupcall = api.groupCall(this, groupid);

You need to use this object to join a room and create publishers as explained in the upcoming steps.

Implement GroupCallListener

You will need to implement GroupCallListener and pass it to the Group Call object which you created in the step above so that it can notify you when other participant joins and leaves the room by calling MesiboGroupcall_OnPublisher. It also notifies you when a participant subscribes to your video or voice streams through MesiboGroupcall_OnSubscriber.

intro-example

public void MesiboGroupcall_OnPublisher(MesiboParticipant participant, boolean joined) {
  if (joined) {
    // call the publisher to view their stream
    // Add participant to list of publishers
  } else {
    // Remove participant from list of publishers
  }
}

public void MesiboGroupcall_OnSubscriber(MesiboCall.MesiboParticipant participant, boolean joined) {
  // This participant has subscribed to your stream
}
-(void) MesiboGroupcall_OnPublisher:(MesiboParticipant *)participant joined:(BOOL)joined {
  if (joined) {
    // call the publisher to view their stream
    // Add participant to list of publishers
  } else {
    // Remove participant from list of publishers
  }
}

-(void) MesiboGroupcall_OnSubscriber:(MesiboParticipant *)participant joined:(BOOL)joined{
  // This participant has subscribed to your stream
}
GroupCallListener.prototype.MesiboGroupcall_OnPublisher = function(p, joined) {  
  if (joined) {
    // call the publisher to view their stream
    // Add participant to list of publishers
  } else {
    // Remove participant from list of publishers
  }
}

GroupCallListener.prototype.MesiboGroupcall_OnSubscriber = function(p, joined) {
        // This participant has subscribed to your stream
}

How to get Publishers

When you join the room, you will start getting a list of publishers through MesiboGroupcall_OnPublisher. This listener will be called for each publisher in the room and also when publishers join later. Once you know who all are publishing in the room, you can subscribe to their stream.

Whenever someone starts or stops publishing a stream, mesibo will call MesiboGroupcall_OnPublisher.

How to get Subscribers

When you start publishing your stream to the group, everyone in the group will be notified about your stream through MesiboGroupcall_OnPublisher.

When anyone subscribes to your stream, you will be notified through MesiboGroupcall_OnSubscriber. You will get the information about the subscriber like name, address, etc. which you can use for typical book-keeping.

Whenever someone starts or stops subscribing to your stream, mesibo will call MesiboGroupcall_OnSubscriber.

To join a conference, you need to implement GroupCallListener and pass it to the join method as explained in the next step.

Join a Room

To join the room, use the join method from the Group Call object that you created before.


// 'this' has implemented GroupCallListener
mGroupCall.join(this);
// 'self' has implemented GroupCallListener
[MesiboGroupCallInstance join:self];
// 'listener' has implemented GroupCallListener
mGroupcall.join(listener);

Subscribe to a stream using a Participant Object

To subscribe to a stream, you need a Participant object received through the MesiboGroupcall_OnPublisher listener.

Every stream in the conference is represented by a Participant object - An instance of MesiboParticipant. A Participant object contains details about the stream such as the name and address of the publisher, audio & video properties, mute status, talk status, etc. To perform any operation on the stream such as subscribing to a stream, publishing a stream, muting the stream, etc. you need to use the corresponding Participant object.

You will get the Participant object of publishers through MesiboGroupcall_OnPublisher. To subscribe to a publisher, you need to use the call method from the Participant object.

View Streams

The call method similar to the P2P Mesibo Call API takes the following parameters:

  • audio, true if you would like to receive the audio stream, false otherwise
  • video, true if you would like to receive the video stream, false otherwise
  • groupCallInProgressListener, An instance of GroupCallInProgressListener

// only receive audio
participant.call(true, false, listener);

or

// receive both video and audio
participant.call(true, true, listener);
// only receive audio
[participant call:YES  video:NO listener:listener];

or

// receive both video and audio
[participant call:YES  video:YES listener:listener];
// only receive audio
participant.call(true, false, listener);

or

// receive both video and audio
participant.call(true, true, listener);

Note that, the publisher should be publishing the corresponding video or audio stream. For example, if the publisher is publishing only the audio stream, invoking call with video parameters will not yield any video stream.

You will need to implement a GroupCallInProgressListener and pass it as a parameter to the call method to listen to Participant events such as when they mute, start talking, etc. Once you subscribe to a publisher, you will receive audio and video streams and you can display/view them.


public void MesiboGroupcall_OnPublisher(MesiboParticipant participant, boolean joined) {
  if (joined) {
    // call the publisher to subscribe to their stream
    // "this" is a GroupCallInProgressListener 
    participant.call(true, true , this);
  }
}
-(void) MesiboGroupcall_OnPublisher:(MesiboParticipant *)participant joined:(BOOL)joined{
  if (joined) {
    // call the publisher to subscribe to their stream
    // "self" is a GroupCallInProgressListener 
    [participant call:YES  video:NO inProgressListener:self];
  }
}
GroupCallListener.prototype.MesiboGroupcall_OnPublisher = function(participant, joined) {  
  if (joined) {
    // call the publisher to subscribe to their stream
    // "this" is a GroupCallInProgressListener 
    participant.call(true, true , this);
  }
}

Implement GroupCallInProgressListener

Mesibo informs you of various participant events so that you can easily update your App UI or take necessary action, such as,

  • When you make a call using the call method and you are connected, MesiboGroupcall_OnConnected will be called.
  • Once you are connected, you will be notified when you receive the video stream through the listener MesiboGroupcall_OnVideo or the audio stream through MesiboGroupcall_OnAudio
  • When a publisher mutes audio or video, you will be notified through MesiboGroupcall_OnMute
  • When a publisher starts talking, MesiboGroupcall_OnTalking will be called (Talk Detection).
  • When a publisher changes video source (say, to another camera or the screen), MesiboGroupcall_OnVideoSourceChanged will be called.
  • When a publisher leaves the conference, MesiboGroupcall_OnHangup will be called

While subscribing to a stream using the call method, you need to pass an instance of GroupCallInProgressListener.

The following are important participant events that you need to handle, by implementing the GroupCallInProgressListener. For the complete list of events, refer to the reference.

When the call gets connected

MesiboGroupcall_OnConnected is called when the call to a publisher is connected, reconnected, or disconnected. Note that, you will receive video and audio streams only after getting connected.


public void MesiboGroupcall_OnConnected(MesiboCall.MesiboParticipant participant, 
                                                boolean connected) {
    if(connected){
        // Participant is connected or reconnected
    } else {
        // Participant has been disconnected
    }
}
-(void) MesiboGroupcall_OnConnected:(MesiboParticipant *)participant 
                                                connected:(BOOL)connected {
    if(connected){
        // Participant is connected or reconnected
    } else {
        // Participant has been disconnected
    }
}
GroupCallInProgressListener.prototype.MesiboGroupcall_OnConnected =
                                    function(participant, connected) {
    if(connected){
        // Participant is connected or reconnected
    } else {
        // Participant has been disconnected
    }
}

When you receive the video stream

MesiboGroupcall_OnVideo is called when you receive a video from the publisher you have subscribed to. You can now display the stream. It is also called when any properties of the video change. For example, if there are changes in aspect ratio, resolution, orientation (say portrait to landscape), etc. You can accordingly update the UI to display the video or reflect changes.


public void MesiboGroupcall_OnVideo(MesiboCall.MesiboParticipant participant, 
  float aspect_ratio, boolean available) {
    // Display the video
}
-(void) MesiboGroupcall_OnVideo:(MesiboParticipant *)participant 
  aspectRatio:(float)ratio available:(BOOL)available {
    // Display the video
}
GroupCallInProgressListener.prototype.MesiboGroupcall_OnVideo = 
                                            function(participant) { 
  // Display the video
}

When you receive the audio stream

MesiboGroupcall_OnAudio is called when you receive audio from the participant.


public void MesiboGroupcall_OnAudio(MesiboCall.MesiboParticipant participant) {
    // Receiving Audio
}
-(void) MesiboGroupcall_OnAudio:(MesiboParticipant *)participant { 
    // Receiving Audio
}
GroupCallInProgressListener.prototype.MesiboGroupcall_OnAudio = function(participant) {   
  // Receiving Audio
}

When publisher mutes audio or video

MesiboGroupcall_OnMute is called when the publisher mutes audio or video.


public void MesiboGroupcall_OnMute(MesiboCall.MesiboParticipant participant, 
  boolean audioMuted, boolean videoMuted) {
    
    if(remote){
	    // Remote participant has muted
    }

    // Check mute status
    if(audioMuted){
        // Audio Muted
    }

    if(videoMuted){
        // Video Muted
    }
}
-(void) MesiboGroupcall_OnMute:(MesiboParticipant *)participant 
  audio:(BOOL)audioMuted video:(BOOL)videoMuted {

    if(remote){
	// Remote participant has muted
    }

    // Check mute status
    if(audioMuted){
        // Audio Muted
    }

    if(videoMuted){
        // Video Muted
    }
}
GroupCallInProgressListener.prototype.MesiboGroupcall_OnMute = 
            function(participant, audioMuted, videoMuted, remote) { 

    if(remote){
	    // Remote participant has muted
    }

    // Check mute status
    if(audioMuted){
        // Audio Muted
    }

    if(videoMuted){
        // Video Muted
    }
}

You can also use the getMuteStatus method to know about the current mute status of a participant.


// Pass true to get video mute status, false for audio mute status
participant.getMuteStatus(true); // Get Audio Mute Status
participant.getMuteStatus(false); // Get Video Mute Status
// Pass YES to get video mute status, NO for audio mute status
[participant getMuteStatus:YES]; // Get Audio Mute Status
[participant getMuteStatus:NO]; // Get Video Mute Status
// Pass true to get video mute status, false for audio mute status
participant.getMuteStatus(true); // Get Audio Mute Status
participant.getMuteStatus(false); // Get Video Mute Status

You can also mute video and audio locally, for the streams that you are viewing. You can use the toggleAudioMute method to toggle the audio and the toggleVideoMute method to toggle the video of a stream.

For example,


participant.toggleVideoMute();
participant.toggleAudioMute();
[participant toggleVideoMute]
[participant toggleAudioMute]
participant.toggleVideoMute();
participant.toggleAudioMute();

If you mute a stream that you are publishing (you created the Participant object), other participants who are subscribing to your stream, will be notified of it through MesiboGroupcall_OnMute

When a publisher starts talking (Voice Activity Detection)

Mesibo let you know when the publisher is talking (VAD). MesiboGroupcall_OnTalking is called when the participant starts or stops talking.


public void MesiboGroupcall_OnTalking(MesiboCall.MesiboParticipant participant, boolean talking) {
        if(talking){
                // If talking is true, participant started talking
                // if it is false, participant stopped talking
        }
    }
-(void) MesiboGroupcall_OnTalking:(MesiboParticipant *)participant talking:(BOOL)talking {
        if(talking){
                // If talking is true, participant started talking
                // if it is false, participant stopped talking
        }
    }
GroupCallInProgressListener.prototype.MesiboGroupcall_OnTalking = function(participant, talking) {
        if(talking){
            // If talking is true, participant started talking
            // if it is false, participant stopped talking
        }
}

You can also use the isTalking method from the Participant object to check if the publisher is talking.


participant.isTalking();
[participant isTalking];
participant.isTalking();

Hangup

To hang up a stream, you need to use the hangup method from the Participant object.


participant.hangup()
[participant hangup]
participant.hangup()

When a publisher hangs up, those who are subscribing to that publisher will be notified of it through MesiboGroupcall_OnHangup


public void MesiboGroupcall_OnHangup(MesiboCall.MesiboParticipant p, int reason) {
    if(MESIBOCALL_HANGUP_REASON_REMOTE == reason){
        // Remote participant has hanged up
        // Cleanup
    }
}
-(void) MesiboGroupcall_OnHangup:(MesiboParticipant *)participant reason:(int)reason{
    if(MESIBOCALL_HANGUP_REASON_REMOTE == reason){
        // Remote participant has hanged up
        // Cleanup
    }
}
GroupCallInProgressListener.prototype.MesiboGroupcall_OnHangup = function(p, reason) {
    if(MESIBOCALL_HANGUP_REASON_REMOTE == reason){
        // Remote participant has hanged up
        // Cleanup
    }
}

The reason for hangup can be one of the following:

  • MESIBOCALL_HANGUP_REASON_REMOTE, The remote participant hanged up
  • MESIBOCALL_HANGUP_REASON_BACKGROUND, The application moved into the background
  • MESIBOCALL_HANGUP_REASON_USER, The user hung up the participant
  • MESIBOCALL_HANGUP_REASON_ERROR, An error occurred

Subscribing to multiple streams from a participant

A participant can publish as many streams as they wish, for example, multiple cameras, multiple audios, multiple screens, etc. If a participant is publishing multiple streams, MesiboGroupcall_OnPublisher will be called for each stream.

For example, let's say we have a participant on mobile, sending three streams - one from the front camera, one from the rear camera, and sharing the screen simultaneously. In this case, MesiboGroupcall_OnPublisher will be called thrice with three different participant objects. You can use the call method from each of these participant objects to subscribe to each of these streams and display them.


public void MesiboGroupcall_OnPublisher(MesiboParticipant participant, boolean joined) {
  if (joined) {
        // participant object for front cam, or 
        // participant object for rear cam, or
        // participant object for screen, ..etc.
        
        // subscribe to each stream
        participant.call(true, true , this);
  }
}
-(void) MesiboGroupcall_OnPublisher:(MesiboParticipant *)participant joined:(BOOL)joined{
  if (joined) {
        // participant object for front cam, or 
        // participant object for rear cam, or
        // participant object for screen, ..etc.
        
        // subscribe to each stream
        [participant call:YES  video:NO inProgressListener:self];
  }
}
GroupCallListener.prototype.MesiboGroupcall_OnPublisher = function(participant, joined) {  
  if (joined) {
        // participant object for front cam, or 
        // participant object for rear cam, or
        // participant object for screen, ..etc.
        
        // subscribe to each stream
        participant.call(true, true , this);
  }
}

Publish a Stream by creating a Participant Object

In previous sections, we learned how to subscribe to streams from other publishers. In this section, we will learn about how to publish your stream so that others can subscribe to it.

As we explained before, every stream in the conference is a Participant object - An instance of MesiboParticipant. To publish a stream, you need to create a Participant object using the createPublisher method from the Group Call object. Then, use the call method to publish your stream. You also need to implement a GroupCallInProgressListener and pass it as a parameter to the call method, just like in the case of subscribing to a stream.

Publish Streams

//Create a participant object
mParticipant = mGroupcall.createPublisher(0);

//Set the source. For example, camera
mParticipant.setVideoSource(MesiboCall.MESIBOCALL_VIDEOSOURCE_CAMERAFRONT, 0);

//Make a call. "this" is an instance of GroupCallInProgressListener 
mParticipant.call(true, true, this);
//Create a participant object
MesiboParticipant *mParticipant = [GroupCallInstance createPublisher:0];

//Set the source. For example, camera
[mParticipant setVideoSource:MESIBOCALL_VIDEOSOURCE_CAMERAFRONT index:0];

//Make a call. "self" is an instance of GroupCallInProgressListener 
[mParticipant call:YES video:YES listener:self];
//Create a participant object
let mParticipant = mGroupcall.createPublisher(0);

//Set the source. For example, camera
mParticipant.setVideoSource(MESIBOCALL_VIDEOSOURCE_CAMERAFRONT, 0);

//Make a call. "this" is an instance of GroupCallInProgressListener 
mParticipant.call(true, true, this);

Once you publish, all other participants in the room will get your Participant object. A participant can publish multiple streams by creating multiple Participant objects.

publish

Publishing Multiple Streams

You can create a Participant object using the createPublisher method from the Group Call Object. Each participant needs to have a unique sid or stream-id, which can be any random number(a long integer, up to 32 bits). A participant can publish multiple streams by creating multiple participant objects each with a different sid.

For example, if you want to publish three streams - one from the front camera, one from the rear camera and share the screen simultaneously, you need to create three participant objects.


MesiboParticipant mFrontCamera = mGroupcall.createPublisher(0);
MesiboParticipant mRearCamera = mGroupcall.createPublisher(1);
MesiboParticipant mScreen = mGroupcall.createPublisher(2);
MesiboParticipant *mFrontCamera = [GroupCallInstance createPublisher:0];
MesiboParticipant *mRearCamera = [GroupCallInstance createPublisher:1];
MesiboParticipant *mScreen = [GroupCallInstance createPublisher:2];
let mFrontCamera = mGroupcall.createPublisher(0);
let mRearCamera = mGroupcall.createPublisher(1);
let mScreen = mGroupcall.createPublisher(2);

Set the Video Source

A participant can publish streams from two types of video sources - camera or screen. You can specify the source, using the setVideoSource method which takes the following parameters:

  • source, which can be one of the following:
    • MESIBOCALL_VIDEOSOURCE_CAMERADEFAULT Default camera to publish from
    • MESIBOCALL_VIDEOSOURCE_CAMERAFRONT to publish stream from the device's front camera (on Mobile)
    • MESIBOCALL_VIDEOSOURCE_CAMERAREAR to publish stream from the device's rear camera (on Mobile)
    • MESIBOCALL_VIDEOSOURCE_SCREEN to share live screen
  • index, Camera index. If there are multiple(in addition to the front and rear) cameras on mobile, set the camera index.

For example,


mFrontCamera.setVideoSource(MesiboCall.MESIBOCALL_VIDEOSOURCE_CAMERAFRONT, 0);
mRearCamera.setVideoSource(MesiboCall.MESIBOCALL_VIDEOSOURCE_CAMERAREAR, 0);
mScreen.setVideoSource(MesiboCall.MESIBOCALL_VIDEOSOURCE_SCREEN, 0);
[mFrontCamera setVideoSource:MESIBOCALL_VIDEOSOURCE_CAMERAFRONT index:0];
[mRearCamera setVideoSource:MESIBOCALL_VIDEOSOURCE_CAMERAREAR index:0];
[mScreen setVideoSource:MESIBOCALL_VIDEOSOURCE_SCREEN index:0];
mFrontCamera.setVideoSource(MESIBOCALL_VIDEOSOURCE_CAMERAFRONT, 0);
mRearCamera.setVideoSource(MESIBOCALL_VIDEOSOURCE_CAMERAREAR, 0);
mScreen.setVideoSource(MESIBOCALL_VIDEOSOURCE_SCREEN, 0);

If you are not publishing a video, and you are only streaming audio, you need not set any source. You can change the video source anytime during the call.

Switching the Video Source

You can switch between the two video sources - camera and screen using the switchSource method For instance, if are publishing a camera stream, and you call switchSource on your Participant object, you will switch to streaming from the screen. This is useful when the participant is using a mobile app and at a given time they need to only publish either from the front camera or share the mobile screen.

Publishing a Stream

To publish your stream, use the call method from the Participant object. You need to pass a GroupCallInProgressListener as a parameter to it.

When you publish your stream, you will also receive your stream and MesiboGroupCall_OnVideo will be called with your Participant object. You can then display your stream. Refer to the section Implement GroupCallInProgressListener to learn more.

The call method takes the following parameters:

  • audio, true if you would like to receive the audio stream, false otherwise
  • video, true if you would like to receive the video stream, false otherwise
  • groupCallInProgressListener, An instance of GroupCallInProgressListener

// Publish audio only
mParticipant.call(true, false, this);

or

// Publish both video and audio
mParticipant.call(true, false, this);
// Publish audio only
[mParticipant call:YES  video:NO listener:listener];

or

// Publish both video and audio
[mParticipant call:YES  video:YES listener:listener];
// Publish audio only
mParticipant.call(true, false, listener);

or

// Publish both video and audio
mParticipant.call(true, true, listener);

Once you make a call, your Participant object is sent to the group. All other participants(group members) will receive your Participant object through MesiboGroupcall_OnPublisher on their end. If they subscribe to your stream ( using the call method), you will be notified of it through MesiboGroupcall_OnSubscriber.

publish

Display Streams

Once you subscribe to a stream, you will receive the video and audio stream. When you receive the video, you will be notified by MesiboGroupCall_OnVideo and you can display the stream. When you receive the audio you will be notified by MesiboGroupCall_OnAudio


To display a video stream, you need a MesiboVideoView element.

Before, displaying the video it is a good practice to check if the stream has a video stream using the hasVideo method. Use the setVideoViewmethod from the Participant object, to display the stream in the UI element.

In Android, you can have a MesiboVideoView in your XML Layout file like below,

<com.mesibo.calls.api.MesiboVideoView
    android:id="@+id/participant_stream_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

You can display the stream in this view, as follows:

if(participant.hasVideo()){
    MesiboVideoView videoView = findViewById(R.id.participant_stream_view);
    participant.setVideoView(videoView);
}

You can use various methods from MesiboVideoView, to control how the video is displayed. For example, use the enableMirror method to mirror the video, the scaleToFill method to fill video, etc. Refer to the documentation for MesiboVideoView to learn more.

To display a video stream, you need a MesiboVideoView element.

Before, displaying the video it is a good practice to check if the stream has a video stream using the hasVideo method. Use the setVideoViewmethod from the Participant object, to display the stream in the UI element. You can display the stream in this view, as follows:

if([participant isVideoCall] && [participant hasVideo]) {

    [participant setVideoView:mVideoView];
}

You can use various methods from MesiboVideoView, to control how the video is displayed. For example, use the enableMirror method to mirror the video, the scaleToFill method to fill video, etc. Refer to the documentation for MesiboVideoView to learn more.

If you have an HTML element where you would like to display the stream, like below:

<video class="centered" id="video-publisher" autoplay playsinline width="100%" height="100%" />

You need to call setVideoView() as follows

function on_setvideo(set){

}

participant.setVideoView('video-publisher', on_setvideo, 100, 50);

In case you are using a DOM framework and the HTML element you need to display the stream is not created at the moment you call setVideoView(), you can try reattaching after a small delay or a timeout, which can be specified in retryTimeout. You can also specify the maximum number of attempts to attach in maxRetries. If the element is not available even after maxRetries is reached, setVideoView() will fail. In this case, on_setvideo will be called false. If setVideoView() is successful, it will be called with true

Example,

function on_setvideo(set){
    //set is `true` if the video element is displaying the video, false otherwise
}

//Calls setVideoView every 100ms, for a maximum number of 50 times, until successful
participant.setVideoView('video-publisher', on_setvideo, 100, 50);

Display multiple streams from a participant

Each stream published by a participant will have sid - the stream ID. The sid of a stream is arbitrary and is set by the publisher(using createPublisher). You can get the sid of a stream using the getSid method from the Participant object.

If a participant is publishing multiple streams, each stream will have a different sid. For example, let's say we have a participant sharing three streams - two cameras and one screen simultaneously. Now, in this case, MesiboGroupcall_OnPublisher will be called thrice, with three different Participant objects for three streams, each stream with a different sid. If we subscribe to each of these streams then, we receive three different video or audio streams. To display each stream, call setVideoView for each Participant object.

Leave the room

A participant can leave the room anytime. All other participants(if they have subscribed to that participant) will be informed that the participant has hanged up through MesiboGroupcall_OnHangup.


mGroupcall.leave();
[GroupCallInstance leave]
mGroupcall.leave();

Open-Source App

Now that you have are familiar with all the basic conferencing APIs, you are ready to build a fully functional conferencing app using mesibo! To make it easier for you, we have created a fully-featured open-source Zoom-like conferencing app for mobile and web. Head over to the next section Open Source App to learn more.

Open Source App >>

API Reference

Mesibo conferencing APIs are unified APIs available for Android, iOS, and Javascript. Mesibo maintains the same API signature across all platforms. This makes it easier for you to create cross-platform apps, target multiple platforms, or port code from one platform to another.

The following is a list of all methods and functions which are part of the Conferencing API, used in this document.

Client API Overview

MesiboGroupCall

The following are some of the methods in MesiboGroupCall class. Refer to the class reference for MesiboGroupCall for a complete list of methods and properties.

MethodDescription
createPublisherCreate a participant object to publish a stream.
joinJoin a group call
leaveLeave a group call

MesiboParticipant

The following are some of the methods in MesiboParticipant class. Refer to the class reference for MesiboParticipant for a complete list of methods and properties.

MethodDescription
callTo establish a connection to the participant to get the video/audio stream
setVideoViewTo display the stream in a UI element
getNameReturns the name of the participant set by the publisher
setNameSet the name of the participant
getAddressReturns the address of the participant
getSidReturns the streamId - set by the publisher
isMeReturns true if participant is a local stream, false otherwise
getIdReturns the unique stream-ID
isTalkingReturns true if participant is talking, false otherwise
toggleAudioMuteToggle stream audio
toggleVideoMuteToggle stream video
getMuteStatusCheck if participant has muted audio/video
hangupHangup the stream

GroupCallListener

The following functions are part of the GroupCallListener class.

FunctionDescription
MesiboGroupcall_OnPublisherCalled when a publisher has joined the conference
MesiboGroupcall_OnSubscriberCalled when a participant has subscribed to your stream
MesiboGroupcall_OnAudioDeviceChangedCalled when the participant has changed their audio source

GroupCallInProgressListener

The following functions are part of the GroupCallInProgressListener listener class.

FunctionDescription
MesiboGroupcall_OnConnectedCalled when the participant is connected or disconnected
MesiboGroupcall_OnVideoCalled when you receive the video stream from the participant
MesiboGroupcall_OnVideoSourceChangedCalled when the participant has changed the video source from which they are publishing, For example, from camera to screen.
MesiboGroupcall_OnAudioCalled when you receive the audio stream from the participant
MesiboGroupcall_OnMuteCalled when the particpipant has muted/unmuted their audio or video
MesiboGroupcall_OnTalkingCalled when the particpipant starts/stops talking
MesiboGroupcall_OnHangupCalled when the particpipant hangsup

Also see: