// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef WEBKIT_GLUE_IMAGE_RESOURCE_FETCHER_H_ #define WEBKIT_GLUE_IMAGE_RESOURCE_FETCHER_H_ #include "base/basictypes.h" #include "base/callback.h" #include "webkit/glue/resource_fetcher.h" class SkBitmap; namespace webkit_glue { // ImageResourceFetcher handles downloading an image for a webview. Once // downloading is done the supplied callback is notified. ImageResourceFetcher // is used to download the favicon and images for web apps. class ImageResourceFetcher { public: typedef Callback2<ImageResourceFetcher*, const SkBitmap&>::Type Callback; ImageResourceFetcher(const GURL& image_url, WebKit::WebFrame* frame, int id, int image_size, WebKit::WebURLRequest::TargetType target_type, Callback* callback); virtual ~ImageResourceFetcher(); // URL of the image we're downloading. const GURL& image_url() const { return image_url_; } // Unique identifier for the request. int id() const { return id_; } private: // ResourceFetcher::Callback. Decodes the image and invokes callback_. void OnURLFetchComplete(const WebKit::WebURLResponse& response, const std::string& data); scoped_ptr<Callback> callback_; // Unique identifier for the request. const int id_; // URL of the image. const GURL image_url_; // The size of the image. This is only a hint that is used if the image // contains multiple sizes. A value of 0 results in using the first frame // of the image. const int image_size_; // Does the actual download. scoped_ptr<ResourceFetcher> fetcher_; DISALLOW_COPY_AND_ASSIGN(ImageResourceFetcher); }; } // namespace webkit_glue #endif // WEBKIT_GLUE_IMAGE_RESOURCE_FETCHER_H_