OLD | NEW |
| (Empty) |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #ifndef CHROME_BROWSER_ANDROID_SHORTCUT_DATA_FETCHER_H_ | |
6 #define CHROME_BROWSER_ANDROID_SHORTCUT_DATA_FETCHER_H_ | |
7 | |
8 #include "base/basictypes.h" | |
9 #include "base/task/cancelable_task_tracker.h" | |
10 #include "base/timer/timer.h" | |
11 #include "chrome/browser/android/shortcut_info.h" | |
12 #include "chrome/common/web_application_info.h" | |
13 #include "components/favicon_base/favicon_types.h" | |
14 #include "content/public/browser/web_contents_observer.h" | |
15 #include "content/public/common/manifest.h" | |
16 | |
17 namespace content { | |
18 class WebContents; | |
19 } // namespace content | |
20 | |
21 namespace IPC { | |
22 class Message; | |
23 } | |
24 | |
25 class GURL; | |
26 | |
27 // Aysnchronously fetches and processes data needed to create a shortcut for an | |
28 // Android Home screen launcher. | |
29 // | |
30 // Because of the various asynchronous calls made by this class, it is | |
31 // refcounted to prevent the class from being prematurely deleted. If the | |
32 // pointer to the ShortcutHelper becomes invalid, the pipeline should kill | |
33 // itself. | |
34 class ShortcutDataFetcher | |
35 : public base::RefCounted<ShortcutDataFetcher>, | |
36 public content::WebContentsObserver { | |
37 public: | |
38 class Observer { | |
39 public: | |
40 // Called when the title of the page is available. | |
41 virtual void OnUserTitleAvailable(const base::string16& title) = 0; | |
42 | |
43 // Converts the icon into one that can be used on the Android Home screen. | |
44 virtual SkBitmap FinalizeLauncherIcon(const SkBitmap& icon, | |
45 const GURL& url) = 0; | |
46 | |
47 // Called when all the data needed to create a shortcut is available. | |
48 virtual void OnDataAvailable(const ShortcutInfo& info, | |
49 const SkBitmap& icon) = 0; | |
50 }; | |
51 | |
52 // Initialize the fetcher by requesting the information about the page to the | |
53 // renderer process. The initialization is asynchronous and | |
54 // OnDidGetWebApplicationInfo is expected to be called when finished. | |
55 ShortcutDataFetcher(content::WebContents* web_contents, Observer* observer); | |
56 | |
57 // IPC message received when the initialization is finished. | |
58 void OnDidGetWebApplicationInfo(const WebApplicationInfo& web_app_info); | |
59 | |
60 // Called when the Manifest has been parsed, or if no Manifest was found. | |
61 void OnDidGetManifest(const content::Manifest& manifest); | |
62 | |
63 // Accessors, etc. | |
64 void set_weak_observer(Observer* observer) { weak_observer_ = observer; } | |
65 bool is_ready() { return is_ready_; } | |
66 ShortcutInfo& shortcut_info() { return shortcut_info_; } | |
67 const SkBitmap& shortcut_icon() { return shortcut_icon_; } | |
68 | |
69 // WebContentsObserver | |
70 bool OnMessageReceived(const IPC::Message& message) override; | |
71 | |
72 private: | |
73 ~ShortcutDataFetcher() override; | |
74 | |
75 // Grabs the favicon for the current URL. | |
76 void FetchFavicon(); | |
77 void OnFaviconFetched( | |
78 const favicon_base::FaviconRawBitmapResult& bitmap_result); | |
79 | |
80 // Creates the launcher icon from the given bitmap. | |
81 void CreateLauncherIcon( | |
82 const favicon_base::FaviconRawBitmapResult& bitmap_result); | |
83 | |
84 // Callback run after an attempt to download manifest icon has been made. May | |
85 // kick off the download of a favicon if it failed. | |
86 void OnManifestIconFetched(int id, | |
87 int http_status_code, | |
88 const GURL& url, | |
89 const std::vector<SkBitmap>& bitmaps, | |
90 const std::vector<gfx::Size>& sizes); | |
91 | |
92 // Notifies the observer that the shortcut data is all available. | |
93 void NotifyObserver(const SkBitmap& icon); | |
94 | |
95 Observer* weak_observer_; | |
96 | |
97 bool is_waiting_for_web_application_info_; | |
98 bool is_icon_saved_; | |
99 bool is_ready_; | |
100 base::Timer icon_timeout_timer_; | |
101 ShortcutInfo shortcut_info_; | |
102 | |
103 // The icon must only be set on the UI thread for thread safety. | |
104 SkBitmap shortcut_icon_; | |
105 base::CancelableTaskTracker favicon_task_tracker_; | |
106 | |
107 const int preferred_icon_size_in_px_; | |
108 static const int kPreferredIconSizeInDp; | |
109 | |
110 friend class base::RefCounted<ShortcutDataFetcher>; | |
111 DISALLOW_COPY_AND_ASSIGN(ShortcutDataFetcher); | |
112 }; | |
113 | |
114 #endif // CHROME_BROWSER_ANDROID_SHORTCUT_DATA_FETCHER_H_ | |
OLD | NEW |