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.
5 #ifndef CHROME_BROWSER_ANDROID_SHORTCUT_DATA_FETCHER_H_
6 #define CHROME_BROWSER_ANDROID_SHORTCUT_DATA_FETCHER_H_
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"
19 } // namespace content
27 // Aysnchronously fetches and processes data needed to create a shortcut for an
28 // Android Home screen launcher.
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
34 class ShortcutDataFetcher
35 : public base::RefCounted
<ShortcutDataFetcher
>,
36 public content::WebContentsObserver
{
40 // Called when the title of the page is available.
41 virtual void OnUserTitleAvailable(const base::string16
& title
) = 0;
43 // Converts the icon into one that can be used on the Android Home screen.
44 virtual SkBitmap
FinalizeLauncherIcon(const SkBitmap
& icon
,
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;
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
);
57 // IPC message received when the initialization is finished.
58 void OnDidGetWebApplicationInfo(const WebApplicationInfo
& web_app_info
);
60 // Called when the Manifest has been parsed, or if no Manifest was found.
61 void OnDidGetManifest(const content::Manifest
& manifest
);
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_
; }
69 // WebContentsObserver
70 bool OnMessageReceived(const IPC::Message
& message
) override
;
73 ~ShortcutDataFetcher() override
;
75 // Grabs the favicon for the current URL.
77 void OnFaviconFetched(
78 const favicon_base::FaviconRawBitmapResult
& bitmap_result
);
80 // Creates the launcher icon from the given bitmap.
81 void CreateLauncherIcon(
82 const favicon_base::FaviconRawBitmapResult
& bitmap_result
);
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
,
89 const std::vector
<SkBitmap
>& bitmaps
,
90 const std::vector
<gfx::Size
>& sizes
);
92 // Notifies the observer that the shortcut data is all available.
93 void NotifyObserver(const SkBitmap
& icon
);
95 Observer
* weak_observer_
;
97 bool is_waiting_for_web_application_info_
;
100 base::Timer icon_timeout_timer_
;
101 ShortcutInfo shortcut_info_
;
103 // The icon must only be set on the UI thread for thread safety.
104 SkBitmap shortcut_icon_
;
105 base::CancelableTaskTracker favicon_task_tracker_
;
107 const int preferred_icon_size_in_px_
;
108 static const int kPreferredIconSizeInDp
;
110 friend class base::RefCounted
<ShortcutDataFetcher
>;
111 DISALLOW_COPY_AND_ASSIGN(ShortcutDataFetcher
);
114 #endif // CHROME_BROWSER_ANDROID_SHORTCUT_DATA_FETCHER_H_