 Chromium Code Reviews
 Chromium Code Reviews Issue 1839973003:
  If the <use> is hidden and the child of it is visible, should clip the non-resource  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master
    
  
    Issue 1839973003:
  If the <use> is hidden and the child of it is visible, should clip the non-resource  (Closed) 
  Base URL: https://chromium.googlesource.com/chromium/src.git@master| Index: third_party/WebKit/Source/core/layout/svg/LayoutSVGResourceClipper.cpp | 
| diff --git a/third_party/WebKit/Source/core/layout/svg/LayoutSVGResourceClipper.cpp b/third_party/WebKit/Source/core/layout/svg/LayoutSVGResourceClipper.cpp | 
| index 01734e2a85d7ed7c39ebf1c170a2c1dcbaf86fc0..1e27d08fbefd91fc30387b75a55db3877c385e53 100644 | 
| --- a/third_party/WebKit/Source/core/layout/svg/LayoutSVGResourceClipper.cpp | 
| +++ b/third_party/WebKit/Source/core/layout/svg/LayoutSVGResourceClipper.cpp | 
| @@ -86,7 +86,7 @@ bool LayoutSVGResourceClipper::calculateClipContentPathIfNeeded() | 
| continue; | 
| const ComputedStyle* style = childLayoutObject->style(); | 
| - if (!style || style->display() == NONE || style->visibility() != VISIBLE) | 
| + if (!style || style->display() == NONE || (style->visibility() != VISIBLE && !isSVGUseElement(*childElement))) | 
| continue; | 
| // Current shape in clip-path gets clipped too. Fallback to masking. | 
| @@ -177,12 +177,12 @@ PassRefPtr<const SkPicture> LayoutSVGResourceClipper::createContentPicture() | 
| continue; | 
| const ComputedStyle* style = layoutObject->style(); | 
| - if (!style || style->display() == NONE || style->visibility() != VISIBLE) | 
| + if (!style || style->display() == NONE || (style->visibility() != VISIBLE && !isSVGUseElement(*childElement))) | 
| continue; | 
| bool isUseElement = isSVGUseElement(*childElement); | 
| if (isUseElement) { | 
| - const SVGGraphicsElement* clippingElement = toSVGUseElement(*childElement).targetGraphicsElementForClipping(); | 
| + const SVGGraphicsElement* clippingElement = toSVGUseElement(*childElement).visibleTargetGraphicsElementForClipping(); | 
| if (!clippingElement) | 
| continue; | 
| @@ -221,8 +221,11 @@ void LayoutSVGResourceClipper::calculateClipContentPaintInvalidationRect() | 
| if (!layoutObject->isSVGShape() && !layoutObject->isSVGText() && !isSVGUseElement(*childElement)) | 
| continue; | 
| const ComputedStyle* style = layoutObject->style(); | 
| - if (!style || style->display() == NONE || style->visibility() != VISIBLE) | 
| + if (!style || style->display() == NONE || (style->visibility() != VISIBLE && !isSVGUseElement(*childElement))) | 
| continue; | 
| + if (isSVGUseElement(childElement) && !toSVGUseElement(*childElement).visibleTargetGraphicsElementForClipping()) | 
| 
fs
2016/04/27 14:14:39
*childElement
 
hyunjunekim2
2016/04/29 12:59:09
Done.
 | 
| + continue; | 
| + | 
| m_clipBoundaries.unite(layoutObject->localToSVGParentTransform().mapRect(layoutObject->paintInvalidationRectInLocalSVGCoordinates())); | 
| } | 
| m_clipBoundaries = toSVGClipPathElement(element())->calculateAnimatedLocalTransform().mapRect(m_clipBoundaries); |