Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(391)

Side by Side Diff: Source/core/rendering/svg/RenderSVGResourceClipper.h

Issue 908243002: Move rendering/svg/RenderSVGResource* to layout/svg. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 5 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 /*
2 * Copyright (C) Research In Motion Limited 2009-2010. All rights reserved.
3 *
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
8 *
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
13 *
14 * You should have received a copy of the GNU Library General Public License
15 * along with this library; see the file COPYING.LIB. If not, write to
16 * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17 * Boston, MA 02110-1301, USA.
18 */
19
20 #ifndef RenderSVGResourceClipper_h
21 #define RenderSVGResourceClipper_h
22
23 #include "core/rendering/svg/RenderSVGResourceContainer.h"
24 #include "core/svg/SVGClipPathElement.h"
25
26 class SkPicture;
27
28 namespace blink {
29
30 class RenderSVGResourceClipper final : public RenderSVGResourceContainer {
31 public:
32 enum ClipperState {
33 ClipperNotApplied,
34 ClipperAppliedPath,
35 ClipperAppliedMask
36 };
37
38 explicit RenderSVGResourceClipper(SVGClipPathElement*);
39 virtual ~RenderSVGResourceClipper();
40
41 virtual const char* renderName() const override { return "RenderSVGResourceC lipper"; }
42
43 virtual void removeAllClientsFromCache(bool markForInvalidation = true) over ride;
44 virtual void removeClientFromCache(LayoutObject*, bool markForInvalidation = true) override;
45
46 // FIXME: Filters are also stateful resources that could benefit from having their state managed
47 // on the caller stack instead of the current hashmap. We should look at refactoring these
48 // into a general interface that can be shared.
49 bool applyStatefulResource(LayoutObject*, GraphicsContext*&, ClipperState&);
50 void postApplyStatefulResource(LayoutObject*, GraphicsContext*&, ClipperStat e&);
51
52 // clipPath can be clipped too, but don't have a boundingBox or paintInvalid ationRect. So we can't call
53 // applyResource directly and use the rects from the object, since they are empty for RenderSVGResources
54 // FIXME: We made applyClippingToContext public because we cannot call apply Resource on HTML elements (it asserts on LayoutObject::objectBoundingBox)
55 bool applyClippingToContext(LayoutObject*, const FloatRect&, const FloatRect &, GraphicsContext*, ClipperState&);
56
57 FloatRect resourceBoundingBox(const LayoutObject*);
58
59 static const RenderSVGResourceType s_resourceType = ClipperResourceType;
60 virtual RenderSVGResourceType resourceType() const override { return s_resou rceType; }
61
62 bool hitTestClipContent(const FloatRect&, const FloatPoint&);
63
64 SVGUnitTypes::SVGUnitType clipPathUnits() const { return toSVGClipPathElemen t(element())->clipPathUnits()->currentValue()->enumValue(); }
65
66 private:
67 bool tryPathOnlyClipping(DisplayItemClient, GraphicsContext*, const AffineTr ansform&, const FloatRect&);
68 void drawClipMaskContent(GraphicsContext*, const FloatRect& targetBoundingBo x);
69 void createPicture(GraphicsContext*);
70 void calculateClipContentPaintInvalidationRect();
71
72 RefPtr<const SkPicture> m_clipContentPicture;
73 FloatRect m_clipBoundaries;
74
75 // Reference cycle detection.
76 bool m_inClipExpansion;
77 };
78
79 DEFINE_RENDER_SVG_RESOURCE_TYPE_CASTS(RenderSVGResourceClipper, ClipperResourceT ype);
80
81 }
82
83 #endif
OLDNEW
« no previous file with comments | « Source/core/rendering/svg/RenderSVGPath.cpp ('k') | Source/core/rendering/svg/RenderSVGResourceClipper.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698