表现就是,相同的视频加载字幕,时间轴是对的,如果做成 HLS 后再播放加载字幕,会发现时间轴对不上(轻微偏移),下面是命令(已经查过网上的一些回复,都测试过了,不行,也许还有没有搜索到的资料)。也直接试过 HLS 的命令也是一样的问题。
ffmpeg.exe -accurate_seek -i .\wawa.mp4 -force_key_frames "expr:gte(t,n_forced*5.000)" -c:v copy -c:a copy -f segment -segment_time 5.000 -segment_list outputlist.m3u8 -segment_format mpegts output%03d.ts
(不打算转码的原因是为了效率,并非是为了体积小,局域网内的应用使用) (目前测试过截取的视频,不转 HLS ,是可以匹配上字幕时间轴的,转了就拉跨)
1
momocraft 2022-10-26 18:31:55 +08:00
用的什么播放器
|
2
mxT52CRuqR6o5 2022-10-26 18:42:55 +08:00
是固定时间的偏移还是会随着时间越来越大的偏移?
|
3
gam2046 2022-10-26 19:27:06 +08:00
hls 转码,又不转码的情况下(你使用了-c:v copy ),并不能严格按照你设置的间隔进行分片,因为 I 帧的缘故,实际分片的长度会增加或减少一定时间,以靠近最近的 I 帧。不太确定是否与这个有关。
|
4
allanpk716 OP @momocraft 在本地转码后,测试了 VLC 以及 5kPlayer
|
5
allanpk716 OP @mxT52CRuqR6o5 我切了 5min 的视频来测试,目测是累加的误差
|
6
allanpk716 OP @gam2046 不使用 `-c:v copy` 进行转码,也会遇到找个问题。
|
7
allanpk716 OP 或者换个思路,怎么能够类似于 Emby Jellyfin 读取本地视频给 Web 播放,并且能够加载字幕的,最好是不太占用计算资源···
|
8
allanpk716 OP 相同转换出来的 HLS 文件,使用 JS 的以下库打开就没得延迟的问题,所以这是本地播放器的梗。
`<script src="https://cdnjs.cloudflare.com/ajax/libs/hls.js/0.14.7/hls.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/dplayer/dist/DPlayer.min.js"></script> <script src="https://cdn.jsdelivr.net/npm/artplayer/dist/artplayer.js"></script> ` |