Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(271)

Side by Side Diff: ui/gfx/image/image.h

Issue 10799014: Add support for PNG representation in gfx::Image (Closed) Base URL: http://git.chromium.org/chromium/src.git@bookmark-sync
Patch Set: Created 8 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | ui/gfx/image/image.cc » ('j') | ui/gfx/image/image.cc » ('J')
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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 // An Image wraps an image any flavor, be it platform-native GdkBitmap/NSImage, 5 // An Image wraps an image any flavor, be it platform-native GdkBitmap/NSImage,
6 // or a SkBitmap. This also provides easy conversion to other image types 6 // or a SkBitmap. This also provides easy conversion to other image types
7 // through operator overloading. It will cache the converted representations 7 // through operator overloading. It will cache the converted representations
8 // internally to prevent double-conversion. 8 // internally to prevent double-conversion.
9 // 9 //
10 // The lifetime of both the initial representation and any converted ones are 10 // The lifetime of both the initial representation and any converted ones are
(...skipping 18 matching lines...) Expand all
29 #include "ui/gfx/native_widget_types.h" 29 #include "ui/gfx/native_widget_types.h"
30 30
31 class SkBitmap; 31 class SkBitmap;
32 32
33 namespace { 33 namespace {
34 class ImageTest; 34 class ImageTest;
35 class ImageMacTest; 35 class ImageMacTest;
36 } 36 }
37 37
38 namespace gfx { 38 namespace gfx {
39 class ImagePNG;
Robert Sesek 2012/07/20 21:03:01 Remove
cjhopman 2012/07/24 01:44:13 Done.
39 class ImageSkia; 40 class ImageSkia;
40 class ImageSkiaRep; 41 class ImageSkiaRep;
41 42
42 #if defined(TOOLKIT_GTK) 43 #if defined(TOOLKIT_GTK)
43 class CairoCachedSurface; 44 class CairoCachedSurface;
44 #endif 45 #endif
45 46
46 namespace internal { 47 namespace internal {
47 class ImageRep; 48 class ImageRep;
48 class ImageStorage; 49 class ImageStorage;
49 } 50 }
50 51
51 class UI_EXPORT Image { 52 class UI_EXPORT Image {
52 public: 53 public:
53 enum RepresentationType { 54 enum RepresentationType {
54 kImageRepGdk, 55 kImageRepGdk,
55 kImageRepCocoa, 56 kImageRepCocoa,
56 kImageRepCairo, 57 kImageRepCairo,
57 kImageRepSkia, 58 kImageRepSkia,
59 kImageRepPNG,
58 }; 60 };
59 61
60 typedef std::map<RepresentationType, internal::ImageRep*> RepresentationMap; 62 typedef std::map<RepresentationType, internal::ImageRep*> RepresentationMap;
61 63
62 // Creates an empty image with no representations. 64 // Creates an empty image with no representations.
63 Image(); 65 Image();
64 66
67 // Creates a new image by copying the png-encoded input for use as the default
68 // representation.
69 Image(const unsigned char* png, size_t input_size);
70 explicit Image(const std::vector<unsigned char>& png);
Robert Sesek 2012/07/20 21:03:01 I wonder if you even need this constructor. A clie
cjhopman 2012/07/24 01:44:13 Agreed. Done.
71
65 // Creates a new image by copying the ImageSkia for use as the default 72 // Creates a new image by copying the ImageSkia for use as the default
66 // representation. 73 // representation.
67 explicit Image(const ImageSkia& image); 74 explicit Image(const ImageSkia& image);
68 75
69 // Creates a new image by copying the image rep for use as the default 76 // Creates a new image by copying the image rep for use as the default
70 // representation. 77 // representation.
71 explicit Image(const ImageSkiaRep& image_rep); 78 explicit Image(const ImageSkiaRep& image_rep);
72 79
73 // Creates a new image by copying the bitmap for use as the default 80 // Creates a new image by copying the bitmap for use as the default
74 // representation. 81 // representation.
(...skipping 16 matching lines...) Expand all
91 // Copies a reference to |other|'s storage. 98 // Copies a reference to |other|'s storage.
92 Image& operator=(const Image& other); 99 Image& operator=(const Image& other);
93 100
94 // Deletes the image and, if the only owner of the storage, all of its cached 101 // Deletes the image and, if the only owner of the storage, all of its cached
95 // representations. 102 // representations.
96 ~Image(); 103 ~Image();
97 104
98 // Converts the Image to the desired representation and stores it internally. 105 // Converts the Image to the desired representation and stores it internally.
99 // The returned result is a weak pointer owned by and scoped to the life of 106 // The returned result is a weak pointer owned by and scoped to the life of
100 // the Image. 107 // the Image.
108 const std::vector<unsigned char>* ToImagePNG() const;
Robert Sesek 2012/07/20 21:03:01 I'm wondering if this should return a const ref. R
cjhopman 2012/07/24 01:44:13 I think my preference would be to keep it consiste
Robert Sesek 2012/07/24 18:59:17 Agree. Let's keep these as pointers.
101 const SkBitmap* ToSkBitmap() const; 109 const SkBitmap* ToSkBitmap() const;
102 const ImageSkia* ToImageSkia() const; 110 const ImageSkia* ToImageSkia() const;
103 #if defined(TOOLKIT_GTK) 111 #if defined(TOOLKIT_GTK)
104 GdkPixbuf* ToGdkPixbuf() const; 112 GdkPixbuf* ToGdkPixbuf() const;
105 CairoCachedSurface* const ToCairo() const; 113 CairoCachedSurface* const ToCairo() const;
106 #elif defined(OS_MACOSX) 114 #elif defined(OS_MACOSX)
107 NSImage* ToNSImage() const; 115 NSImage* ToNSImage() const;
108 #endif 116 #endif
109 117
110 // Performs a conversion, like above, but returns a copy of the result rather 118 // Performs a conversion, like above, but returns a copy of the result rather
111 // than a weak pointer. The caller is responsible for deleting the result. 119 // than a weak pointer. The caller is responsible for deleting the result.
112 // Note that the result is only a copy in terms of memory management; the 120 // Note that the result is only a copy in terms of memory management; the
113 // backing pixels are shared amongst all copies (a fact of each of the 121 // backing pixels are shared amongst all copies (a fact of each of the
114 // converted representations, rather than a limitation imposed by Image) and 122 // converted representations, rather than a limitation imposed by Image) and
115 // so the result should be considered immutable. 123 // so the result should be considered immutable.
124 std::vector<unsigned char>* CopyImagePNG() const;
116 ImageSkia* CopyImageSkia() const; 125 ImageSkia* CopyImageSkia() const;
117 SkBitmap* CopySkBitmap() const; 126 SkBitmap* CopySkBitmap() const;
118 #if defined(TOOLKIT_GTK) 127 #if defined(TOOLKIT_GTK)
119 GdkPixbuf* CopyGdkPixbuf() const; 128 GdkPixbuf* CopyGdkPixbuf() const;
120 #elif defined(OS_MACOSX) 129 #elif defined(OS_MACOSX)
121 NSImage* CopyNSImage() const; 130 NSImage* CopyNSImage() const;
122 #endif 131 #endif
123 132
124 // DEPRECATED ---------------------------------------------------------------- 133 // DEPRECATED ----------------------------------------------------------------
125 // Conversion handlers. These wrap the ToType() variants. 134 // Conversion handlers. These wrap the ToType() variants.
(...skipping 30 matching lines...) Expand all
156 // be cheaply copied. 165 // be cheaply copied.
157 scoped_refptr<internal::ImageStorage> storage_; 166 scoped_refptr<internal::ImageStorage> storage_;
158 167
159 friend class ::ImageTest; 168 friend class ::ImageTest;
160 friend class ::ImageMacTest; 169 friend class ::ImageMacTest;
161 }; 170 };
162 171
163 } // namespace gfx 172 } // namespace gfx
164 173
165 #endif // UI_GFX_IMAGE_IMAGE_H_ 174 #endif // UI_GFX_IMAGE_IMAGE_H_
OLDNEW
« no previous file with comments | « no previous file | ui/gfx/image/image.cc » ('j') | ui/gfx/image/image.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698