| OLD | NEW | 
|---|
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 UI_GFX_OZONE_SURFACE_LNUX_FACTORY_OZONE_H_ | 5 #ifndef UI_GFX_OZONE_SURFACE_LNUX_FACTORY_OZONE_H_ | 
| 6 #define UI_GFX_OZONE_SURFACE_LNUX_FACTORY_OZONE_H_ | 6 #define UI_GFX_OZONE_SURFACE_LNUX_FACTORY_OZONE_H_ | 
| 7 | 7 | 
| 8 #include "base/callback.h" | 8 #include "base/callback.h" | 
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" | 
| 10 #include "base/native_library.h" | 10 #include "base/native_library.h" | 
| 11 #include "ui/gfx/geometry/point.h" | 11 #include "ui/gfx/geometry/point.h" | 
| 12 #include "ui/gfx/geometry/rect.h" | 12 #include "ui/gfx/geometry/rect.h" | 
| 13 #include "ui/gfx/gfx_export.h" | 13 #include "ui/gfx/gfx_export.h" | 
| 14 #include "ui/gfx/native_widget_types.h" | 14 #include "ui/gfx/native_widget_types.h" | 
| 15 #include "ui/gfx/rect.h" | 15 #include "ui/gfx/rect.h" | 
| 16 | 16 | 
| 17 class SkBitmap; | 17 class SkBitmap; | 
| 18 class SkCanvas; | 18 class SkCanvas; | 
| 19 | 19 | 
| 20 namespace gfx { | 20 namespace gfx { | 
| 21 class VSyncProvider; | 21 class VSyncProvider; | 
| 22 class OverlayCandidatesOzone; | 22 class OverlayCandidatesOzone; | 
| 23 class SurfaceOzone; | 23 class SurfaceOzone; | 
| 24 typedef intptr_t NativeBufferOzone; | 24 typedef intptr_t NativeBufferOzone; | 
| 25 | 25 | 
|  | 26 // Widget for use by platforms that only support one surface at a time. | 
|  | 27 // This is probably not useful for any real platform, but it makes | 
|  | 28 // implementing simple platforms with only one surface easier. | 
|  | 29 GFX_EXPORT extern const gfx::AcceleratedWidget | 
|  | 30   kDefaultAcceleratedWidgetForSingleWindow; | 
|  | 31 | 
| 26 // The Ozone interface allows external implementations to hook into Chromium to | 32 // The Ozone interface allows external implementations to hook into Chromium to | 
| 27 // provide a system specific implementation. The Ozone interface supports two | 33 // provide a system specific implementation. The Ozone interface supports two | 
| 28 // drawing modes: 1) accelerated drawing through EGL and 2) software drawing | 34 // drawing modes: 1) accelerated drawing through EGL and 2) software drawing | 
| 29 // through Skia. | 35 // through Skia. | 
| 30 // | 36 // | 
| 31 // The following functionality is specific to the drawing mode and may not have | 37 // The following functionality is specific to the drawing mode and may not have | 
| 32 // any meaningful implementation in the other mode. An implementation must | 38 // any meaningful implementation in the other mode. An implementation must | 
| 33 // provide functionality for at least one mode. | 39 // provide functionality for at least one mode. | 
| 34 // | 40 // | 
| 35 // 1) Accelerated Drawing (EGL path): | 41 // 1) Accelerated Drawing (EGL path): | 
| (...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 98   virtual HardwareState InitializeHardware() = 0; | 104   virtual HardwareState InitializeHardware() = 0; | 
| 99 | 105 | 
| 100   // Cleans up display hardware state. Call this from within the GPU process. | 106   // Cleans up display hardware state. Call this from within the GPU process. | 
| 101   // This method must be safe to run inside of the sandbox. | 107   // This method must be safe to run inside of the sandbox. | 
| 102   virtual void ShutdownHardware() = 0; | 108   virtual void ShutdownHardware() = 0; | 
| 103 | 109 | 
| 104   // Returns native platform display handle. This is used to obtain the EGL | 110   // Returns native platform display handle. This is used to obtain the EGL | 
| 105   // display connection for the native display. | 111   // display connection for the native display. | 
| 106   virtual intptr_t GetNativeDisplay(); | 112   virtual intptr_t GetNativeDisplay(); | 
| 107 | 113 | 
| 108   // Obtains an AcceleratedWidget backed by a native Linux framebuffer. |  | 
| 109   // The  returned AcceleratedWidget is an opaque token that must realized |  | 
| 110   // before it can be used to create a GL surface. |  | 
| 111   virtual gfx::AcceleratedWidget GetAcceleratedWidget() = 0; |  | 
| 112 |  | 
| 113   // Create a surface for the specified gfx::AcceleratedWidget. | 114   // Create a surface for the specified gfx::AcceleratedWidget. | 
| 114   virtual scoped_ptr<SurfaceOzone> CreateSurfaceForWidget( | 115   virtual scoped_ptr<SurfaceOzone> CreateSurfaceForWidget( | 
| 115       gfx::AcceleratedWidget widget); | 116       gfx::AcceleratedWidget widget); | 
| 116 | 117 | 
| 117   // Sets up GL bindings for the native surface. Takes two callback parameters | 118   // Sets up GL bindings for the native surface. Takes two callback parameters | 
| 118   // that allow Ozone to register the GL bindings. | 119   // that allow Ozone to register the GL bindings. | 
| 119   virtual bool LoadEGLGLES2Bindings( | 120   virtual bool LoadEGLGLES2Bindings( | 
| 120       AddGLLibraryCallback add_gl_library, | 121       AddGLLibraryCallback add_gl_library, | 
| 121       SetGLGetProcAddressProcCallback set_gl_get_proc_address) = 0; | 122       SetGLGetProcAddressProcCallback set_gl_get_proc_address) = 0; | 
| 122 | 123 | 
| (...skipping 28 matching lines...) Expand all  Loading... | 
| 151   virtual gfx::NativeBufferOzone CreateNativeBuffer(gfx::Size size, | 152   virtual gfx::NativeBufferOzone CreateNativeBuffer(gfx::Size size, | 
| 152                                                     BufferFormat format); | 153                                                     BufferFormat format); | 
| 153 | 154 | 
| 154  private: | 155  private: | 
| 155   static SurfaceFactoryOzone* impl_; // not owned | 156   static SurfaceFactoryOzone* impl_; // not owned | 
| 156 }; | 157 }; | 
| 157 | 158 | 
| 158 }  // namespace gfx | 159 }  // namespace gfx | 
| 159 | 160 | 
| 160 #endif  // UI_GFX_OZONE_SURFACE_LNUX_FACTORY_OZONE_H_ | 161 #endif  // UI_GFX_OZONE_SURFACE_LNUX_FACTORY_OZONE_H_ | 
| OLD | NEW | 
|---|