/* Copyright 2014 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.
*/
/* From ppb_compositor.idl modified Tue Jun 3 12:44:44 2014. */
#ifndef PPAPI_C_PPB_COMPOSITOR_H_
#define PPAPI_C_PPB_COMPOSITOR_H_
#include "ppapi/c/pp_bool.h"
#include "ppapi/c/pp_completion_callback.h"
#include "ppapi/c/pp_instance.h"
#include "ppapi/c/pp_macros.h"
#include "ppapi/c/pp_resource.h"
#include "ppapi/c/pp_stdint.h"
#define PPB_COMPOSITOR_INTERFACE_0_1 "PPB_Compositor;0.1" /* dev */
/**
* @file
*/
/**
* @addtogroup Interfaces
* @{
*/
/**
* Defines the PPB_Compositor
interface. Used for setting
* PPB_CompositorLayer
layers to the Chromium compositor for
* compositing. This allows a plugin to combine different sources of visual
* data efficiently, such as PPB_ImageData
images and
* OpenGL textures. See also PPB_CompositorLayer
for more
* information.
* This interface is still in development (Dev API status) and may change,
* so is only supported on Dev channel and Canary currently.
*
* Example usage from plugin code:
*
* Setup:
* @code
* PP_Resource compositor;
* compositor = compositor_if->Create(instance);
* instance_if->BindGraphics(instance, compositor);
* @endcode
*
* Setup layer stack:
* @code
* PP_Resource color_layer = compositor_if->AddLayer(compositor);
* PP_Resource texture_layer = compositor_if->AddLayer(compositor);
* @endcode
*
* Present one frame:
* layer_if->SetColor(color_layer, 255, 255, 0, 255, PP_MakeSize(400, 400));
* PP_CompletionCallback release_callback = {
* TextureReleasedCallback, 0, PP_COMPLETIONCALLBACK_FLAG_NONE,
* };
* layer_if->SetTexture(texture_layer, graphics3d, texture_id,
* PP_MakeSize(300, 300), release_callback);
*
* PP_CompletionCallback callback = {
* DidFinishCommitLayersCallback,
* (void*) texture_id,
* PP_COMPLETIONCALLBACK_FLAG_NONE,
* };
* compositor_if->CommitLayers(compositor, callback);
* @endcode
*
* release callback
* void ReleaseCallback(int32_t result, void* user_data) {
* if (result == PP_OK) {
* uint32_t texture_id = (uint32_t) user_data;
* // reuse the texture or delete it.
* }
* }
*
* Shutdown:
* @code
* core->ReleaseResource(color_layer);
* core->ReleaseResource(texture_layer);
* core->ReleaseResource(compositor);
* @endcode
*/
struct PPB_Compositor_0_1 { /* dev */
/**
* Determines if a resource is a compositor resource.
*
* @param[in] resource The PP_Resource
to test.
*
* @return A PP_Bool
with PP_TRUE
if the given
* resource is a compositor resource or PP_FALSE
otherwise.
*/
PP_Bool (*IsCompositor)(PP_Resource resource);
/**
* Creates a Compositor resource.
*
* @param[in] instance A PP_Instance
identifying one instance
* of a module.
*
* @return A PP_Resource
containing the compositor resource if
* successful or 0 otherwise.
*/
PP_Resource (*Create)(PP_Instance instance);
/**
* Creates a new PPB_CompositorLayer
and adds it to the end
* of the layer stack. A PP_Resource
containing the layer is
* returned. It is uninitialized, SetColor()
,
* SetTexture
or SetImage
should be used to
* initialize it. The layer will appear above other pre-existing layers.
* If ResetLayers
is called or the PPB_Compositor
is
* released, the returned layer will be invalidated, and any further calls on
* the layer will return PP_ERROR_BADRESOURCE
.
*
* param[in] compositor A PP_Resource
corresponding to
* a compositor layer resource.
*
* @return A PP_Resource
containing the compositor layer
* resource if successful or 0 otherwise.
*/
PP_Resource (*AddLayer)(PP_Resource compositor);
/**
* Commits layers added by AddLayer()
to the chromium compositor.
*
* param[in] compositor A PP_Resource
corresponding to
* a compositor layer resource.
* @param[in] cc A PP_CompletionCallback
to be called when
* layers have been represented on screen.
*
* @return An int32_t containing a result code from pp_errors.h
.
*/
int32_t (*CommitLayers)(PP_Resource compositor,
struct PP_CompletionCallback cc);
/**
* Resets layers added by AddLayer()
.
*
* param[in] compositor A PP_Resource
corresponding to
* a compositor layer resource.
*
* @return An int32_t containing a result code from pp_errors.h
.
*/
int32_t (*ResetLayers)(PP_Resource compositor);
};
/**
* @}
*/
#endif /* PPAPI_C_PPB_COMPOSITOR_H_ */