1 // Copyright (c) 2012 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_EXTENSIONS_EXTENSION_ICON_IMAGE_H_ 6 #define CHROME_BROWSER_EXTENSIONS_EXTENSION_ICON_IMAGE_H_ 7 8 #include <map> 9 #include <string> 10 11 #include "base/basictypes.h" 12 #include "base/memory/weak_ptr.h" 13 #include "chrome/common/extensions/extension_icon_set.h" 14 #include "content/public/browser/notification_observer.h" 15 #include "content/public/browser/notification_registrar.h" 16 #include "ui/base/layout.h" 17 #include "ui/gfx/image/image_skia.h" 18 19 namespace content { 20 class BrowserContext; 21 } 22 23 namespace extensions { 24 class Extension; 25 } 26 27 namespace gfx { 28 class Size; 29 class Image; 30 } 31 32 namespace extensions { 33 34 // A class that provides an ImageSkia for UI code to use. It handles extension 35 // icon resource loading, screen scale factor change etc. UI code that uses 36 // extension icon should host this class and be its observer. ExtensionIconImage 37 // should be outlived by the observer. In painting code, UI code paints with the 38 // ImageSkia provided by this class. If required extension icon resource is not 39 // already present, this class tries to load it and calls its observer interface 40 // when the image get updated. Until the resource is loaded, the UI code will be 41 // provided with blank, transparent image. 42 // If the requested resource doesn't exist or can't be loaded and a default 43 // icon was supplied in the constructor, icon image will be updated with the 44 // default icon's resource. 45 // The default icon doesn't need to be supplied, but in that case, icon image 46 // representation will be left blank if the resource loading fails. 47 // If default icon is supplied, it is assumed that it contains or can 48 // synchronously create (when |GetRepresentation| is called on it) 49 // representations for all the scale factors supported by the current platform. 50 // Note that |IconImage| is not thread safe. 51 class IconImage : public content::NotificationObserver { 52 public: 53 class Observer { 54 public: 55 // Invoked when a new image rep for an additional scale factor 56 // is loaded and added to |image|. 57 virtual void OnExtensionIconImageChanged(IconImage* image) = 0; 58 59 protected: 60 virtual ~Observer() {} 61 }; 62 63 // |context| is required by the underlying implementation to retrieve the 64 // |ImageLoader| instance associated with the given context. |ImageLoader| is 65 // used to perform the asynchronous image load work. 66 IconImage(content::BrowserContext* context, 67 const Extension* extension, 68 const ExtensionIconSet& icon_set, 69 int resource_size_in_dip, 70 const gfx::ImageSkia& default_icon, 71 Observer* observer); 72 virtual ~IconImage(); 73 74 const gfx::ImageSkia& image_skia() const { return image_skia_; } 75 76 private: 77 class Source; 78 79 // Loads an image representation for the scale factor. 80 // If the representation gets loaded synchronously, it is returned by this 81 // method. 82 // If representation loading is asynchronous, an empty image 83 // representation is returned. When the representation gets loaded the 84 // observer's |OnExtensionIconImageLoaded| will be called. 85 gfx::ImageSkiaRep LoadImageForScaleFactor(ui::ScaleFactor scale_factor); 86 87 void OnImageLoaded(float scale_factor, const gfx::Image& image); 88 89 // content::NotificationObserver overrides: 90 virtual void Observe(int type, 91 const content::NotificationSource& source, 92 const content::NotificationDetails& details) OVERRIDE; 93 94 content::BrowserContext* browser_context_; 95 const Extension* extension_; 96 const ExtensionIconSet& icon_set_; 97 const int resource_size_in_dip_; 98 99 Observer* observer_; 100 101 Source* source_; // Owned by ImageSkia storage. 102 gfx::ImageSkia image_skia_; 103 // The icon with whose representation |image_skia_| should be updated if 104 // its own representation load fails. 105 gfx::ImageSkia default_icon_; 106 107 content::NotificationRegistrar registrar_; 108 109 base::WeakPtrFactory<IconImage> weak_ptr_factory_; 110 111 DISALLOW_COPY_AND_ASSIGN(IconImage); 112 }; 113 114 } // namespace extensions 115 116 #endif // CHROME_BROWSER_EXTENSIONS_EXTENSION_ICON_IMAGE_H_ 117