L'API Co-Watching gère l'expérience de réunion de plusieurs participants qui regardent ou écoutent du contenu dans votre application.
Ce guide explique comment implémenter l'API Co-Watching.
Commencer
Pour utiliser l'API Co-Watching, vous devez d'abord déployer un module complémentaire Meet. Une fois ces étapes effectuées, vous pouvez commencer à utiliser l'API Co-Watching depuis votre nouveau module complémentaire.
Pour utiliser l'API Co-Watching, commencez par obtenir un objet AddonSession
, qui sert de point d'entrée pour les activités de groupe Google Meet :
TypeScript
const session = await window.meet.addon.createAddonSession({
cloudProjectNumber: "CLOUD_PROJECT_NUMBER",
});
Remplacez CLOUD_PROJECT_NUMBER par le numéro de projet de votre projet Google Cloud.
Créer un client de visionnage à plusieurs
Pour commencer, créez un objet CoWatchingClient
à partir de votre AddonSession
.
Pour créer un CoWatchingCient
, appelez la méthode createCoWatchingClient()
et fournissez un objet CoWatchingDelegate
.
CoWatchingDelegate
est la façon dont l'API Co-Watching met à jour votre application chaque fois qu'un nouvel état est disponible. Lorsque la méthode onCoWatchingStateChanged()
est appelée, votre application doit appliquer immédiatement le nouvel état.
L'exemple de code suivant montre comment utiliser l'API Co-Watching :
TypeScript
const coWatchingClient = await addonSession.createCoWatchingClient({
activityTitle: "ACTIVITY_TITLE",
onCoWatchingStateQuery() {
// This function should return the current state of your CoWatching activity
return getMyApplicationCoWatchingState();
},
onCoWatchingStateChanged(coWatchingState: CoWatchingState) {
// This function should apply newState to your ongoing CoWatching activity
},
});
Remplacez ACTIVITY_TITLE par le titre du contenu multimédia de votre activité.
Gérer l'état actuel
Lorsque les utilisateurs effectuent une action dans votre application, celle-ci doit immédiatement appeler les méthodes d'API fournies.
Vous ne devez appeler ces méthodes qu'en réponse à des événements importants. Par exemple, vous n'avez pas besoin de les appeler chaque fois que votre application avance une vidéo en cours de lecture. Le CoWatchingDelegate
que vous créez gère la mise à jour des positions de lecture dans ces circonstances.
Vous pouvez contrôler l'état du visionnage à plusieurs à l'aide des méthodes suivantes :
notifyBuffering()
: Appel lorsque l'application d'un utilisateur commence à mettre en mémoire tampon en raison d'une mise en mémoire tampon à la suite d'un changement de contenu multimédia, d'une recherche de contenu multimédia ou d'une congestion du réseau.notifyPauseState()
: appel lorsque l'utilisateur met en pause ou relance la lecture du contenu multimédia.notifyPlayoutRate()
: Appelez cette méthode lorsqu'un utilisateur modifie la vitesse de lecture sur une nouvelle valeur (par exemple, 1,25x).notifyReady()
: Appelez lorsque la mise en mémoire tampon est terminée et que le contenu multimédia est prêt à être lu.notifySeekToTimestamp()
: à appeler lorsqu'un utilisateur modifie explicitement la position de lecture.notifySwitchToMedia()
: appelez chaque fois que le contenu multimédia en cours de lecture change. Par exemple, l'utilisateur sélectionne une nouvelle vidéo ou la lecture automatique lance la vidéo suivante.