2

YouTube iFrame API 的字幕功能不适用于自动生成的字幕。

是否有解决此缺陷的计划,或者是否有其他方法可以在 iFrame API 中启用自动生成的字幕?

4

2 回答 2

0

一如既往,有办法。

没有官方或记录在案的方法可以强制嵌入视频中的自动生成字幕。但是,有一个 setOption 方法的解决方案现在可以使用,但不能保证它将来会起作用,因为这是该方法的未记录调用:

const tag = document.createElement('script')
tag.src = 'https://www.youtube.com/iframe_api'
const firstScriptTag = document.getElementsByTagName('script')[0]
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag)

let player

const onApiChange = _ => {   
  if (typeof player.setOption === 'function') {
    player.setOption('captions', 'track', {languageCode: 'en'})
  }  
}

const onReady = _ => {   
  player.playVideo()
}

function onYouTubePlayerAPIReady() {
  player = new YT.Player('player', {
    height: '360',
    width: '640',
    videoId: 'q2C0EO0zzAY',
    playerVars: {
      cc_load_policy: 1
    },
    events: {
      onReady,
      onApiChange
    }
  })
}

工作jsFiddle 在这里

在使用 setOption 函数之前,您必须等待 onApiChange 事件。(参见:https ://developers.google.com/youtube/iframe_api_reference#Events )根据文档,仅支持“fontSize”和“reload”参数。但是,更改字幕轨道也有效,它会打开字幕作为副作用。我只尝试了“en”语言代码,当然,如果有可用的,这将更改为正常的英文字幕轨道,但在没有预定义轨道的情况下会显示自动生成的英文字幕。

(您也可以使用 getOption 方法查询活动字幕轨道,但如果使用自动生成的字幕,它将不会返回任何内容。)

于 2020-03-25T06:22:48.520 回答
-1

我也有同样的需求 - 越来越多的视频使用 Auto cptions 发布,如果 iframe 也能支持它们会很好

于 2017-03-24T17:43:22.283 回答