Upstream version 5.34.104.0
[platform/framework/web/crosswalk.git] / src / third_party / WebKit / Source / core / fetch / ImageResource.h
1 /*
2     Copyright (C) 1998 Lars Knoll (knoll@mpi-hd.mpg.de)
3     Copyright (C) 2001 Dirk Mueller <mueller@kde.org>
4     Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com)
5     Copyright (C) 2004, 2005, 2006, 2007 Apple Inc. All rights reserved.
6
7     This library is free software; you can redistribute it and/or
8     modify it under the terms of the GNU Library General Public
9     License as published by the Free Software Foundation; either
10     version 2 of the License, or (at your option) any later version.
11
12     This library is distributed in the hope that it will be useful,
13     but WITHOUT ANY WARRANTY; without even the implied warranty of
14     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15     Library General Public License for more details.
16
17     You should have received a copy of the GNU Library General Public License
18     along with this library; see the file COPYING.LIB.  If not, write to
19     the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
20     Boston, MA 02110-1301, USA.
21 */
22
23 #ifndef ImageResource_h
24 #define ImageResource_h
25
26 #include "core/fetch/ResourcePtr.h"
27 #include "core/svg/graphics/SVGImageCache.h"
28 #include "platform/geometry/IntRect.h"
29 #include "platform/geometry/IntSizeHash.h"
30 #include "platform/geometry/LayoutSize.h"
31 #include "platform/graphics/ImageObserver.h"
32 #include "wtf/HashMap.h"
33
34 namespace WebCore {
35
36 class ImageResourceClient;
37 class ResourceFetcher;
38 class FloatSize;
39 class Length;
40 class MemoryCache;
41 class RenderObject;
42 class SecurityOrigin;
43
44 class ImageResource FINAL : public Resource, public ImageObserver {
45     friend class MemoryCache;
46
47 public:
48     typedef ImageResourceClient ClientType;
49
50     ImageResource(const ResourceRequest&);
51     ImageResource(WebCore::Image*);
52     virtual ~ImageResource();
53
54     virtual void load(ResourceFetcher*, const ResourceLoaderOptions&) OVERRIDE;
55
56     WebCore::Image* image(); // Returns the nullImage() if the image is not available yet.
57     WebCore::Image* imageForRenderer(const RenderObject*); // Returns the nullImage() if the image is not available yet.
58     bool hasImage() const { return m_image.get(); }
59     bool currentFrameKnownToBeOpaque(const RenderObject*); // Side effect: ensures decoded image is in cache, therefore should only be called when about to draw the image.
60
61     static std::pair<WebCore::Image*, float> brokenImage(float deviceScaleFactor); // Returns an image and the image's resolution scale factor.
62     bool willPaintBrokenImage() const;
63
64     bool canRender(const RenderObject* renderer, float multiplier) { return !errorOccurred() && !imageSizeForRenderer(renderer, multiplier).isEmpty(); }
65
66     void setContainerSizeForRenderer(const ImageResourceClient*, const IntSize&, float);
67     bool usesImageContainerSize() const;
68     bool imageHasRelativeWidth() const;
69     bool imageHasRelativeHeight() const;
70     // The device pixel ratio we got from the server for this image, or 1.0.
71     float devicePixelRatioHeaderValue() const { return m_devicePixelRatioHeaderValue; }
72     bool hasDevicePixelRatioHeaderValue() const { return m_hasDevicePixelRatioHeaderValue; }
73
74     enum SizeType {
75         NormalSize, // Report the size of the image associated with a certain renderer
76         IntrinsicSize // Report the intrinsic size, i.e. ignore whatever has been set extrinsically.
77     };
78     // This method takes a zoom multiplier that can be used to increase the natural size of the image by the zoom.
79     LayoutSize imageSizeForRenderer(const RenderObject*, float multiplier, SizeType = NormalSize); // returns the size of the complete image.
80     void computeIntrinsicDimensions(Length& intrinsicWidth, Length& intrinsicHeight, FloatSize& intrinsicRatio);
81
82     bool isAccessAllowed(SecurityOrigin*);
83
84     virtual void didAddClient(ResourceClient*) OVERRIDE;
85     virtual void didRemoveClient(ResourceClient*) OVERRIDE;
86
87     virtual void allClientsRemoved() OVERRIDE;
88
89     virtual void appendData(const char*, int) OVERRIDE;
90     virtual void error(Resource::Status) OVERRIDE;
91     virtual void responseReceived(const ResourceResponse&) OVERRIDE;
92     virtual void finishOnePart() OVERRIDE;
93
94     // For compatibility, images keep loading even if there are HTTP errors.
95     virtual bool shouldIgnoreHTTPStatusCodeErrors() const OVERRIDE { return true; }
96
97     virtual bool isImage() const OVERRIDE { return true; }
98     virtual bool stillNeedsLoad() const OVERRIDE { return !errorOccurred() && status() == Unknown && !isLoading(); }
99
100     // ImageObserver
101     virtual void decodedSizeChanged(const WebCore::Image*, int delta) OVERRIDE;
102     virtual void didDraw(const WebCore::Image*) OVERRIDE;
103
104     virtual bool shouldPauseAnimation(const WebCore::Image*) OVERRIDE;
105     virtual void animationAdvanced(const WebCore::Image*) OVERRIDE;
106     virtual void changedInRect(const WebCore::Image*, const IntRect&) OVERRIDE;
107
108 protected:
109     virtual bool isSafeToUnlock() const OVERRIDE;
110     virtual void destroyDecodedDataIfPossible() OVERRIDE;
111
112 private:
113     void clear();
114
115     void setCustomAcceptHeader();
116     void createImage();
117     void updateImage(bool allDataReceived);
118     void clearImage();
119     // If not null, changeRect is the changed part of the image.
120     void notifyObservers(const IntRect* changeRect = 0);
121
122     virtual void switchClientsToRevalidatedResource() OVERRIDE;
123
124     typedef pair<IntSize, float> SizeAndZoom;
125     typedef HashMap<const ImageResourceClient*, SizeAndZoom> ContainerSizeRequests;
126     ContainerSizeRequests m_pendingContainerSizeRequests;
127     float m_devicePixelRatioHeaderValue;
128
129     RefPtr<WebCore::Image> m_image;
130     OwnPtr<SVGImageCache> m_svgImageCache;
131     bool m_loadingMultipartContent;
132     bool m_hasDevicePixelRatioHeaderValue;
133 };
134
135 DEFINE_RESOURCE_TYPE_CASTS(Image);
136
137 }
138
139 #endif