Les traductions sont fournies par des outils de traduction automatique. En cas de conflit entre le contenu d'une traduction et celui de la version originale en anglais, la version anglaise prévaudra.
Parcourez les événements pour les entités abonnées
Permet AllSubscriptionEvents()
d'obtenir une liste des événements pour les entités abonnées (entités situées dans la zone d'abonnement de l'application). La fonction possède la signature suivante :
Result<SubscriptionChangeList> AllSubscriptionEvents(Transaction& txn)
Effectuez ensuite une itération sur les entités à l'aide d'une boucle, comme illustré dans l'exemple suivant.
Exemple
WEAVERRUNTIME_TRY(Api::SubscriptionChangeList subscriptionChangeList, Api::AllSubscriptionEvents(transaction)); for (const Api::SubscriptionEvent& event : subscriptionChangeList.changes) { Api::Entity entity = event.entity; Api::ChangeListAction action = event.action; switch (action) { case Api::ChangeListAction::None: // insert code to handle the event break; case Api::ChangeListAction::Remove: // insert code to handle the event break; case Api::ChangeListAction::Add: // insert code to handle the event break; case Api::ChangeListAction::Update: // insert code to handle the event break; case Api::ChangeListAction::Reject: // insert code to handle the event break; } }
Types d’événements
None
— L'entité se trouve dans la zone et ses données de position et de champ n'ont pas été modifiées.Remove
— L'entité a été supprimée de la zone.Add
— L'entité a été ajoutée à la zone.Update
— L'entité se trouve dans la zone et a été modifiée.Reject
— L'application n'a pas réussi à supprimer l'entité de la zone.
Note
Dans le cas d'un Reject
événement, l'application tentera à nouveau le transfert à la prochaine case.