OLD | NEW |
(Empty) | |
| 1 // Copyright (c) 2010 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. |
| 4 |
| 5 #ifndef PPAPI_C_DEV_PP_GRAPHICS_3D_DEV_H_ |
| 6 #define PPAPI_C_DEV_PP_GRAPHICS_3D_DEV_H_ |
| 7 |
| 8 // TODO(alokp): Using PP_Graphics3D prefix is making these enum names rather |
| 9 // long. Can we just use PP_GL? It will be a nice short replacement of EGL. |
| 10 // In which case we should rename associated classes as - PP_GL, PP_GLContext, |
| 11 // PP_GLContext, PP_GLSurface, PP_GLConfig, and PP_OpenGLES2. |
| 12 // |
| 13 // Another option is to rename Surface3D and Context3D to Graphics3DSurface |
| 14 // and Graphics3DContext respectively But this does not make the names |
| 15 // any shorter. |
| 16 |
| 17 enum PP_Graphics3DError_Dev { |
| 18 PP_GRAPHICS3DERROR_BAD_ACCESS = 0x3002, |
| 19 PP_GRAPHICS3DERROR_BAD_ATTRIBUTE = 0x3004, |
| 20 PP_GRAPHICS3DERROR_BAD_CONFIG = 0x3005, |
| 21 PP_GRAPHICS3DERROR_BAD_CONTEXT = 0x3006, |
| 22 PP_GRAPHICS3DERROR_BAD_MATCH = 0x3009, |
| 23 PP_GRAPHICS3DERROR_BAD_SURFACE = 0x300D, |
| 24 PP_GRAPHICS3DERROR_CONTEXT_LOST = 0x300E |
| 25 }; |
| 26 |
| 27 enum PP_Graphics3DString_Dev { |
| 28 PP_GRAPHICS3DSTRING_VENDOR = 0x3053, |
| 29 PP_GRAPHICS3DSTRING_VERSION = 0x3054, |
| 30 // Which extensions are supported. |
| 31 PP_GRAPHICS3DSTRING_EXTENSIONS = 0x3055, |
| 32 // Which client rendering APIs are supported. |
| 33 PP_GRAPHICS3DSTRING_CLIENT_APIS = 0x308D |
| 34 }; |
| 35 |
| 36 enum PP_Graphics3DAttrib_Dev { |
| 37 // Total color component bits in the color buffer. |
| 38 PP_GRAPHICS3DATTRIB_BUFFER_SIZE = 0x3020, |
| 39 // Bits of Alpha in the color buffer. |
| 40 PP_GRAPHICS3DATTRIB_ALPHA_SIZE = 0x3021, |
| 41 // Bits of Blue in the color buffer. |
| 42 PP_GRAPHICS3DATTRIB_BLUE_SIZE = 0x3022, |
| 43 // Bits of Green in the color buffer. |
| 44 PP_GRAPHICS3DATTRIB_GREEN_SIZE = 0x3023, |
| 45 // Bits of Red in the color buffer. |
| 46 PP_GRAPHICS3DATTRIB_RED_SIZE = 0x3024, |
| 47 // Bits of Z in the depth buffer. |
| 48 PP_GRAPHICS3DATTRIB_DEPTH_SIZE = 0x3025, |
| 49 // Bits of Stencil in the stencil buffer. |
| 50 PP_GRAPHICS3DATTRIB_STENCIL_SIZE = 0x3026, |
| 51 // Any caveats for the configuration. |
| 52 PP_GRAPHICS3DATTRIB_CONFIG_CAVEAT = 0x3027, |
| 53 // Unique EGLConfig identifier. |
| 54 PP_GRAPHICS3DATTRIB_CONFIG_ID = 0x3028, |
| 55 // Maximum height of surface. |
| 56 PP_GRAPHICS3DATTRIB_MAX_SURFACE_HEIGHT = 0x302A, |
| 57 // Maximum size of surface. |
| 58 PP_GRAPHICS3DATTRIB_MAX_SURFACE_PIXELS = 0x302B, |
| 59 // Maximum width of surface. |
| 60 PP_GRAPHICS3DATTRIB_MAX_SURFACE_WIDTH = 0x302C, |
| 61 // Number of samples per pixel. |
| 62 PP_GRAPHICS3DATTRIB_SAMPLES = 0x3031, |
| 63 // Number of multisample buffers. |
| 64 PP_GRAPHICS3DATTRIB_SAMPLE_BUFFERS = 0x3032, |
| 65 // Which types of EGL surfaces are supported. |
| 66 PP_GRAPHICS3DATTRIB_SURFACE_TYPE = 0x3033, |
| 67 // Type of transparency supported. |
| 68 PP_GRAPHICS3DATTRIB_TRANSPARENT_TYPE = 0x3034, |
| 69 // Transparent blue value. |
| 70 PP_GRAPHICS3DATTRIB_TRANSPARENT_BLUE_VALUE = 0x3035, |
| 71 // Transparent green value. |
| 72 PP_GRAPHICS3DATTRIB_TRANSPARENT_GREEN_VALUE = 0x3036, |
| 73 // Transparent red value. |
| 74 PP_GRAPHICS3DATTRIB_TRANSPARENT_RED_VALUE = 0x3037, |
| 75 // Attrib list terminator. |
| 76 PP_GRAPHICS3DATTRIB_NONE = 0x3038, |
| 77 // TODO(alokp): Find out if we can support swap intervals. Remove them if not. |
| 78 // Minimum swap interval. |
| 79 PP_GRAPHICS3DATTRIB_MIN_SWAP_INTERVAL = 0x303B, |
| 80 // Maximum swap interval. |
| 81 PP_GRAPHICS3DATTRIB_MAX_SWAP_INTERVAL = 0x303C, |
| 82 // Bits of Luminance in the color buffer. |
| 83 PP_GRAPHICS3DATTRIB_LUMINANCE_SIZE = 0x303D, |
| 84 // Bits of Alpha Mask in the mask buffer. |
| 85 PP_GRAPHICS3DATTRIB_ALPHA_MASK_SIZE = 0x303E, |
| 86 // Color buffer type. |
| 87 PP_GRAPHICS3DATTRIB_COLOR_BUFFER_TYPE = 0x303F, |
| 88 // Which client APIs are supported. |
| 89 PP_GRAPHICS3DATTRIB_RENDERABLE_TYPE = 0x3040, |
| 90 // Whether contexts created with this config are conformant. |
| 91 PP_GRAPHICS3DATTRIB_CONFORMANT = 0x3042, |
| 92 |
| 93 // Surface-specific attributes. |
| 94 // Height of surface in pixels. |
| 95 PP_GRAPHICS3DATTRIB_HEIGHT = 0x3056, |
| 96 // Width of surface in pixels. |
| 97 PP_GRAPHICS3DATTRIB_WIDTH = 0x3057, |
| 98 // If true, largest possible surface is created. |
| 99 PP_GRAPHICS3DATTRIB_LARGEST_SURFACE = 0x3058, |
| 100 // The buffer which client API renders to. |
| 101 PP_GRAPHICS3DATTRIB_RENDER_BUFFER = 0x3086, |
| 102 // Specifies the effect on the color buffer of posting a surface |
| 103 // with SwapBuffers. |
| 104 PP_GRAPHICS3DATTRIB_SWAP_BEHAVIOR = 0x3093, |
| 105 // Specifies the filter to use when resolving the multisample buffer. |
| 106 PP_GRAPHICS3DATTRIB_MULTISAMPLE_RESOLVE = 0x3099, |
| 107 |
| 108 // Context-specific attributes. |
| 109 // Which client API the context supports. |
| 110 PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_TYPE = 0x3097, |
| 111 // Version of OpenGL ES supported by a context. |
| 112 // An attribute value of 1 specifies OpenGL ES 1.x. |
| 113 // An attribute value of 2 specifies OpenGL ES 2.x. |
| 114 // The default value for PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_VERSION is 1. |
| 115 // This attribute is only meaningful for an OpenGL ES context. |
| 116 PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_VERSION = 0x3098 |
| 117 }; |
| 118 |
| 119 enum PP_Graphics3DAttribValue_Dev { |
| 120 PP_GRAPHICS3DATTRIBVALUE_NONE = 0x3038, |
| 121 |
| 122 // PP_GRAPHICS3DATTRIB_CONFIG_CAVEAT values. |
| 123 PP_GRAPHICS3DATTRIBVALUE_SLOW_CONFIG = 0x3050, |
| 124 PP_GRAPHICS3DATTRIBVALUE_NON_CONFORMANT_CONFIG = 0x3051, |
| 125 |
| 126 // PP_GRAPHICS3DATTRIB_TRANSPARENT_TYPE values. |
| 127 PP_GRAPHICS3DATTRIBVALUE_TRANSPARENT_RGB = 0x3052, |
| 128 |
| 129 // PP_GRAPHICS3DATTRIB_COLOR_BUFFER_TYPE values. |
| 130 PP_GRAPHICS3DATTRIBVALUE_RGB_BUFFER = 0x308E, |
| 131 PP_GRAPHICS3DATTRIBVALUE_LUMINANCE_BUFFER = 0x308F, |
| 132 |
| 133 // PP_GRAPHICS3DATTRIB_SURFACE_TYPE mask bits. |
| 134 // Indicates if box filter (PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_BOX) |
| 135 // for resolving the multisample buffer is supported. |
| 136 PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_BOX_BIT = 0x0200, |
| 137 PP_GRAPHICS3DATTRIBVALUE_SWAP_BEHAVIOR_PRESERVED_BIT = 0x0400, |
| 138 |
| 139 // PP_GRAPHICS3DATTRIB_RENDERABLE_TYPE mask bits. |
| 140 PP_GRAPHICS3DATTRIBVALUE_OPENGL_ES_BIT = 0x0001, |
| 141 PP_GRAPHICS3DATTRIBVALUE_OPENGL_ES2_BIT = 0x0004, |
| 142 PP_GRAPHICS3DATTRIBVALUE_OPENGL_BIT = 0x0008, |
| 143 |
| 144 // PP_GRAPHICS3DATTRIB_RENDER_BUFFER values. |
| 145 // The default value is PP_GRAPHICS3DATTRIBVALUE_BACK_BUFFER. |
| 146 // Surface contains two color buffers and client APIs render into |
| 147 // the back buffer. |
| 148 PP_GRAPHICS3DATTRIBVALUE_BACK_BUFFER = 0x3084, |
| 149 // Surface contains a single color buffer. |
| 150 PP_GRAPHICS3DATTRIBVALUE_SINGLE_BUFFER = 0x3085, |
| 151 |
| 152 // PP_GRAPHICS3DATTRIB_SWAP_BEHAVIOR values. |
| 153 // The initial value is chosen by the implementation. |
| 154 // Indicates that color buffer contents are unaffected. |
| 155 PP_GRAPHICS3DATTRIBVALUE_BUFFER_PRESERVED = 0x3094, |
| 156 // Indicates that color buffer contents may be destroyed or changed. |
| 157 PP_GRAPHICS3DATTRIBVALUE_BUFFER_DESTROYED = 0x3095, |
| 158 |
| 159 // PP_GRAPHICS3DATTRIB_MULTISAMPLE_RESOLVE values. |
| 160 // The default value is PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_DEFAULT. |
| 161 // The default implementation-defined filtering method. |
| 162 PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_DEFAULT = 0x309A, |
| 163 // One-pixel wide box filter placing equal weighting on all |
| 164 // multisample values. |
| 165 PP_GRAPHICS3DATTRIBVALUE_MULTISAMPLE_RESOLVE_BOX = 0x309B, |
| 166 |
| 167 // PP_GRAPHICS3DATTRIB_CONTEXT_CLIENT_TYPE values. |
| 168 PP_GRAPHICS3DATTRIBVALUE_OPENGL_ES_API = 0x30A0, |
| 169 PP_GRAPHICS3DATTRIBVALUE_OPENGL_API = 0x30A2, |
| 170 }; |
| 171 |
| 172 typedef int32_t PP_Graphics3DConfig_Dev; |
| 173 |
| 174 #endif // PPAPI_C_DEV_PP_GRAPHICS_3D_DEV_H_ |
OLD | NEW |