RESOLVED FIXED 146226
[iOS] MediaControls: Start Play and Can't Play buttons need to be cutout and blurred
https://bugs.webkit.org/show_bug.cgi?id=146226
Summary [iOS] MediaControls: Start Play and Can't Play buttons need to be cutout and ...
Said Abou-Hallawa
Reported 2015-06-22 19:30:55 PDT
The Start Play button needs to blur its background and blend the glyph with the correct color. Same with the Can't Play button.
Attachments
Patch (6.67 KB, patch)
2015-06-22 19:47 PDT, Said Abou-Hallawa
no flags
ios-simulator-screen-shot (deleted)
2015-06-22 20:05 PDT, Said Abou-Hallawa
no flags
Patch (6.67 KB, patch)
2015-06-23 08:21 PDT, Said Abou-Hallawa
darin: review+
iso-simulator-screen-shot-without-backdrop-filter (deleted)
2015-06-23 13:53 PDT, Said Abou-Hallawa
no flags
Patch (7.06 KB, patch)
2015-07-02 14:59 PDT, Said Abou-Hallawa
no flags
Patch (12.59 KB, patch)
2015-07-07 17:47 PDT, Dean Jackson
simon.fraser: review+
Said Abou-Hallawa
Comment 1 2015-06-22 19:47:42 PDT
Said Abou-Hallawa
Comment 2 2015-06-22 20:05:07 PDT
Created attachment 255392 [details] ios-simulator-screen-shot
Jon Lee
Comment 3 2015-06-22 23:07:46 PDT
Comment on attachment 255390 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=255390&action=review > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:245 > +video::-webkit-media-controls-start-playback-button:active video::-webkit-media-controls-start-playback-glyph missing comma > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:250 > +video::-webkit-media-controls-start-playback-button.failed video::-webkit-media-controls-start-playback-glyph missing comma
Said Abou-Hallawa
Comment 4 2015-06-23 08:21:27 PDT
Said Abou-Hallawa
Comment 5 2015-06-23 09:22:23 PDT
I think the size of the playback button on iOS (72x72) is really big (see the screenshot). Also the size of the button is fixed but I think its size should be scaled down if the video/audio element is small. This patch changes the style of the button and I am not sure if I should change the size as well or not.
Darin Adler
Comment 6 2015-06-23 10:35:44 PDT
Comment on attachment 255412 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=255412&action=review > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:203 > + left: -webkit-calc(50% - 36px); > + top: -webkit-calc(50% - 36px); What’s the significance of moving from calc to webkit-calc? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:204 > + -webkit-transform: translate3d(0, 0, 0); Is this really needed? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:216 > + -webkit-transform: translate3d(0, 0, 0); Is this really needed? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:226 > + -webkit-transform: translate3d(0, 0, 0); Is this really needed? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:238 > + background-image: url('data:image/svg+xml,<svg viewBox="0 0 144 144" xmlns="http://www.w3.org/2000/svg"><path d="M48,36v74L109,74z" fill="black"/></svg>'); This is 60x60; why is the SVG 144x144? Is there a way to avoid the xmlns here? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:242 > + -webkit-transform: translate3d(0, 0, 0); Is this really needed?
Said Abou-Hallawa
Comment 7 2015-06-23 13:53:22 PDT
Created attachment 255429 [details] iso-simulator-screen-shot-without-backdrop-filter
David Kilzer (:ddkilzer)
Comment 8 2015-06-23 17:05:58 PDT
The content of attachment 255392 [details] has been deleted by David Kilzer (:ddkilzer) <ddkilzer@webkit.org> without providing any reason. The token used to delete this attachment was generated at 2015-06-23 17:05:53 PDT.
David Kilzer (:ddkilzer)
Comment 9 2015-06-23 17:06:09 PDT
The content of attachment 255429 [details] has been deleted by David Kilzer (:ddkilzer) <ddkilzer@webkit.org> without providing any reason. The token used to delete this attachment was generated at 2015-06-23 17:06:07 PDT.
Said Abou-Hallawa
Comment 10 2015-07-01 15:02:10 PDT
Comment on attachment 255412 [details] Patch Working on a work-around fix since the back-drop filter causes the image to be displayed blurred.
Said Abou-Hallawa
Comment 11 2015-07-02 14:59:07 PDT
Said Abou-Hallawa
Comment 12 2015-07-02 15:11:23 PDT
This patch is the best I can do right now. The glyph of the can't play button is not draw correctly. I am using the clip-path to draw the glyph of the button. The polygon() function does not allow three separate areas to be drawn without connecting them: https://bugs.webkit.org/show_bug.cgi?id=146539. If I draw the glyph using css or an image, either a bitmap or an SVG, the backdrop-filter makes the edges of the image blurred. The css selectors also do not work correctly for the failure case. Also I could not figure out how I get the video to fail loading such that the class ".failed" is added to the play button and the can't play picture is drawn. <rdar://problem/21656127> <rdar://problem/21655685> <rdar://problem/21656923>
Dean Jackson
Comment 13 2015-07-07 17:47:27 PDT
Said Abou-Hallawa
Comment 14 2015-07-07 18:05:59 PDT
Comment on attachment 256339 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=256339&action=review > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:-194 > -audio::-webkit-media-controls-start-playback-button { why are we getting rid of the audio media control support? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:229 > + background-image: url(''); Can't we use SVG instead? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:245 > +*/ Why are we leaving this? Also having ...-button ...-background.active is confusing to me since the state should be associated with the button; not the background nor the glyph. Or is this just a workaround till we get the right fix and have ...-button.active ...-background ...-button.active ...-glyph ...-button.failed ...-background ...-button.failed ...-glyph > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:254 > + background-image: url(''); Can't we use SVG instead? > Source/WebCore/Modules/mediacontrols/mediaControlsiOS.js:473 > + this.controls.startPlaybackButton.querySelector('.webkit-media-controls-start-playback-background').classList.add('active'); Is this part of the workaround?
Dean Jackson
Comment 15 2015-07-07 18:34:25 PDT
Comment on attachment 256339 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=256339&action=review >> Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:-194 >> -audio::-webkit-media-controls-start-playback-button { > > why are we getting rid of the audio media control support? Because audio elements don't have the start-play button. They are always inline. (technically the developer could use an <audio> and point to a video stream, but that's their problem) >> Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:229 >> + background-image: url(''); > > Can't we use SVG instead? I only have the source artwork in PNG. And we've decided for this cycle to just use the artwork we're given, even though they could all be SVG. >> Source/WebCore/Modules/mediacontrols/mediaControlsiOS.css:245 >> +*/ > > Why are we leaving this? > Also having > ...-button ...-background.active > is confusing to me since the state should be associated with the button; not the background nor the glyph. Or is this just a workaround till we get the right fix and have > ...-button.active ...-background > ...-button.active ...-glyph > ...-button.failed ...-background > ...-button.failed ...-glyph Yes, I'll remove that commented code. And yes, the confusing .active thing is to work around the bugs you mentioned. I tried selectors that were more correct, but they didn't work :( >> Source/WebCore/Modules/mediacontrols/mediaControlsiOS.js:473 >> + this.controls.startPlaybackButton.querySelector('.webkit-media-controls-start-playback-background').classList.add('active'); > > Is this part of the workaround? Yes.
Dean Jackson
Comment 16 2015-07-07 19:21:31 PDT
Note You need to log in before you can comment on or make changes to this bug.