Chrome 75 中的媒体更新

François Beaufort
François Beaufort

Chrome 的媒体功能在版本 75 中进行了更新。在本文中,我将介绍这些新功能,包括:

  • 预测加密媒体是否能够流畅播放并实现高能效。
  • 支持视频元素的 playsInline 属性提示。

加密媒体:解码信息

从 Chrome 66 开始,Web 开发者可以使用解码信息,根据编解码器、配置文件、分辨率、比特率等信息向浏览器查询设备的清晰内容解码能力。它会根据浏览器记录的之前的播放统计信息,指明播放是否流畅(及时)且能否节省电量。

定义解码信息的 Media Capabilities API 规范也已更新,以处理加密媒体配置,以便使用加密媒体 (EME) 的网站可以选择最佳媒体串流。

简而言之,EME 的解码信息的运作方式如下。不妨试试官方示例

const encryptedMediaConfig = {
  type: 'media-source', // or 'file'
  video: {
    contentType: 'video/webm; codecs="vp09.00.10.08"',
    width: 1920,
    height: 1080,
    bitrate: 2646242, // number of bits used to encode a second of video
    framerate: '25' // number of frames used in one second
  },
  keySystemConfiguration: {
    keySystem: 'com.widevine.alpha',
    videoRobustness: 'SW_SECURE_DECODE' // Widevine L3
  }
};

navigator.mediaCapabilities.decodingInfo(encryptedMediaConfig).then(result => {
  if (!result.supported) {
    console.log('Argh! This encrypted media configuration is not supported.');
    return;
  }

  if (!result.keySystemAccess) {
    console.log('Argh! Encrypted media support is not available.')
    return;
  }

  console.log('This encrypted media configuration is supported.');
  console.log('Playback should be' +
      (result.smooth ? '' : ' NOT') + ' smooth and' +
      (result.powerEfficient ? '' : ' NOT') + ' power efficient.');

  // TODO: Use `result.keySystemAccess.createMediaKeys()` to setup EME playback.
});

EME 播放具有专用的解码和渲染代码路径,这意味着与清晰播放相比,它支持的编解码器和性能不同。因此,必须在传递给 navigator.mediaCapabilities.decodingInfo() 的媒体配置对象中设置新的 keySystemConfiguration 键。此键的值是一个字典,其中包含多个众所周知的 EME 类型。这会复制向 EME 的 requestMediaKeySystemAccess() 提供的输入,但有一个主要区别:如果序列的 intent 是让 requestMediaKeySystemAccess() 选择它支持的子集,则向 requestMediaKeySystemAccess() 提供的输入序列会扁平化为单个值。

解码信息用于描述对单个音频和视频串流的支持质量(流畅度和功耗效率),而不会为调用方做出决策。调用方仍应像使用 requestMediaKeySystemAccess() 一样对媒体配置进行排序。只是现在,它们会自行遍历列表。

navigator.mediaCapabilities.decodingInfo() 会返回一个 Promise,该 Promise 会异步解析为包含三个布尔值(supportedsmoothpowerEfficient)的对象。不过,设置 keySystemConfiguration 键并将 supported 设为 true 后,系统还会返回另一个名为 keySystemAccessMediaKeySystemAccess 对象。它可用于请求某些媒体密钥并设置加密媒体播放。示例如下:

// Like rMSKA(), orderedMediaConfigs is ordered from most to least wanted.
const capabilitiesPromises = orderedMediaConfigs.map(mediaConfig =>
  navigator.mediaCapabilities.decodingInfo(mediaConfig)
);

// Assume this app wants a supported and smooth media playback.
let bestConfig = null;
for await (const result of capabilitiesPromises) {
  if (result.supported && result.smooth) {
    bestConfig = result;
    break;
  }
}

if (bestConfig) {
  const mediaKeys = await bestConfig.keySystemAccess.createMediaKeys();
  // TODO: rest of EME path as-is
} else {
  // Argh! No smooth configs found.
  // TODO: Maybe choose the lowest resolution and framerate available.
}

请注意,解码加密媒体信息需要使用 HTTPS。

此外,请注意,它可能会以与 requestMediaKeySystemAccess() 相同的方式在 Android 和 ChromeOS 上触发用户提示。不过,尽管需要更多调用来设置加密媒体播放,但它不会显示比 requestMediaKeySystemAccess() 更多的提示。

ALT_TEXT_HERE
受保护内容提示

Intent to Experiment | Chromestatus Tracker | Chromium Bug

HTMLVideoElement.playsInline

Chrome 现在支持 playsInline 布尔值属性。如果存在,则会提示浏览器默认在文档中以“内嵌”方式显示视频,并限制在元素的播放区域内。

Safari 类似,iPhone 上的视频元素在开始播放时不会自动进入全屏模式,但借助此提示,部分嵌入者可以获得自动全屏视频播放体验。Web 开发者可以根据需要使用此 API 来停用此体验。

<video playsinline></video>

由于 Android 版和桌面版 Chrome 未实现自动全屏,因此不会使用 playsInline 视频元素属性提示。

发货意向 | Chromestatus 跟踪器 | Chromium bug