OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) | 2 * Copyright (C) 1999 Lars Knoll (knoll@kde.org) |
3 * (C) 1999 Antti Koivisto (koivisto@kde.org) | 3 * (C) 1999 Antti Koivisto (koivisto@kde.org) |
4 * (C) 2007 David Smith (catfish.man@gmail.com) | 4 * (C) 2007 David Smith (catfish.man@gmail.com) |
5 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. | 5 * Copyright (C) 2003, 2004, 2005, 2006, 2007, 2008, 2009, 2010, 2011 Apple Inc. All rights reserved. |
6 * Copyright (C) Research In Motion Limited 2010. All rights reserved. | 6 * Copyright (C) Research In Motion Limited 2010. All rights reserved. |
7 * | 7 * |
8 * This library is free software; you can redistribute it and/or | 8 * This library is free software; you can redistribute it and/or |
9 * modify it under the terms of the GNU Library General Public | 9 * modify it under the terms of the GNU Library General Public |
10 * License as published by the Free Software Foundation; either | 10 * License as published by the Free Software Foundation; either |
(...skipping 2747 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2758 | 2758 |
2759 if ((hitTestAction == HitTestBlockBackground || hitTestAction == HitTestChil dBlockBackground) | 2759 if ((hitTestAction == HitTestBlockBackground || hitTestAction == HitTestChil dBlockBackground) |
2760 && visibleToHitTestRequest(request) | 2760 && visibleToHitTestRequest(request) |
2761 && isPointInOverflowControl(result, locationInContainer.point(), adjuste dLocation)) { | 2761 && isPointInOverflowControl(result, locationInContainer.point(), adjuste dLocation)) { |
2762 updateHitTestResult(result, locationInContainer.point() - localOffset); | 2762 updateHitTestResult(result, locationInContainer.point() - localOffset); |
2763 // FIXME: isPointInOverflowControl() doesn't handle rect-based tests yet . | 2763 // FIXME: isPointInOverflowControl() doesn't handle rect-based tests yet . |
2764 if (!result.addNodeToRectBasedTestResult(nodeForHitTest(), request, loca tionInContainer)) | 2764 if (!result.addNodeToRectBasedTestResult(nodeForHitTest(), request, loca tionInContainer)) |
2765 return true; | 2765 return true; |
2766 } | 2766 } |
2767 | 2767 |
2768 if (style()->clipPath()) { | |
2769 // FIXME: handle REFERENCE | |
krit
2014/04/16 18:51:08
I would do a switch here to make sure you cover al
| |
2770 if (style()->clipPath()->type() == ClipPathOperation::SHAPE) { | |
2771 ShapeClipPathOperation* clipPath = toShapeClipPathOperation(style()- >clipPath()); | |
2772 // FIXME: handle marginBox etc. | |
2773 if (!clipPath->path(borderBoxRect()).contains(locationInContainer.po int() - localOffset, clipPath->windRule())) | |
krit
2014/04/16 18:51:08
Not sure if that is a win here. What about checkin
| |
2774 return false; | |
2775 } | |
2776 } | |
2777 | |
2768 // If we have clipping, then we can't have any spillout. | 2778 // If we have clipping, then we can't have any spillout. |
2769 bool useOverflowClip = hasOverflowClip() && !hasSelfPaintingLayer(); | 2779 bool useOverflowClip = hasOverflowClip() && !hasSelfPaintingLayer(); |
2770 bool useClip = (hasControlClip() || useOverflowClip); | 2780 bool useClip = (hasControlClip() || useOverflowClip); |
2771 bool checkChildren = !useClip || (hasControlClip() ? locationInContainer.int ersects(controlClipRect(adjustedLocation)) : locationInContainer.intersects(over flowClipRect(adjustedLocation, IncludeOverlayScrollbarSize))); | 2781 bool checkChildren = !useClip || (hasControlClip() ? locationInContainer.int ersects(controlClipRect(adjustedLocation)) : locationInContainer.intersects(over flowClipRect(adjustedLocation, IncludeOverlayScrollbarSize))); |
2772 if (checkChildren) { | 2782 if (checkChildren) { |
2773 // Hit test descendants first. | 2783 // Hit test descendants first. |
2774 LayoutSize scrolledOffset(localOffset); | 2784 LayoutSize scrolledOffset(localOffset); |
2775 if (hasOverflowClip()) | 2785 if (hasOverflowClip()) |
2776 scrolledOffset -= scrolledContentOffset(); | 2786 scrolledOffset -= scrolledContentOffset(); |
2777 | 2787 |
(...skipping 2129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
4907 void RenderBlock::showLineTreeAndMark(const InlineBox* markedBox1, const char* m arkedLabel1, const InlineBox* markedBox2, const char* markedLabel2, const Render Object* obj) const | 4917 void RenderBlock::showLineTreeAndMark(const InlineBox* markedBox1, const char* m arkedLabel1, const InlineBox* markedBox2, const char* markedLabel2, const Render Object* obj) const |
4908 { | 4918 { |
4909 showRenderObject(); | 4919 showRenderObject(); |
4910 for (const RootInlineBox* root = firstRootBox(); root; root = root->nextRoot Box()) | 4920 for (const RootInlineBox* root = firstRootBox(); root; root = root->nextRoot Box()) |
4911 root->showLineTreeAndMark(markedBox1, markedLabel1, markedBox2, markedLa bel2, obj, 1); | 4921 root->showLineTreeAndMark(markedBox1, markedLabel1, markedBox2, markedLa bel2, obj, 1); |
4912 } | 4922 } |
4913 | 4923 |
4914 #endif | 4924 #endif |
4915 | 4925 |
4916 } // namespace WebCore | 4926 } // namespace WebCore |
OLD | NEW |