https://bugs.webkit.org/show_bug.cgi?id=156383
<rdar://problem/
23540816>
Reviewed by Simon Fraser.
.:
Add a manual test for iOS that shows the expected appearance
of a video element. Unfortunately, due to the way we take
snapshots on iOS within our test runner, we don't get the
platform blurring effect, which means an automated test
won't work.
* ManualTests/ios/start-playback-button-appearance-expected.html: Added.
* ManualTests/ios/start-playback-button-appearance.html: Added.
Source/WebKit2:
Elements that are backed by a layer with either LightBackdropAppearance
or DarkBackdropAppearance are actually a combination of a
few layers (inside a special view). If we apply a mask to one
of those layers, it needs to be attached to the correct
child layer.
* Shared/mac/RemoteLayerTreePropertyApplier.mm:
(WebKit::RemoteLayerTreePropertyApplier::applyProperties): If we have
one of the special appearance flags, apply the mask layer to
a particular child, rather than the layer itself.
git-svn-id: https://svn.webkit.org/repository/webkit/trunk@199212
268f45cc-cd09-0410-ab3c-
d52691b4dbfc
+2016-04-07 Dean Jackson <dino@apple.com>
+
+ [iOS] Play button on video is too dark
+ https://bugs.webkit.org/show_bug.cgi?id=156383
+ <rdar://problem/23540816>
+
+ Reviewed by Simon Fraser.
+
+ Add a manual test for iOS that shows the expected appearance
+ of a video element. Unfortunately, due to the way we take
+ snapshots on iOS within our test runner, we don't get the
+ platform blurring effect, which means an automated test
+ won't work.
+
+ * ManualTests/ios/start-playback-button-appearance-expected.html: Added.
+ * ManualTests/ios/start-playback-button-appearance.html: Added.
+
2016-04-06 Alex Christensen <achristensen@webkit.org>
Fix CMake DumpRenderTree
--- /dev/null
+<meta name="viewport" content="width=device-width,initial-scale=1">
+<style>
+div {
+ width: 250px;
+ height: 200px;
+ position: relative;
+}
+
+.a {
+ background-color: #895;
+}
+
+.b {
+ background-color: #55f;
+}
+
+.button {
+ position: absolute;
+ width: 72px;
+ height: 72px;
+ left: calc(50% - 36px);
+ top: calc(50% - 36px);
+}
+
+.background {
+ position: absolute;
+ width: 72px;
+ height: 72px;
+ -webkit-clip-path: circle(36px);
+}
+
+.a .background {
+ background-color: rgb(159, 181, 85);
+}
+
+.b .background {
+ background-color: rgb(113, 113, 255);
+}
+
+.glyph {
+ -webkit-appearance: none;
+ position: absolute;
+ width: 72px;
+ height: 72px;
+ opacity: 0.6;
+ background-image: url('');
+ background-repeat: no-repeat;
+ background-position: 50% 50%;
+ background-size: 100% 100%;
+}
+
+
+</style>
+
+<div class="a">
+ <div class="button">
+ <div class="background"></div>
+ <div class="glyph"></div>
+ </div>
+</div>
+
+<div class="b">
+ <div class="button">
+ <div class="background"></div>
+ <div class="glyph"></div>
+ </div>
+</div>
--- /dev/null
+<meta name="viewport" content="width=device-width,initial-scale=1">
+<style>
+video {
+ width: 250px;
+ height: 200px;
+ background-color: rgb(136, 153, 85);
+ display: block;
+}
+
+video:nth-of-type(2) {
+ background-color: rgb(85, 85, 255);
+}
+</style>
+<script>
+if (window.testRunner) {
+ window.testRunner.waitUntilDone();
+
+ window.addEventListener("load", function () {
+ setTimeout(function () {
+ window.testRunner.notifyDone();
+ }, 3000);
+ }, false);
+}
+
+</script>
+
+<video controls src="content/counting.mp4"></video>
+<video controls src="content/counting.mp4"></video>
+2016-04-07 Dean Jackson <dino@apple.com>
+
+ [iOS] Play button on video is too dark
+ https://bugs.webkit.org/show_bug.cgi?id=156383
+ <rdar://problem/23540816>
+
+ Reviewed by Simon Fraser.
+
+ Elements that are backed by a layer with either LightBackdropAppearance
+ or DarkBackdropAppearance are actually a combination of a
+ few layers (inside a special view). If we apply a mask to one
+ of those layers, it needs to be attached to the correct
+ child layer.
+
+ * Shared/mac/RemoteLayerTreePropertyApplier.mm:
+ (WebKit::RemoteLayerTreePropertyApplier::applyProperties): If we have
+ one of the special appearance flags, apply the mask layer to
+ a particular child, rather than the layer itself.
+
2016-04-07 Jeremy Jones <jeremyj@apple.com>
Clearing the application cache doesn't work.
}
if (properties.changedProperties & RemoteLayerTreeTransaction::MaskLayerChanged) {
+
+ CALayer *maskOwnerLayer = view.layer;
+
+ if (properties.customAppearance == GraphicsLayer::LightBackdropAppearance || properties.customAppearance == GraphicsLayer::DarkBackdropAppearance) {
+ // This is a UIBackdropView, which means any mask must be applied to the CABackdropLayer rather
+ // that the view's layer. The backdrop is the first layer child.
+ if (view.layer.sublayers.count && [view.layer.sublayers[0] isKindOfClass:[CABackdropLayer class]])
+ maskOwnerLayer = view.layer.sublayers[0];
+ }
+
if (!properties.maskLayerID)
- view.layer.mask = nullptr;
+ maskOwnerLayer.mask = nullptr;
else {
UIView *maskView = relatedLayers.get(properties.maskLayerID);
// FIXME: need to check that the mask view is kept alive.
ASSERT(!maskView.layer.superlayer);
if (!maskView.layer.superlayer)
- view.layer.mask = maskView.layer;
+ maskOwnerLayer.mask = maskView.layer;
}
}
END_BLOCK_OBJC_EXCEPTIONS;