Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(68)

Side by Side Diff: ppapi/c/dev/ppb_graphics_3d_dev.h

Issue 5944001: Make Graphics3D::SwapBuffers take a completion callback (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 10 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698