| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #ifndef CONTENT_RENDERER_IMAGE_LOADING_HELPER_H_ | 5 #ifndef CONTENT_RENDERER_IMAGE_LOADING_HELPER_H_ |
| 6 #define CONTENT_RENDERER_IMAGE_LOADING_HELPER_H_ | 6 #define CONTENT_RENDERER_IMAGE_LOADING_HELPER_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| 11 #include "base/memory/scoped_vector.h" | 11 #include "base/memory/scoped_vector.h" |
| 12 #include "content/public/renderer/render_frame_observer.h" | 12 #include "content/public/renderer/render_frame_observer.h" |
| 13 #include "third_party/WebKit/public/platform/WebURLRequest.h" |
| 13 #include "url/gurl.h" | 14 #include "url/gurl.h" |
| 14 | 15 |
| 15 class SkBitmap; | 16 class SkBitmap; |
| 16 | 17 |
| 17 namespace content { | 18 namespace content { |
| 18 | 19 |
| 19 class MultiResolutionImageResourceFetcher; | 20 class MultiResolutionImageResourceFetcher; |
| 20 | 21 |
| 21 // This class deals with image downloading. | 22 // This class deals with image downloading. |
| 22 // One instance of ImageLoadingHelper is owned by RenderFrame. | 23 // One instance of ImageLoadingHelper is owned by RenderFrame. |
| 23 class ImageLoadingHelper : public RenderFrameObserver { | 24 class ImageLoadingHelper : public RenderFrameObserver { |
| 24 public: | 25 public: |
| 25 explicit ImageLoadingHelper(RenderFrame* render_frame); | 26 explicit ImageLoadingHelper(RenderFrame* render_frame); |
| 26 | 27 |
| 27 private: | 28 private: |
| 28 ~ImageLoadingHelper() override; | 29 ~ImageLoadingHelper() override; |
| 29 | 30 |
| 30 // Message handler. | 31 // Message handler. |
| 31 void OnDownloadImage(int id, | 32 void OnDownloadImage(int id, |
| 32 const GURL& image_url, | 33 const GURL& image_url, |
| 33 bool is_favicon, | 34 bool is_favicon, |
| 34 uint32_t max_image_size); | 35 uint32_t max_image_size, |
| 36 blink::WebURLRequest::CachePolicy cache_policy); |
| 35 | 37 |
| 36 // Requests to download an image. When done, the ImageLoadingHelper | 38 // Requests to download an image. When done, the ImageLoadingHelper |
| 37 // is notified by way of DidDownloadImage. Returns true if the | 39 // is notified by way of DidDownloadImage. Returns true if the |
| 38 // request was successfully started, false otherwise. id is used to | 40 // request was successfully started, false otherwise. id is used to |
| 39 // uniquely identify the request and passed back to the | 41 // uniquely identify the request and passed back to the |
| 40 // DidDownloadImage method. If the image is a favicon, cookies will not be | 42 // DidDownloadImage method. If the image is a favicon, cookies will not be |
| 41 // sent nor accepted during download. If the image has multiple frames, all | 43 // sent nor accepted during download. If the image has multiple frames, all |
| 42 // the frames whose size <= |max_image_size| are returned. If all of the | 44 // the frames whose size <= |max_image_size| are returned. If all of the |
| 43 // frames are larger than |max_image_size|, the smallest frame is resized to | 45 // frames are larger than |max_image_size|, the smallest frame is resized to |
| 44 // |max_image_size| and is the only result. |max_image_size| == 0 is | 46 // |max_image_size| and is the only result. |max_image_size| == 0 is |
| 45 // interpreted as no max image size. | 47 // interpreted as no max image size. |
| 46 bool DownloadImage(int id, | 48 bool DownloadImage(int id, |
| 47 const GURL& image_url, | 49 const GURL& image_url, |
| 48 bool is_favicon, | 50 bool is_favicon, |
| 49 uint32_t max_image_size); | 51 uint32_t max_image_size, |
| 52 blink::WebURLRequest::CachePolicy cache_policy); |
| 50 | 53 |
| 51 // This callback is triggered when DownloadImage completes, either | 54 // This callback is triggered when DownloadImage completes, either |
| 52 // succesfully or with a failure. See DownloadImage for more | 55 // succesfully or with a failure. See DownloadImage for more |
| 53 // details. | 56 // details. |
| 54 void DidDownloadImage( | 57 void DidDownloadImage( |
| 55 uint32_t max_image_size, | 58 uint32_t max_image_size, |
| 56 MultiResolutionImageResourceFetcher* fetcher, | 59 MultiResolutionImageResourceFetcher* fetcher, |
| 57 const std::vector<SkBitmap>& images); | 60 const std::vector<SkBitmap>& images); |
| 58 | 61 |
| 59 // Decodes a data: URL image or returns an empty image in case of failure. | 62 // Decodes a data: URL image or returns an empty image in case of failure. |
| 60 SkBitmap ImageFromDataUrl(const GURL&) const; | 63 SkBitmap ImageFromDataUrl(const GURL&) const; |
| 61 | 64 |
| 62 // RenderFrameObserver implementation. | 65 // RenderFrameObserver implementation. |
| 63 bool OnMessageReceived(const IPC::Message& message) override; | 66 bool OnMessageReceived(const IPC::Message& message) override; |
| 64 | 67 |
| 65 typedef ScopedVector<MultiResolutionImageResourceFetcher> | 68 typedef ScopedVector<MultiResolutionImageResourceFetcher> |
| 66 ImageResourceFetcherList; | 69 ImageResourceFetcherList; |
| 67 | 70 |
| 68 // ImageResourceFetchers schedule via DownloadImage. | 71 // ImageResourceFetchers schedule via DownloadImage. |
| 69 ImageResourceFetcherList image_fetchers_; | 72 ImageResourceFetcherList image_fetchers_; |
| 70 | 73 |
| 71 DISALLOW_COPY_AND_ASSIGN(ImageLoadingHelper); | 74 DISALLOW_COPY_AND_ASSIGN(ImageLoadingHelper); |
| 72 }; | 75 }; |
| 73 | 76 |
| 74 } // namespace content | 77 } // namespace content |
| 75 | 78 |
| 76 #endif // CONTENT_RENDERER_IMAGE_LOADING_HELPER_H_ | 79 #endif // CONTENT_RENDERER_IMAGE_LOADING_HELPER_H_ |
| 77 | 80 |
| OLD | NEW |