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

Side by Side Diff: ui/gl/gl_image_linux.cc

Issue 13543007: GLImage support for Android zero-copy pixel buffers (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Fix minor indentation issue Created 7 years, 8 months 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) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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 #include "ui/gl/gl_image.h" 5 #include "ui/gl/gl_image.h"
6 6
7 #include "base/debug/trace_event.h" 7 #include "base/debug/trace_event.h"
8 #include "ui/gl/gl_image_glx.h" 8 #include "ui/gl/gl_image_glx.h"
9 #include "ui/gl/gl_image_stub.h" 9 #include "ui/gl/gl_image_stub.h"
10 #include "ui/gl/gl_implementation.h" 10 #include "ui/gl/gl_implementation.h"
11 11
12 namespace gfx { 12 namespace gfx {
13 13
14 scoped_refptr<GLImage> GLImage::CreateGLImage(gfx::PluginWindowHandle window) { 14 scoped_refptr<GLImage> GLImage::CreateGLImage(gfx::PluginWindowHandle window) {
15 TRACE_EVENT0("gpu", "GLImage::CreateGLImage"); 15 TRACE_EVENT0("gpu", "GLImage::CreateGLImage");
16 switch (GetGLImplementation()) { 16 switch (GetGLImplementation()) {
17 case kGLImplementationOSMesaGL: { 17 case kGLImplementationOSMesaGL:
18 return NULL; 18 return NULL;
19 } 19 case kGLImplementationDesktopGL:
20 case kGLImplementationDesktopGL: {
21 scoped_refptr<GLImageGLX> image(new GLImageGLX(window)); 20 scoped_refptr<GLImageGLX> image(new GLImageGLX(window));
22 if (!image->Initialize()) 21 if (!image->Initialize())
23 return NULL; 22 return NULL;
24 23
25 return image; 24 return image;
26 } 25 case kGLImplementationEGLGLES2:
27 case kGLImplementationEGLGLES2: {
28 return NULL; 26 return NULL;
29 }
30 case kGLImplementationMockGL: 27 case kGLImplementationMockGL:
31 return new GLImageStub; 28 return new GLImageStub;
32 default: 29 default:
30 NOTREACHED();
31 return NULL;
32 }
33 }
34
35 scoped_refptr<GLImage> GLImage::CreateGLImageForGpuMemoryBuffer(
36 gfx::GpuMemoryBufferHandle buffer, const gfx::Size& size) {
37 TRACE_EVENT0("gpu", "GLImage::CreateGLImageForGpuMemoryBuffer");
38 switch (GetGLImplementation()) {
39 case kGLImplementationOSMesaGL:
40 case kGLImplementationDesktopGL:
41 case kGLImplementationEGLGLES2:
42 return NULL;
43 case kGLImplementationMockGL:
44 return new GLImageStub;
45 default:
33 NOTREACHED(); 46 NOTREACHED();
34 return NULL; 47 return NULL;
35 } 48 }
36 } 49 }
37 50
38 } // namespace gfx 51 } // namespace gfx
OLDNEW
« ui/gl/gl_image_egl.cc ('K') | « ui/gl/gl_image_glx.cc ('k') | ui/gl/gl_image_mac.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698