Bug 227047

Summary: [iOS] Fullscreen video playback gets stuck after interacting with the playback controls
Product: WebKit Reporter: Peng Liu <peng.liu6>
Component: MediaAssignee: Peng Liu <peng.liu6>
Status: RESOLVED FIXED    
Severity: Normal CC: eric.carlson, ews-watchlist, glenn, hi, jer.noble, philipj, sergio, webkit-bug-importer
Priority: P2 Keywords: InRadar
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=227106
Bug Depends on:    
Bug Blocks: 227106    
Attachments:
Description Flags
Patch
none
Patch
none
Fix build failures on macOS
eric.carlson: review+
Revise the patch based on Devin and Eric's comments none

Peng Liu
Reported 2021-06-15 14:37:54 PDT
[iOS] Fullscreen video playback gets stuck after interacting with the playback controls
Attachments
Patch (37.67 KB, patch)
2021-06-15 15:19 PDT, Peng Liu
no flags
Patch (37.66 KB, patch)
2021-06-15 15:24 PDT, Peng Liu
no flags
Fix build failures on macOS (38.85 KB, patch)
2021-06-15 16:31 PDT, Peng Liu
eric.carlson: review+
Revise the patch based on Devin and Eric's comments (42.34 KB, patch)
2021-06-17 15:11 PDT, Peng Liu
no flags
Peng Liu
Comment 1 2021-06-15 14:38:45 PDT
Peng Liu
Comment 2 2021-06-15 15:19:37 PDT
Peng Liu
Comment 3 2021-06-15 15:24:38 PDT
Devin Rousso
Comment 4 2021-06-15 15:50:45 PDT
Comment on attachment 431486 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=431486&action=review > Source/WebCore/platform/cocoa/PlaybackSessionModel.h:105 > + virtual void rateChanged(bool /* isPlaying */, bool /* isStalled */, double /* playbackRate */, double /* defaultPlaybackRate */) { } Could we maybe have an `OptionSet` of enum flags? > Source/WebCore/platform/cocoa/PlaybackSessionModelMediaElement.mm:-55 > -static const float StalledPlaybackRate = 0.00000001f; Do we still need to report this value (or something like it) to AVKit? Or will AVKit be fine with a playback rate of 1 (or 2 or 0.5 or whatever) when we're still loading? > Source/WebCore/platform/ios/PlaybackSessionInterfaceAVKit.mm:130 > + if (!isStalled) I wonder if instead of not modifying `m_playerController` we should instead have a `stalled` property on `WebAVPlayerController` and have `setRate:` ignore/defer modifications if `stalled`. This way, if AVKit calls `setRate:` then we will wait to update the rate until we're no longer stalled (e.g. inside `setStalled:` you could send the `rate` back to the `model`). Though I think all of this assumes my comment on PlaybackSessionModelMediaElement.mm:55 is accurate.
Peng Liu
Comment 5 2021-06-15 16:31:05 PDT
Created attachment 431494 [details] Fix build failures on macOS
Peng Liu
Comment 6 2021-06-16 15:15:52 PDT
Comment on attachment 431486 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=431486&action=review >> Source/WebCore/platform/cocoa/PlaybackSessionModel.h:105 >> + virtual void rateChanged(bool /* isPlaying */, bool /* isStalled */, double /* playbackRate */, double /* defaultPlaybackRate */) { } > > Could we maybe have an `OptionSet` of enum flags? Yes. Like an `OptionSet` of ``` enum class PlaybackState { Playing = 1 << 0, Stalled = 1 << 1, }; ``` >> Source/WebCore/platform/cocoa/PlaybackSessionModelMediaElement.mm:-55 >> -static const float StalledPlaybackRate = 0.00000001f; > > Do we still need to report this value (or something like it) to AVKit? Or will AVKit be fine with a playback rate of 1 (or 2 or 0.5 or whatever) when we're still loading? With this patch, I cannot reproduce bug 211797. So looks like AVKit does not need this value anymore. >> Source/WebCore/platform/ios/PlaybackSessionInterfaceAVKit.mm:130 >> + if (!isStalled) > > I wonder if instead of not modifying `m_playerController` we should instead have a `stalled` property on `WebAVPlayerController` and have `setRate:` ignore/defer modifications if `stalled`. This way, if AVKit calls `setRate:` then we will wait to update the rate until we're no longer stalled (e.g. inside `setStalled:` you could send the `rate` back to the `model`). Though I think all of this assumes my comment on PlaybackSessionModelMediaElement.mm:55 is accurate. Hmm, this approach sounds safer. However, if `m_playerController` does not report the rate back to the WebContent process when its `stalled` property is YES, its rate might be overwritten by a value comes from the WebContent process. That could happen when a user changes playback rate in fullscreen immediately after scrubbing the video.
Eric Carlson
Comment 7 2021-06-17 07:44:10 PDT
Comment on attachment 431494 [details] Fix build failures on macOS View in context: https://bugs.webkit.org/attachment.cgi?id=431494&action=review > Source/WebCore/platform/cocoa/PlaybackSessionModel.h:105 > + virtual void rateChanged(bool /* isPlaying */, bool /* isStalled */, double /* playbackRate */, double /* defaultPlaybackRate */) { } I agree that an enums and an OptionSet would be nicer than bools
Peng Liu
Comment 8 2021-06-17 15:11:36 PDT
Created attachment 431727 [details] Revise the patch based on Devin and Eric's comments
EWS
Comment 9 2021-06-18 12:15:48 PDT
Committed r279043 (238963@main): <https://commits.webkit.org/238963@main> All reviewed patches have been landed. Closing bug and clearing flags on attachment 431727 [details].
Peng Liu
Comment 10 2021-06-21 15:35:58 PDT
*** Bug 227106 has been marked as a duplicate of this bug. ***
Note You need to log in before you can comment on or make changes to this bug.