OLD | NEW |
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef PPAPI_C_DEV_PPB_GRAPHICS_3D_DEV_H_ | 5 #ifndef PPAPI_C_DEV_PPB_GRAPHICS_3D_DEV_H_ |
6 #define PPAPI_C_DEV_PPB_GRAPHICS_3D_DEV_H_ | 6 #define PPAPI_C_DEV_PPB_GRAPHICS_3D_DEV_H_ |
7 | 7 |
8 #include "ppapi/c/pp_bool.h" | 8 #include "ppapi/c/pp_bool.h" |
| 9 #include "ppapi/c/pp_completion_callback.h" |
9 #include "ppapi/c/pp_instance.h" | 10 #include "ppapi/c/pp_instance.h" |
10 #include "ppapi/c/pp_module.h" | 11 #include "ppapi/c/pp_module.h" |
11 #include "ppapi/c/pp_resource.h" | 12 #include "ppapi/c/pp_resource.h" |
12 #include "ppapi/c/pp_stdint.h" | 13 #include "ppapi/c/pp_stdint.h" |
13 | 14 |
14 // Example usage from plugin code: | 15 // Example usage from plugin code: |
15 // | 16 // |
16 // PP_Resource context = device->Create(module, config, contextAttribList); | 17 // PP_Resource context = device->Create(module, config, contextAttribList); |
17 // CHECK(context); | 18 // CHECK(context); |
18 // | 19 // |
19 // // Present one frame. | 20 // // Present one frame. |
20 // CHECK(device->MakeCurrent(context)); | 21 // CHECK(device->MakeCurrent(context)); |
21 // glClear(GL_COLOR_BUFFER); | 22 // glClear(GL_COLOR_BUFFER); |
22 // CHECK(device->MakeCurrent(NULL)); | 23 // CHECK(device->MakeCurrent(NULL)); |
23 // CHECK(device->SwapBuffers(context)); | 24 // CHECK(device->SwapBuffers(context, callback)); |
24 // | 25 // |
25 // // Shutdown. | 26 // // Shutdown. |
26 // core->ReleaseResource(context); | 27 // core->ReleaseResource(context); |
27 | 28 |
28 #define PPB_GRAPHICS_3D_DEV_INTERFACE "PPB_Graphics3D(Dev);0.3" | 29 #define PPB_GRAPHICS_3D_DEV_INTERFACE "PPB_Graphics3D(Dev);0.4" |
29 | 30 |
30 // These are the same error codes as used by EGL. | 31 // These are the same error codes as used by EGL. |
31 enum { | 32 enum { |
32 PP_GRAPHICS_3D_ERROR_SUCCESS = 0x3000, | 33 PP_GRAPHICS_3D_ERROR_SUCCESS = 0x3000, |
33 PP_GRAPHICS_3D_ERROR_NOT_INITIALIZED = 0x3001, | 34 PP_GRAPHICS_3D_ERROR_NOT_INITIALIZED = 0x3001, |
34 PP_GRAOHICS_3D_ERROR_BAD_CONTEXT = 0x3006, | 35 PP_GRAOHICS_3D_ERROR_BAD_CONTEXT = 0x3006, |
35 PP_GRAPHICS_3D_ERROR_BAD_PARAMETER = 0x300C, | 36 PP_GRAPHICS_3D_ERROR_BAD_PARAMETER = 0x300C, |
36 PP_GRAPHICS_3D_ERROR_CONTEXT_LOST = 0x300E | 37 PP_GRAPHICS_3D_ERROR_CONTEXT_LOST = 0x300E |
37 }; | 38 }; |
38 | 39 |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
82 // on success, PP_FALSE on failure. | 83 // on success, PP_FALSE on failure. |
83 PP_Bool (*MakeCurent)(PP_Resource context); | 84 PP_Bool (*MakeCurent)(PP_Resource context); |
84 | 85 |
85 // Returns the calling thread's current context or NULL if no context is | 86 // Returns the calling thread's current context or NULL if no context is |
86 // current. | 87 // current. |
87 PP_Resource (*GetCurrentContext)(); | 88 PP_Resource (*GetCurrentContext)(); |
88 | 89 |
89 // Snapshots the rendered frame and makes it available for composition with | 90 // Snapshots the rendered frame and makes it available for composition with |
90 // the rest of the page. The alpha channel is used for translucency effects. | 91 // the rest of the page. The alpha channel is used for translucency effects. |
91 // One means fully opaque. Zero means fully transparent. Any thread. | 92 // One means fully opaque. Zero means fully transparent. Any thread. |
| 93 // The callback will be called when SwapBuffers completes. While a SwapBuffers |
| 94 // call is pending, all subsequent SwapBuffers calls will fail. Specifying a |
| 95 // NULL callback means blocking but this is not legal on the main thread. |
92 // TODO(apatrick): premultiplied alpha or linear alpha? Premultiplied alpha is | 96 // TODO(apatrick): premultiplied alpha or linear alpha? Premultiplied alpha is |
93 // better for correct alpha blending effect. Most existing OpenGL code assumes | 97 // better for correct alpha blending effect. Most existing OpenGL code assumes |
94 // linear. I could convert from linear to premultiplied during the copy from | 98 // linear. I could convert from linear to premultiplied during the copy from |
95 // back-buffer to offscreen "front-buffer". | 99 // back-buffer to offscreen "front-buffer". |
96 PP_Bool (*SwapBuffers)(PP_Resource context); | 100 PP_Bool (*SwapBuffers)(PP_Resource context, |
| 101 struct PP_CompletionCallback callback); |
97 | 102 |
98 // Returns the current error for this thread. This is not associated with a | 103 // Returns the current error for this thread. This is not associated with a |
99 // particular context. It is distinct from the GL error returned by | 104 // particular context. It is distinct from the GL error returned by |
100 // glGetError. | 105 // glGetError. |
101 uint32_t (*GetError)(); | 106 uint32_t (*GetError)(); |
102 }; | 107 }; |
103 | 108 |
104 #endif // PPAPI_C_DEV_PPB_GRAPHICS_3D_DEV_H_ | 109 #endif // PPAPI_C_DEV_PPB_GRAPHICS_3D_DEV_H_ |
OLD | NEW |