1 // Copyright (c) 2011 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 PPAPI_CPP_IMAGE_DATA_H_
6 #define PPAPI_CPP_IMAGE_DATA_H_
8 #include "ppapi/c/ppb_image_data.h"
9 #include "ppapi/cpp/point.h"
10 #include "ppapi/cpp/size.h"
11 #include "ppapi/cpp/resource.h"
14 /// This file defines the APIs for determining how a browser
15 /// handles image data.
20 class ImageData
: public Resource
{
22 /// Default constructor for creating an is_null() <code>ImageData</code>
26 /// A constructor used when you have received a <code>PP_Resource</code> as a
27 /// return value that has already been reference counted.
29 /// @param[in] resource A PP_Resource corresponding to image data.
30 ImageData(PassRef
, PP_Resource resource
);
32 /// The copy constructor for <code>ImageData</code>. This constructor
33 /// produces an <code>ImageData</code> object that shares the underlying
34 /// <code>Image</code> resource with <code>other</code>.
36 /// @param[in] other A pointer to an image data.
37 ImageData(const ImageData
& other
);
39 /// A constructor that allocates a new <code>ImageData</code> in the browser
40 /// with the provided parameters. The resulting object will be is_null() if
41 /// the allocation failed.
43 /// @param[in] instance The instance with which this resource will be
46 /// @param[in] format A PP_ImageDataFormat containing desired image format.
47 /// PP_ImageDataFormat is an enumeration of the different types of
48 /// image data formats. Refer to
49 /// <a href="../c/ppb__image__data_8h.html">
50 /// <code>ppb_image_data.h</code></a> for further information.
52 /// @param[in] size A pointer to a <code>Size</code> containing the image
55 /// @param[in] init_to_zero A bool used to determine transparency at
56 /// creation. Set the <code>init_to_zero</code> flag if you want the bitmap
57 /// initialized to transparent during the creation process. If this flag is
58 /// not set, the current contents of the bitmap will be undefined, and the
59 /// module should be sure to set all the pixels.
60 ImageData(const InstanceHandle
& instance
,
61 PP_ImageDataFormat format
,
65 /// This function decrements the reference count of this
66 /// <code>ImageData</code> and increments the reference count of the
67 /// <code>other</code> <code>ImageData</code>. This <code>ImageData</code>
68 /// shares the underlying image resource with <code>other</code>.
70 /// @param[in] other An other image data.
72 /// @return A new image data context.
73 ImageData
& operator=(const ImageData
& other
);
75 /// IsImageDataFormatSupported() returns <code>true</code> if the supplied
76 /// format is supported by the browser. Note:
77 /// <code>PP_IMAGEDATAFORMAT_BGRA_PREMUL</code> and
78 /// <code>PP_IMAGEDATAFORMAT_RGBA_PREMUL</code> formats are always supported.
79 /// Other image formats do not make this guarantee, and should be checked
80 /// first with IsImageDataFormatSupported() before using.
82 /// @param[in] format Image data format.
84 /// @return <code>true</code> if the format is supported by the browser.
85 static bool IsImageDataFormatSupported(PP_ImageDataFormat format
);
87 /// GetNativeImageDataFormat() determines the browser's preferred format for
88 /// images. Using this format guarantees no extra conversions will occur when
91 /// @return <code>PP_ImageDataFormat</code> containing the preferred format.
92 static PP_ImageDataFormat
GetNativeImageDataFormat();
94 /// A getter function for returning the current format for images.
96 /// @return <code>PP_ImageDataFormat</code> containing the preferred format.
97 PP_ImageDataFormat
format() const { return desc_
.format
; }
99 /// A getter function for returning the image size.
101 /// @return The image size in pixels.
102 pp::Size
size() const { return desc_
.size
; }
104 /// A getter function for returning the row width in bytes.
106 /// @return The row width in bytes.
107 int32_t stride() const { return desc_
.stride
; }
109 /// A getter function for returning a raw pointer to the image pixels.
111 /// @return A raw pointer to the image pixels.
112 void* data() const { return data_
; }
114 /// This function is used retrieve the address of the given pixel for 32-bit
117 /// @param[in] coord A <code>Point</code> representing the x and y
118 /// coordinates for a specific pixel.
120 /// @return The address for the pixel.
121 const uint32_t* GetAddr32(const Point
& coord
) const;
123 /// This function is used retrieve the address of the given pixel for 32-bit
126 /// @param[in] coord A <code>Point</code> representing the x and y
127 /// coordinates for a specific pixel.
129 /// @return The address for the pixel.
130 uint32_t* GetAddr32(const Point
& coord
);
135 PP_ImageDataDesc desc_
;
141 #endif // PPAPI_CPP_IMAGE_DATA_H_