狀態開始

狀態開始事件表示媒體播放器進入追蹤狀態,例如全熒幕、靜音或隱藏式字幕。 播放器可同時處於多個狀態,且狀態可在相同事件呼叫中開始和結束。 以狀態end事件關閉每個狀態。

有效的狀態名稱: fullscreenmuteclosedCaptioningpictureInPictureinFocus

建議的實作型別

Web SDK

使用eventType: "media.statesUpdate"statesStart中的狀態名稱呼叫sendEvent

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

可以在相同呼叫中開始多個狀態:

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

使用狀態物件(從適當的MediaConstants.PlayerState常數建立)的trackPlayerStateStart

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

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

使用狀態物件(從適當的MediaConstants.PlayerState常數建立)的trackPlayerStateStart

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

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

使用eventType: "media.statesUpdate"statesStart中的狀態名稱呼叫sendMediaEvent

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

呼叫statesUpdate端點,其狀態名稱位於statesStart中:

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": 60,
        "statesStart": [{ "name": "fullscreen" }]
      },
      "timestamp": "YYYY-08-20T22:41:40+00:00"
    }
  }]
}'

舊版實作型別(僅限Analytics)

Media SDK JS 3.x

搭配適當的ADB.Media.PlayerState常數使用ADB.Media.createStateObject

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

tracker.trackPlayerStateStart(stateObject);
Chromecast

搭配適當的ADBMobile.media.PlayerState常數使用ADBMobile.media.createStateObject

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

ADBMobile.media.trackEvent(ADBMobile.media.Event.StateStart, stateObject);
媒體收集API

傳送stateStart張貼至事件端點

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