支持在Flutter视频播放器中同步SRT/VTT字幕

3

我希望在我的应用程序中播放srt字幕。到目前为止,我已经整合了srt_parser。 同时,我可以通过以下代码获取播放器的当前位置。

  inMilliseconds = _videoPlayerController.value.position.inMilliseconds;

这是srt解析代码。

  String data = '''1
  00:00:01,600 --> 00:00:04,200
  English (US)

  2
  00:00:05,900 --> 00:00:07,999
  This is a subtitle in American English

  3
  00:00:10,000 --> 00:00:14,000
  Adding subtitles is very easy to do''';

  srtParser() {
  List<Subtitle> subtitles = parseSrt(data);
  for (Subtitle item in subtitles) {
  print(
      'inMilliseconds ${inMilliseconds}  Begin is: ${item.range.begin} and End is: 
  ${item.range.end}');
  if (inMilliseconds > item.range.begin &&
      inMilliseconds < item.range.end) {
    for (var line in item.parsedLines) {
      for (var subLine in line.subLines) {
        print(
            'myline${item.parsedLines.indexOf(line)} subline${line.subLines.indexOf(subLine)} is: ${subLine.rawString}');
        setState(() {
          videoSubtitle =
              '${item.parsedLines.indexOf(line)} ${line.subLines.indexOf(subLine)} ${subLine.rawString}';
        });
      }
    }
  } else {
    setState(() {
      videoSubtitle = null;
    });
  }
}
if (subtitles[0].parsedLines[0].subLines[1].htmlCode.b == true) {
  print('true');
}

如何将字幕与视频播放器位置同步?

目前,我正在解析SRT字符串。如何从SRT文件中解析它?


添加更多的标签,以便问题能够被更广泛的观众看到。 - Standin.Wolf
作为一种解决方法,我现在使用 https://pub.dev/packages/mx_player_plugin。它将视频 URL 和 srt URL 作为参数,并使用 MX 播放器播放视频。 - Ravinder Kumar
1个回答

5

我目前正在使用subtitle_wrapper_package

它支持在视频播放器中使用vtt字幕。

SubTitleWrapper(
  videoPlayerController: chewieController.videoPlayerController,
  subtitleController: SubtitleController(
    subtitleUrl: subtitleUrl,
    showSubtitles: true,
  ),
  subtitleStyle:
      SubtitleStyle(textColor: Colors.white, hasBorder: true),
  videoChild: Chewie(
    controller: chewieController,
  )),

输出:

这里输入图片描述


(此内容为HTML格式,已翻译)

有没有对缓冲视频的管理?如果视频正在播放,用户通过触摸设置了先前的时间,它不会保存缓冲视频,而是重新开始。 - Pankaj Bansal

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接