/* Copyright (C) 1998 Lars Knoll (knoll@mpi-hd.mpg.de) Copyright (C) 2001 Dirk Mueller Copyright (C) 2006 Samuel Weinig (sam.weinig@gmail.com) Copyright (C) 2004, 2005, 2006, 2007 Apple Inc. All rights reserved. This library is free software; you can redistribute it and/or modify it under the terms of the GNU Library General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License for more details. You should have received a copy of the GNU Library General Public License along with this library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ #ifndef CachedImage_h #define CachedImage_h #include "CachedResource.h" #include "Image.h" #include "ImageObserver.h" #include "IntRect.h" #include "IntSizeHash.h" #include "LayoutSize.h" #include "SVGImageCache.h" #include #include namespace WebCore { class CachedImageClient; class CachedResourceLoader; class FloatSize; class MemoryCache; class RenderElement; class RenderObject; class SecurityOrigin; struct Length; class CachedImage final : public CachedResource, public ImageObserver { friend class MemoryCache; public: enum CacheBehaviorType { AutomaticallyCached, ManuallyCached }; CachedImage(const ResourceRequest&, SessionID); CachedImage(Image*, SessionID); CachedImage(const URL&, Image*, SessionID); CachedImage(const URL&, Image*, CacheBehaviorType, SessionID); virtual ~CachedImage(); WEBCORE_EXPORT Image* image(); // Returns the nullImage() if the image is not available yet. WEBCORE_EXPORT Image* imageForRenderer(const RenderObject*); // Returns the nullImage() if the image is not available yet. bool hasImage() const { return m_image.get(); } bool currentFrameKnownToBeOpaque(const RenderElement*); std::pair brokenImage(float deviceScaleFactor) const; // Returns an image and the image's resolution scale factor. bool willPaintBrokenImage() const; bool canRender(const RenderObject* renderer, float multiplier) { return !errorOccurred() && !imageSizeForRenderer(renderer, multiplier).isEmpty(); } void setContainerSizeForRenderer(const CachedImageClient*, const LayoutSize&, float); bool usesImageContainerSize() const; bool imageHasRelativeWidth() const; bool imageHasRelativeHeight() const; virtual void addDataBuffer(SharedBuffer&) override; virtual void finishLoading(SharedBuffer*) override; enum SizeType { UsedSize, IntrinsicSize }; // This method takes a zoom multiplier that can be used to increase the natural size of the image by the zoom. LayoutSize imageSizeForRenderer(const RenderObject*, float multiplier, SizeType = UsedSize); // returns the size of the complete image. void computeIntrinsicDimensions(Length& intrinsicWidth, Length& intrinsicHeight, FloatSize& intrinsicRatio); bool isManuallyCached() const { return m_isManuallyCached; } RevalidationDecision makeRevalidationDecision(CachePolicy) const override; virtual void load(CachedResourceLoader&, const ResourceLoaderOptions&) override; bool isOriginClean(SecurityOrigin*); private: void clear(); void createImage(); void clearImage(); // If not null, changeRect is the changed part of the image. void notifyObservers(const IntRect* changeRect = nullptr); void checkShouldPaintBrokenImage(); virtual void switchClientsToRevalidatedResource() override; virtual bool mayTryReplaceEncodedData() const override { return true; } virtual void didAddClient(CachedResourceClient*) override; virtual void didRemoveClient(CachedResourceClient*) override; virtual void allClientsRemoved() override; virtual void destroyDecodedData() override; virtual void addData(const char* data, unsigned length) override; virtual void error(CachedResource::Status) override; virtual void responseReceived(const ResourceResponse&) override; // For compatibility, images keep loading even if there are HTTP errors. virtual bool shouldIgnoreHTTPStatusCodeErrors() const override { return true; } virtual bool stillNeedsLoad() const override { return !errorOccurred() && status() == Unknown && !isLoading(); } // ImageObserver virtual void decodedSizeChanged(const Image*, int delta) override; virtual void didDraw(const Image*) override; virtual void animationAdvanced(const Image*) override; virtual void changedInRect(const Image*, const IntRect&) override; void addIncrementalDataBuffer(SharedBuffer&); void didReplaceSharedBufferContents() override; typedef std::pair SizeAndZoom; typedef HashMap ContainerSizeRequests; ContainerSizeRequests m_pendingContainerSizeRequests; RefPtr m_image; std::unique_ptr m_svgImageCache; unsigned m_isManuallyCached : 1; unsigned m_shouldPaintBrokenImage : 1; }; } // namespace WebCore SPECIALIZE_TYPE_TRAITS_CACHED_RESOURCE(CachedImage, CachedResource::ImageResource) #endif // CachedImage_h