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_UI_APP_LIST_ARC_APP_ICON_H_ |
| 6 #define CHROME_BROWSER_UI_APP_LIST_ARC_APP_ICON_H_ |
| 7 |
| 8 #include <string> |
| 9 |
| 10 #include "base/macros.h" |
| 11 #include "base/memory/scoped_vector.h" |
| 12 #include "base/memory/weak_ptr.h" |
| 13 #include "ui/base/layout.h" |
| 14 #include "ui/gfx/image/image.h" |
| 15 #include "ui/gfx/image/image_skia.h" |
| 16 |
| 17 namespace base { |
| 18 class FilePath; |
| 19 } |
| 20 |
| 21 namespace content { |
| 22 class BrowserContext; |
| 23 } |
| 24 |
| 25 // A class that provides an ImageSkia for UI code to use. It handles ARC app |
| 26 // icon resource loading, screen scale factor change etc. UI code that uses |
| 27 // ARC app icon should host this class. |
| 28 class ArcAppIcon { |
| 29 public: |
| 30 class Observer { |
| 31 public: |
| 32 // Invoked when a new image rep for an additional scale factor |
| 33 // is loaded and added to |image|. |
| 34 virtual void OnIconUpdated() = 0; |
| 35 |
| 36 protected: |
| 37 virtual ~Observer() {} |
| 38 }; |
| 39 |
| 40 ArcAppIcon(content::BrowserContext* context, |
| 41 const std::string& app_id, |
| 42 int resource_size_in_dip, |
| 43 Observer* observer); |
| 44 ~ArcAppIcon(); |
| 45 |
| 46 gfx::Image image() const { return image_; } |
| 47 const gfx::ImageSkia& image_skia() const { return image_skia_; } |
| 48 |
| 49 // Icon loading is performed in several steps. It is initiated by |
| 50 // LoadImageForScaleFactor request that specifies a required scale factor. |
| 51 // ArcAppListPrefs is used to resolve a path to resource. Content of file is |
| 52 // asynchronously read in context of browser file thread. On successful read, |
| 53 // an icon data is decoded to an image in the special utility process. |
| 54 // DecodeRequest is used to interact with the utility process, and each |
| 55 // active request is stored at |decode_requests_| vector. When decoding is |
| 56 // complete, results are returned in context of UI thread, and corresponding |
| 57 // request is removed from |decode_requests_|. In case of some requests are |
| 58 // not completed by the time of deleting this icon, they are automatically |
| 59 // canceled. |
| 60 // In case of the icon file is not available this requests ArcAppListPrefs to |
| 61 // install required resource from ARC side. ArcAppListPrefs notifies UI items |
| 62 // that new icon is available and corresponding item should invoke |
| 63 // LoadImageForScaleFactor again. |
| 64 void LoadForScaleFactor(ui::ScaleFactor scale_factor); |
| 65 |
| 66 private: |
| 67 class Source; |
| 68 class DecodeRequest; |
| 69 |
| 70 void RequestIcon(ui::ScaleFactor scale_factor); |
| 71 void ReadOnFileThread(ui::ScaleFactor scale_factor, |
| 72 const base::FilePath& path); |
| 73 void OnIconRead(ui::ScaleFactor scale_factor, |
| 74 const std::string& unsafe_image_data); |
| 75 void Update(const gfx::ImageSkia* image); |
| 76 void DiscardDecodeRequest(DecodeRequest* request); |
| 77 |
| 78 content::BrowserContext* context_; |
| 79 std::string app_id_; |
| 80 const int resource_size_in_dip_; |
| 81 Observer* observer_; |
| 82 |
| 83 Source* source_ = nullptr; // Owned by ImageSkia storage. |
| 84 gfx::ImageSkia image_skia_; |
| 85 |
| 86 // The image wrapper around |image_skia_|. |
| 87 // Note: this is reset each time a new representation is loaded. |
| 88 gfx::Image image_; |
| 89 |
| 90 // Contains pending image decode requests. |
| 91 ScopedVector<DecodeRequest> decode_requests_; |
| 92 |
| 93 base::WeakPtrFactory<ArcAppIcon> weak_ptr_factory_; |
| 94 |
| 95 DISALLOW_COPY_AND_ASSIGN(ArcAppIcon); |
| 96 }; |
| 97 |
| 98 #endif // CHROME_BROWSER_UI_APP_LIST_ARC_APP_ICON_H_ |
OLD | NEW |