Fim do estado

O evento de fim de estado indica que o reprodutor de mídia saiu de um estado rastreado, como tela cheia, mudo ou legendas ocultas. Enviá-lo para fechar um estado aberto por Início do estado. Os estados podem ser iniciados e encerrados na mesma chamada de evento. Um reprodutor pode sair de vários estados simultaneamente.

Nomes de estados válidos: fullscreen, mute, closedCaptioning, pictureInPicture, inFocus

Tipos de implementação recomendados

Web SDK

Chame sendEvent com eventType: "media.statesUpdate" e o nome do estado em statesEnd:

code language-javascript
alloy("sendEvent", {
  xdm: {
    eventType: "media.statesUpdate",
    mediaCollection: {
      statesEnd: [{ name: "fullscreen" }],
      sessionID: "{sid}",
      playhead: 90
    }
  }
});

Os estados podem ser iniciados e encerrados na mesma chamada:

code language-javascript
alloy("sendEvent", {
  xdm: {
    eventType: "media.statesUpdate",
    mediaCollection: {
      statesStart: [{ name: "mute" }],
      statesEnd: [{ name: "fullscreen" }],
      sessionID: "{sid}",
      playhead: 90
    }
  }
});
iOS

Use trackPlayerStateEnd com um objeto de estado criado a partir da constante MediaConstants.PlayerState apropriada.

code language-swift
let stateObject = Media.createStateObjectWith(stateName: MediaConstants.PlayerState.FULLSCREEN)

tracker.trackEvent(event: MediaEvent.StateEnd, info: stateObject, metadata: nil)
Android

Use trackPlayerStateEnd com um objeto de estado criado a partir da constante MediaConstants.PlayerState apropriada.

code language-kotlin
val stateObject = Media.createStateObject(MediaConstants.PlayerState.FULLSCREEN)

tracker.trackEvent(Media.Event.StateEnd, stateObject, null)
Roku

Chame sendMediaEvent com eventType: "media.statesUpdate" e o nome do estado em statesEnd:

code language-brightscript
m.aepSdk.sendMediaEvent({
    "xdm": {
        "eventType": "media.statesUpdate",
        "mediaCollection": {
            "statesEnd": [{ "name": "fullscreen" }],
            "playhead": 90
        }
    }
})
API do Media Edge

Chame o ponto de extremidade statesUpdate com o nome de estado em statesEnd:

code language-sh
curl -X POST "https://edge.adobedc.net/ee/va/v1/statesUpdate?configId={datastreamID}" \
--header 'Content-Type: application/json' \
--data '{
  "events": [{
    "xdm": {
      "eventType": "media.statesUpdate",
      "mediaCollection": {
        "sessionID": "{sid}",
        "playhead": 90,
        "statesEnd": [{ "name": "fullscreen" }]
      },
      "timestamp": "YYYY-08-20T22:41:40+00:00"
    }
  }]
}'

Tipos de implementação herdada (somente Analytics)

Media SDK JS 3.x

Usar ADB.Media.createStateObject com a constante ADB.Media.PlayerState apropriada:

code language-javascript
var stateObject = ADB.Media.createStateObject(ADB.Media.PlayerState.Fullscreen);

tracker.trackPlayerStateEnd(stateObject);
Chromecast

Usar ADBMobile.media.createStateObject com a constante ADBMobile.media.PlayerState apropriada:

code language-javascript
var stateObject = ADBMobile.media.createStateObject(ADBMobile.media.PlayerState.FullScreen);

ADBMobile.media.trackEvent(ADBMobile.media.Event.StateEnd, stateObject);
API da coleção de mídia

Enviar uma POSTAGEM stateEnd para o ponto de extremidade de eventos:

code language-json
{
  "playerTime": { "playhead": 90, "ts": 1699523820000 },
  "eventType": "stateEnd",
  "params": {
    "media.state.name": "fullscreen"
  }
}
recommendation-more-help
media-analytics-help