/* Copyright (c) 2012 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.
*/
/**
* Defines the PPB_Graphics2D
struct representing a 2D graphics
* context within the browser.
*/
label Chrome {
M14 = 1.0
};
/**
* PPB_Graphics2D
defines the interface for a 2D graphics context.
*/
[macro="PPB_GRAPHICS_2D_INTERFACE"]
interface PPB_Graphics2D {
/**
* Create() creates a 2D graphics context. The returned graphics context will
* not be bound to the module instance on creation (call BindGraphics() on
* the module instance to bind the returned graphics context to the module
* instance).
*
* @param[in] instance The module instance.
* @param[in] size The size of the graphic context.
* @param[in] is_always_opaque Set the is_always_opaque
flag to
* PP_TRUE
if you know that you will be painting only opaque
* data to this context. This option will disable blending when compositing
* the module with the web page, which might give higher performance on some
* computers.
*
* If you set is_always_opaque
, your alpha channel should always
* be set to 0xFF or there may be painting artifacts. The alpha values
* overwrite the destination alpha values without blending when
* is_always_opaque
is true.
*
* @return A PP_Resource
containing the 2D graphics context if
* successful or 0 if unsuccessful.
*/
PP_Resource Create(
[in] PP_Instance instance,
[in] PP_Size size,
[in] PP_Bool is_always_opaque);
/**
* IsGraphics2D() determines if the given resource is a valid
* Graphics2D
.
*
* @param[in] resource A Graphics2D
context resource.
*
* @return PP_TRUE if the given resource is a valid Graphics2D
,
* PP_FALSE
if it is an invalid resource or is a resource of
* another type.
*/
PP_Bool IsGraphics2D(
[in] PP_Resource resource);
/**
* Describe() retrieves the configuration for the given graphics context,
* filling the given values (which must not be NULL
).
*
* @param[in] resource The 2D Graphics resource.
* @param[in,out] size The size of the 2D graphics context in the browser.
* @param[in,out] is_always_opaque Identifies whether only opaque data
* will be painted.
*
* @return Returns PP_TRUE
on succes or PP_FALSE
if
* the resource is invalid. The output parameters will be set to 0 on a
* PP_FALSE
.
*/
PP_Bool Describe(
[in] PP_Resource graphics_2d,
[out] PP_Size size,
[out] PP_Bool is_always_opqaue);
/**
* PaintImageData() enqueues a paint of the given image into the context.
* This function has no effect until you call Flush() As a result, what
* counts is the contents of the bitmap when you call Flush(), not when
* you call this function.
*
* The provided image will be placed at top_left
from the top
* left of the context's internal backing store. Then the pixels contained
* in src_rect
will be copied into the backing store. This
* means that the rectangle being painted will be at src_rect
* offset by top_left
.
*
* The src_rect
is specified in the coordinate system of the
* image being painted, not the context. For the common case of copying the
* entire image, you may specify an empty src_rect
.
*
* The painted area of the source bitmap must fall entirely within the
* context. Attempting to paint outside of the context will result in an
* error. However, the source bitmap may fall outside the context, as long
* as the src_rect
subset of it falls entirely within the
* context.
*
* There are two methods most modules will use for painting. The first
* method is to generate a new ImageData
and then paint it. In
* this case, you'll set the location of your painting to
* top_left
and set src_rect
to NULL
.
* The second is that you're generating small invalid regions out of a larger
* bitmap representing your entire instance. In this case, you would set the
* location of your image to (0,0) and then set src_rect
to the
* pixels you changed.
*
* @param[in] resource The 2D Graphics resource.
* @param[in] image The ImageData
to be painted.
* @param[in] top_left A Point
representing the
* top_left
location where the ImageData
will be
* painted.
* @param[in] src_rect The rectangular area where the ImageData
* will be painted.
*/
void PaintImageData(
[in] PP_Resource graphics_2d,
[in] PP_Resource image_data,
[in] PP_Point top_left,
[in] PP_Rect src_rect);
/**
* Scroll() enqueues a scroll of the context's backing store. This
* function has no effect until you call Flush(). The data within the
* provided clipping rectangle will be shifted by (dx, dy) pixels.
*
* This function will result in some exposed region which will have undefined
* contents. The module should call PaintImageData() on these exposed regions
* to give the correct contents.
*
* The scroll can be larger than the area of the clipping rectangle, which
* means the current image will be scrolled out of the rectangle. This
* scenario is not an error but will result in a no-op.
*
* @param[in] graphics_2d The 2D Graphics resource.
* @param[in] clip The clipping rectangle.
* @param[in] amount The amount the area in the clipping rectangle will
* shifted.
*/
void Scroll(
[in] PP_Resource graphics_2d,
[in] PP_Rect clip_rect,
[in] PP_Point amount);
/**
* ReplaceContents() provides a slightly more efficient way to paint the
* entire module's image. Normally, calling PaintImageData() requires that
* the browser copy the pixels out of the image and into the graphics
* context's backing store. This function replaces the graphics context's
* backing store with the given image, avoiding the copy.
*
* The new image must be the exact same size as this graphics context. If the
* new image uses a different image format than the browser's native bitmap
* format (use PPB_ImageData.GetNativeImageDataFormat()
to
* retrieve the format), then a conversion will be done inside the browser
* which may slow the performance a little bit.
*
* Note: The new image will not be painted until you call
* Flush().
*
* After this call, you should take care to release your references to the
* image. If you paint to the image after ReplaceContents(), there is the
* possibility of significant painting artifacts because the page might use
* partially-rendered data when copying out of the backing store.
*
* In the case of an animation, you will want to allocate a new image for the
* next frame. It is best if you wait until the flush callback has executed
* before allocating this bitmap. This gives the browser the option of
* caching the previous backing store and handing it back to you (assuming
* the sizes match). In the optimal case, this means no bitmaps are allocated
* during the animation, and the backing store and "front buffer" (which the
* plugin is painting into) are just being swapped back and forth.
*
* @param[in] graphics_2d The 2D Graphics resource.
* @param[in] image The ImageData
to be painted.
*/
void ReplaceContents(
[in] PP_Resource graphics_2d,
[in] PP_Resource image_data);
/**
* Flush() flushes any enqueued paint, scroll, and replace commands to the
* backing store. This function actually executes the updates, and causes a
* repaint of the webpage, assuming this graphics context is bound to a module
* instance.
*
* Flush() runs in asynchronous mode. Specify a callback function and the
* argument for that callback function. The callback function will be
* executed on the calling thread when the image has been painted to the
* screen. While you are waiting for a flush callback, additional calls to
* Flush() will fail.
*
* Because the callback is executed (or thread unblocked) only when the
* instance's image is actually on the screen, this function provides
* a way to rate limit animations. By waiting until the image is on the
* screen before painting the next frame, you can ensure you're not
* flushing 2D graphics faster than the screen can be updated.
*
* Unbound contexts
* If the context is not bound to a module instance, you will
* still get a callback. The callback will execute after Flush() returns
* to avoid reentrancy. The callback will not wait until anything is
* painted to the screen because there will be nothing on the screen. The
* timing of this callback is not guaranteed and may be deprioritized by
* the browser because it is not affecting the user experience.
*
* Off-screen instances
* If the context is bound to an instance that is currently not visible (for
* example, scrolled out of view) it will behave like the "unbound context"
* case.
*
* Detaching a context
* If you detach a context from a module instance, any pending flush
* callbacks will be converted into the "unbound context" case.
*
* Released contexts
* A callback may or may not get called even if you have released all
* of your references to the context. This scenario can occur if there are
* internal references to the context suggesting it has not been internally
* destroyed (for example, if it is still bound to an instance) or due to
* other implementation details. As a result, you should be careful to
* check that flush callbacks are for the context you expect and that
* you're capable of handling callbacks for unreferenced contexts.
*
* Shutdown
* If a module instance is removed when a flush is pending, the
* callback will not be executed.
*
* @param[in] graphics_2d The 2D Graphics resource.
* @param[in] callback A CompletionCallback
to be called when
* the image has been painted on the screen.
*
* @return Returns PP_OK
on success or
* PP_ERROR_BADRESOURCE
if the graphics context is invalid,
* PP_ERROR_BADARGUMENT
if the callback is null and flush is
* being called from the main thread of the module, or
* PP_ERROR_INPROGRESS
if a flush is already pending that has
* not issued its callback yet. In the failure case, nothing will be updated
* and no callback will be scheduled.
*/
/* TODO(darin): We should ensure that the completion callback always runs, so
* that it is easier for consumers to manage memory referenced by a callback.
*
* TODO(): Add back in the synchronous mode description once we have support
* for it.
*/
int32_t Flush(
[in] PP_Resource graphics_2d,
[in] PP_CompletionCallback callback);
};