blob: 6ea25066650ab34901c1d99b317d7ec2e9108326 [file] [log] [blame]
/* Copyright (c) 2010 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_C_DEV_PP_GRAPHICS_3D_DEV_H_
#define PPAPI_C_DEV_PP_GRAPHICS_3D_DEV_H_
#include "ppapi/c/pp_stdint.h"
// TODO(alokp): Using PP_Graphics3D prefix is making these enum names rather
// long. Can we just use PP_GL? It will be a nice short replacement of EGL.
// In which case we should rename associated classes as - PP_GL, PP_GLContext,
// PP_GLContext, PP_GLSurface, PP_GLConfig, and PP_OpenGLES2.
//
// Another option is to rename Surface3D and Context3D to Graphics3DSurface
// and Graphics3DContext respectively But this does not make the names
// any shorter.
enum PP_Graphics3DError_Dev {
PP_GRAPHICS3DERROR_BAD_ACCESS = 0x3002,
PP_GRAPHICS3DERROR_BAD_ATTRIBUTE = 0x3004,
PP_GRAPHICS3DERROR_BAD_CONFIG = 0x3005,
PP_GRAPHICS3DERROR_BAD_CONTEXT = 0x3006,
PP_GRAPHICS3DERROR_BAD_MATCH = 0x3009,
PP_GRAPHICS3DERROR_BAD_SURFACE = 0x300D,
PP_GRAPHICS3DERROR_CONTEXT_LOST = 0x300E
};
enum PP_Graphics3DString_Dev {
PP_GRAPHICS3DSTRING_VENDOR = 0x3053,
PP_GRAPHICS3DSTRING_VERSION = 0x3054,
// Which extensions are supported.
PP_GRAPHICS3DSTRING_EXTENSIONS = 0x3055,
// Which client rendering APIs are supported.
PP_GRAPHICS3DSTRING_CLIENT_APIS = 0x308D
};
enum PP_Graphics3DAttrib_Dev {
// Total color component bits in the color buffer.
PP_GRAPHICS3DATTRIB_BUFFER_SIZE = 0x3020,
// Bits of Alpha in the color buffer.
PP_GRAPHICS3DATTRIB_ALPHA_SIZE = 0x3021,
// Bits of Blue in the color buffer.
PP_GRAPHICS3DATTRIB_BLUE_SIZE = 0x3022,
// Bits of Green in the color buffer.
PP_GRAPHICS3DATTRIB_GREEN_SIZE = 0x3023,
// Bits of Red in the color buffer.
PP_GRAPHICS3DATTRIB_RED_SIZE = 0x3024,
// Bits of Z in the depth buffer.
PP_GRAPHICS3DATTRIB_DEPTH_SIZE = 0x3025,
// Bits of Stencil in the stencil buffer.
PP_GRAPHICS3DATTRIB_STENCIL_SIZE = 0x3026,
// Any caveats for the configuration.
PP_GRAPHICS3DATTRIB_CONFIG_CAVEAT = 0x3027,
// Unique EGLConfig identifier.
PP_GRAPHICS3DATTRIB_CONFIG_ID = 0x3028,
// Maximum height of surface.
PP_GRAPHICS3DATTRIB_MAX_SURFACE_HEIGHT = 0x302A,
// Maximum size of surface.
PP_GRAPHICS3DATTRIB_MAX_SURFACE_PIXELS = 0x302B,
// Maximum width of surface.
PP_GRAPHICS3DATTRIB_MAX_SURFACE_WIDTH = 0x302C,
// Number of samples per pixel.
PP_GRAPHICS3DATTRIB_SAMPLES = 0x3031,
// Number of multisample buffers.
PP_GRAPHICS3DATTRIB_SAMPLE_BUFFERS = 0x3032,
// Which types of EGL surfaces are supported.
PP_GRAPHICS3DATTRIB_SURFACE_TYPE = 0x3033,
// Type of transparency supported.
PP_GRAPHICS3DATTRIB_TRANSPARENT_TYPE = 0x3034,
// Transparent blue value.
PP_GRAPHICS3DATTRIB_TRANSPARENT_BLUE_VALUE = 0x3035,
// Transparent green value.
PP_GRAPHICS3DATTRIB_TRANSPARENT_GREEN_VALUE = 0x3036,
// Transparent red value.
PP_GRAPHICS3DATTRIB_TRANSPARENT_RED_VALUE = 0x3037,
// Attrib list terminator.
PP_GRAPHICS3DATTRIB_NONE = 0x3038,
// TODO(alokp): Find out if we can support swap intervals. Remove them if not.
// Minimum swap interval.
PP_GRAPHICS3DATTRIB_MIN_SWAP_INTERVAL = 0x303B,
// Maximum swap interval.
PP_GRAPHICS3DATTRIB_MAX_SWAP_INTERVAL = 0x303C,
// Bits of Luminance in the color buffer.
PP_GRAPHICS3DATTRIB_LUMINANCE_SIZE = 0x303D,
// Bits of Alpha Mask in the mask buffer.
PP_GRAPHICS3DATTRIB_ALPHA_MASK_SIZE = 0x303E,
// Color buffer type.
PP_GRAPHICS3DATTRIB_COLOR_BUFFER_TYPE = 0x303F,
// Which client APIs are supported.
PP_GRAPHICS3DATTRIB_RENDERABLE_TYPE = 0x3040,
// Whether contexts created with this config are conformant.
PP_GRAPHICS3DATTRIB_CONFORMANT = 0x3042,
// Surface-specific attributes.
// Height of surface in pixels.
PP_GRAPHICS3DATTRIB_HEIGHT = 0x3056,
// Width of surface in pixels.
PP_GRAPHICS3DATTRIB_WIDTH = 0x3057,
// If true, largest possible surface is created.
PP_GRAPHICS3DATTRIB_LARGEST_SURFACE = 0x3058,
// The buffer which client API renders to.
PP_GRAPHICS3DATTRIB_RENDER_BUFFER = 0x3086,
// Specifies the effect on the color buffer of posting a surface
// with SwapBuffers.
PP_GRAPHICS3DATTRIB_SWAP_BEHAVIOR = 0x3093,
// Specifies the filter to use when resolving the multisample buffer.
PP_GRAPHICS3DATTRIB_MULTISAMPLE_RESOLVE = 0x3099,
// Context-specific attributes.
// Which client API the context supports.
PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_TYPE = 0x3097,
// Version of OpenGL ES supported by a context.
// An attribute value of 1 specifies OpenGL ES 1.x.
// An attribute value of 2 specifies OpenGL ES 2.x.
// The default value for PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_VERSION is 1.
// This attribute is only meaningful for an OpenGL ES context.
PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_VERSION = 0x3098
};
enum PP_Graphics3DAttribValue_Dev {
PP_GRAPHICS3DATTRIBVALUE_NONE = 0x3038,
// PP_GRAPHICS3DATTRIB_CONFIG_CAVEAT values.
PP_GRAPHICS3DATTRIBVALUE_SLOW_CONFIG = 0x3050,
PP_GRAPHICS3DATTRIBVALUE_NON_CONFORMANT_CONFIG = 0x3051,
// PP_GRAPHICS3DATTRIB_TRANSPARENT_TYPE values.
PP_GRAPHICS3DATTRIBVALUE_TRANSPARENT_RGB = 0x3052,
// PP_GRAPHICS3DATTRIB_COLOR_BUFFER_TYPE values.
PP_GRAPHICS3DATTRIBVALUE_RGB_BUFFER = 0x308E,
PP_GRAPHICS3DATTRIBVALUE_LUMINANCE_BUFFER = 0x308F,
// PP_GRAPHICS3DATTRIB_SURFACE_TYPE mask bits.
// Indicates if box filter (PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_BOX)
// for resolving the multisample buffer is supported.
PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_BOX_BIT = 0x0200,
PP_GRAPHICS3DATTRIBVALUE_SWAP_BEHAVIOR_PRESERVED_BIT = 0x0400,
// PP_GRAPHICS3DATTRIB_RENDERABLE_TYPE mask bits.
PP_GRAPHICS3DATTRIBVALUE_OPENGL_ES_BIT = 0x0001,
PP_GRAPHICS3DATTRIBVALUE_OPENGL_ES2_BIT = 0x0004,
PP_GRAPHICS3DATTRIBVALUE_OPENGL_BIT = 0x0008,
// PP_GRAPHICS3DATTRIB_RENDER_BUFFER values.
// The default value is PP_GRAPHICS3DATTRIBVALUE_BACK_BUFFER.
// Surface contains two color buffers and client APIs render into
// the back buffer.
PP_GRAPHICS3DATTRIBVALUE_BACK_BUFFER = 0x3084,
// Surface contains a single color buffer.
PP_GRAPHICS3DATTRIBVALUE_SINGLE_BUFFER = 0x3085,
// PP_GRAPHICS3DATTRIB_SWAP_BEHAVIOR values.
// The initial value is chosen by the implementation.
// Indicates that color buffer contents are unaffected.
PP_GRAPHICS3DATTRIBVALUE_BUFFER_PRESERVED = 0x3094,
// Indicates that color buffer contents may be destroyed or changed.
PP_GRAPHICS3DATTRIBVALUE_BUFFER_DESTROYED = 0x3095,
// PP_GRAPHICS3DATTRIB_MULTISAMPLE_RESOLVE values.
// The default value is PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_DEFAULT.
// The default implementation-defined filtering method.
PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_DEFAULT = 0x309A,
// One-pixel wide box filter placing equal weighting on all
// multisample values.
PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_BOX = 0x309B,
// PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_TYPE values.
PP_GRAPHICS3DATTRIBVALUE_OPENGL_ES_API = 0x30A0,
PP_GRAPHICS3DATTRIBVALUE_OPENGL_API = 0x30A2
};
typedef int32_t PP_Config3D_Dev;
#endif // PPAPI_C_DEV_PP_GRAPHICS_3D_DEV_H_