Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

使用hls.js播放hls时,视频出现了花屏 #6515

Closed
5 tasks done
xht opened this issue Jun 19, 2024 · 19 comments · Fixed by #6617
Closed
5 tasks done

使用hls.js播放hls时,视频出现了花屏 #6515

xht opened this issue Jun 19, 2024 · 19 comments · Fixed by #6617
Labels
Bug Confirmed Bug report confirmed or reproduced. Stream Issue Transport Stream
Milestone

Comments

@xht
Copy link

xht commented Jun 19, 2024

What version of Hls.js are you using?

v1.5.11

What browser (including version) are you using?

Microsoft Edge(125.0.2535.92)

What OS (including version) are you using?

windows10

Test stream

No response

Configuration

{
  "debug": true,
  "enableWorker": true,
  "lowLatencyMode": true,
  "backBufferLength": 90
}

Additional player setup steps

No response

Checklist

Steps to reproduce

  1. 输入http://127.0.0.1:8000/record/Center1@1@文件1/_20240619/test/index.m3u8
    2.点击Apply。
  2. 播放出来的视频是花屏
  3. 可以提供m3u8相关的视频文件,联系方式: 592294266@qq.com

Expected behaviour

能正常解决解码视频

What actually happened?

不太清楚,用ffplay播放m3u8能正常播放

Console output

317.419 | Media element detached
317.422 | Loading http://127.0.0.1:8000/record/Center1@1@文件1/_20240619/test/index.m3u8
317.424 | Loading manifest and attaching video element...
317.428 | Media element attached
317.454 | 1 quality levels found
317.455 | Manifest successfully loaded

Chrome media internals output

No response

@xht xht added Bug Needs Triage If there is a suspected stream issue, apply this label to triage if it is something we should fix. labels Jun 19, 2024
@robwalch robwalch added Need sample stream cannot reproduce and removed Needs Triage If there is a suspected stream issue, apply this label to triage if it is something we should fix. labels Jun 22, 2024
@robwalch
Copy link
Collaborator

可以提供m3u8相关的视频文件,联系方式: 592294266@qq.com

We will not reach out via email or messaging app to follow up.

You can connect with us on Video-Dev Slack in the #hlsjs channel to share samples:
https://www.video-dev.org/

@xht
Copy link
Author

xht commented Jun 23, 2024

收到,已经发到了Video-Dev Slack

@robwalch
Copy link
Collaborator

robwalch commented Jun 24, 2024

Looks like an issue transcoding the Transport Stream segments.

https://github.com/video-dev/hls.js/blob/v1.5.11/src/demux/tsdemuxer.ts

@xht
Copy link
Author

xht commented Jun 24, 2024

那这个需要怎么修改喽

@robwalch
Copy link
Collaborator

It may be related to deficiencies found in NAL Unit overflow parsing. We had to rollback a change that introduced regressions in #6492.

@xht
Copy link
Author

xht commented Jun 24, 2024

刚才我测试了一下其它版本,hls.js-1.4.5和hls.js-1.5.8也有该现象

@xht
Copy link
Author

xht commented Jun 24, 2024

这个有没有方法把ts解析出的264,保存成文件不。这样可以进一步确认解析的264是不是正常

@robwalch
Copy link
Collaborator

这个有没有方法把ts解析出的264,保存成文件不。这样可以进一步确认解析的264是不是正常
Is there any way to save the 264 parsed by ts into a file? This can further confirm whether the parsed 264 is normal.

On the HLS.js demo page, check "Dump transmuxed fMP4 data", then click "Create video-fmp4" under "Playback" controls. All appended segments are concatenated into a single byte array.

@xht
Copy link
Author

xht commented Jun 27, 2024

您好,这个问题有进展了没,我尝试修改了部分代码,按照上面的方法下载了fmp4,用vlc播放,已经不花屏了。但网页上还是花屏。

@robwalch
Copy link
Collaborator

robwalch commented Aug 5, 2024

@xht I've found the root cause to be unexpected AVC NAL Access unit delimiters between the SPS, PPS and frame units. A fix has been pushed to #6617 (test link https://bugfix-avc-nal-aud-samples.hls-js-4zn.pages.dev/demo/).

@xht
Copy link
Author

xht commented Aug 6, 2024

意思是,SPS PPS I这之间当成一帧,只需要1个aud,是这个意思不?

@xht
Copy link
Author

xht commented Aug 6, 2024

刚才测试了一下v1.5.14这个版本,还是花屏。
https://bugfix-avc-nal-aud-samples.hls-js-4zn.pages.dev/demo/这个版本可以

@robwalch
Copy link
Collaborator

robwalch commented Aug 6, 2024

The fix will be released in v1.6. Version 1.5 will not get a patch with this change.

@xht
Copy link
Author

xht commented Aug 6, 2024

I've found the root cause to be unexpected AVC NAL Access unit delimiters between the SPS, PPS and frame units
意思是,SPS PPS I这之间当成一帧,只需要1个aud,是这个意思不?

@robwalch
Copy link
Collaborator

robwalch commented Aug 6, 2024

The NAL units comprising the first frame of the asset that produces this issue (mapped using VideoSample.units.map(u => ({1: 'NDR', 5: 'IDR', 6: 'SEI', 7: 'SPS', 8: 'PPS', 9: 'AUD', 12: 'filler', })[u.type]||u.type).join(',') at a debugger break point in parsePES > pushAccessUnit after changes in #6617):

  • 'AUD,SPS,AUD,PPS,AUD,SPS,AUD,PPS,AUD,IDR'

Typical first frame of TS video (SEI is not required):

  • 'AUD,SPS,PPS,SEI,IDR'

Prior to #6617 the TSDemuxer would only have pushed the data in the last 'AUD,IDR' units into the tranmuxed mp4 mdat. The earlier data was not after encountering unexpected AUD NAL units.

@xht
Copy link
Author

xht commented Aug 6, 2024

明白了,谢谢

@xht
Copy link
Author

xht commented Jan 10, 2025

这个版本是什么时候发布喽

@robwalch
Copy link
Collaborator

robwalch commented Jan 10, 2025

这个版本是什么时候发布喽
(Google translate) When is this version released?

Click the 1.6.0 Milestone link for additional information including the release due date. There is a beta pre-release available now https://github.com/video-dev/hls.js/releases/tag/v1.6.0-beta.2

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Bug Confirmed Bug report confirmed or reproduced. Stream Issue Transport Stream
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants