
Review URL: https://chromiumcodereview.appspot.com/9381010 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@123795 0039d316-1c4b-4281-b951-d872f2087c98
130 lines
4.5 KiB
C++
130 lines
4.5 KiB
C++
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef PPAPI_CPP_IMAGE_DATA_H_
|
|
#define PPAPI_CPP_IMAGE_DATA_H_
|
|
|
|
#include "ppapi/c/ppb_image_data.h"
|
|
#include "ppapi/cpp/point.h"
|
|
#include "ppapi/cpp/size.h"
|
|
#include "ppapi/cpp/resource.h"
|
|
|
|
/// @file
|
|
/// This file defines the APIs for determining how a browser
|
|
/// handles image data.
|
|
namespace pp {
|
|
|
|
class InstanceHandle;
|
|
|
|
class ImageData : public Resource {
|
|
public:
|
|
/// Default constructor for creating an is_null() <code>ImageData</code>
|
|
/// object.
|
|
ImageData();
|
|
|
|
/// A constructor used when you have received a <code>PP_Resource</code> as a
|
|
/// return value that has already been reference counted.
|
|
///
|
|
/// @param[in] resource A PP_Resource corresponding to image data.
|
|
ImageData(PassRef, PP_Resource resource);
|
|
|
|
/// The copy constructor for <code>ImageData</code>. This constructor
|
|
/// produces an <code>ImageData</code> object that shares the underlying
|
|
/// <code>Image</code> resource with <code>other</code>.
|
|
///
|
|
/// @param[in] other A pointer to an image data.
|
|
ImageData(const ImageData& other);
|
|
|
|
/// A constructor that allocates a new <code>ImageData</code> in the browser
|
|
/// with the provided parameters. The resulting object will be is_null() if
|
|
/// the allocation failed.
|
|
///
|
|
/// @param[in] instance The instance with which this resource will be
|
|
/// associated.
|
|
///
|
|
/// @param[in] format A PP_ImageDataFormat containing desired image format.
|
|
/// PP_ImageDataFormat is an enumeration of the different types of
|
|
/// image data formats. Refer to
|
|
/// <a href="../pepperc/ppb__image__data_8h.html">
|
|
/// <code>ppb_image_data.h</code></a> for further information.
|
|
///
|
|
/// @param[in] size A pointer to a <code>Size</code> containing the image
|
|
/// size.
|
|
///
|
|
/// @param[in] init_to_zero A bool used to determine transparency at
|
|
/// creation. Set the <code>init_to_zero</code> flag if you want the bitmap
|
|
/// initialized to transparent during the creation process. If this flag is
|
|
/// not set, the current contents of the bitmap will be undefined, and the
|
|
/// module should be sure to set all the pixels.
|
|
ImageData(const InstanceHandle& instance,
|
|
PP_ImageDataFormat format,
|
|
const Size& size,
|
|
bool init_to_zero);
|
|
|
|
/// This function decrements the reference count of this
|
|
/// <code>ImageData</code> and increments the reference count of the
|
|
/// <code>other</code> <code>ImageData</code>. This <code>ImageData</code>
|
|
/// shares the underlying image resource with <code>other</code>.
|
|
///
|
|
/// @param[in] other An other image data.
|
|
///
|
|
/// @return A new image data context.
|
|
ImageData& operator=(const ImageData& other);
|
|
|
|
/// GetNativeImageDataFormat() determines the browser's preferred format for
|
|
/// images. Using this format guarantees no extra conversions will occur when
|
|
/// painting.
|
|
///
|
|
/// @return <code>PP_ImageDataFormat</code> containing the preferred format.
|
|
static PP_ImageDataFormat GetNativeImageDataFormat();
|
|
|
|
/// A getter function for returning the current format for images.
|
|
///
|
|
/// @return <code>PP_ImageDataFormat</code> containing the preferred format.
|
|
PP_ImageDataFormat format() const { return desc_.format; }
|
|
|
|
/// A getter function for returning the image size.
|
|
///
|
|
/// @return The image size in pixels.
|
|
pp::Size size() const { return desc_.size; }
|
|
|
|
/// A getter function for returning the row width in bytes.
|
|
///
|
|
/// @return The row width in bytes.
|
|
int32_t stride() const { return desc_.stride; }
|
|
|
|
/// A getter function for returning a raw pointer to the image pixels.
|
|
///
|
|
/// @return A raw pointer to the image pixels.
|
|
void* data() const { return data_; }
|
|
|
|
/// This function is used retrieve the address of the given pixel for 32-bit
|
|
/// pixel formats.
|
|
///
|
|
/// @param[in] coord A <code>Point</code> representing the x and y
|
|
/// coordinates for a specific pixel.
|
|
///
|
|
/// @return The address for the pixel.
|
|
const uint32_t* GetAddr32(const Point& coord) const;
|
|
|
|
/// This function is used retrieve the address of the given pixel for 32-bit
|
|
/// pixel formats.
|
|
///
|
|
/// @param[in] coord A <code>Point</code> representing the x and y
|
|
/// coordinates for a specific pixel.
|
|
///
|
|
/// @return The address for the pixel.
|
|
uint32_t* GetAddr32(const Point& coord);
|
|
|
|
private:
|
|
void InitData();
|
|
|
|
PP_ImageDataDesc desc_;
|
|
void* data_;
|
|
};
|
|
|
|
} // namespace pp
|
|
|
|
#endif // PPAPI_CPP_IMAGE_DATA_H_
|