Bug 147745

Summary: Media Session: notify focus manager clients when the playing state of the focused media element changes
Product: WebKit Reporter: Matt Rajca <mrajca>
Component: MediaAssignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: conrad_shultz, eric.carlson, mrajca, webkit-bug-importer
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: All   
OS: All   
Bug Depends on:    
Bug Blocks: 145411    
Attachments:
Description Flags
Patch
none
Patch
none
Patch
none
Patch
none
Patch thorton: review+

Matt Rajca
Reported 2015-08-06 14:06:41 PDT
Clients that display lock screen UIs should be able to change their play button to a pause button (and vice versa) when the 'playing' state of the focused Content media element changes.
Attachments
Patch (15.71 KB, patch)
2015-08-06 14:25 PDT, Matt Rajca
no flags
Patch (16.03 KB, patch)
2015-08-06 16:20 PDT, Matt Rajca
no flags
Patch (16.04 KB, patch)
2015-08-06 16:32 PDT, Matt Rajca
no flags
Patch (16.11 KB, patch)
2015-08-06 16:37 PDT, Matt Rajca
no flags
Patch (16.06 KB, patch)
2015-08-06 16:45 PDT, Matt Rajca
thorton: review+
Matt Rajca
Comment 1 2015-08-06 14:25:28 PDT
Eric Carlson
Comment 2 2015-08-06 14:40:50 PDT
Comment on attachment 258396 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=258396&action=review > Source/WebKit2/UIProcess/API/C/WKMediaSessionFocusManager.h:40 > +typedef void (*WKMediaSessionFocusManagerDidChangePlayingState)(WKMediaSessionFocusManagerRef manager, bool isPaused, const void *clientInfo); Will this ever have to handle more than play/pause state changes? If so, I recommend changing the names to PlaybackState instead of PlayingState and passing flags instead of a bool.
Matt Rajca
Comment 3 2015-08-06 15:25:20 PDT
(In reply to comment #2) > Comment on attachment 258396 [details] > Patch > > View in context: > https://bugs.webkit.org/attachment.cgi?id=258396&action=review > > > Source/WebKit2/UIProcess/API/C/WKMediaSessionFocusManager.h:40 > > +typedef void (*WKMediaSessionFocusManagerDidChangePlayingState)(WKMediaSessionFocusManagerRef manager, bool isPaused, const void *clientInfo); > > Will this ever have to handle more than play/pause state changes? If so, I > recommend changing the names to PlaybackState instead of PlayingState and > passing flags instead of a bool. Good idea. In the future, we'll also need to notify clients whenever the previous/next track controls should be enabled/disabled. I'll generalize this code path so we can use it for said events.
Matt Rajca
Comment 4 2015-08-06 16:20:28 PDT
Matt Rajca
Comment 5 2015-08-06 16:32:14 PDT
Matt Rajca
Comment 6 2015-08-06 16:37:53 PDT
Matt Rajca
Comment 7 2015-08-06 16:45:14 PDT
Matt Rajca
Comment 8 2015-08-06 17:01:42 PDT
Note You need to log in before you can comment on or make changes to this bug.