OLD | NEW |
(Empty) | |
| 1 // Copyright 2015 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 CHROMECAST_OZONE_CAST_EGL_PLATFORM_H_ |
| 6 #define CHROMECAST_OZONE_CAST_EGL_PLATFORM_H_ |
| 7 |
| 8 #include "ui/ozone/public/surface_factory_ozone.h" |
| 9 |
| 10 namespace gfx { |
| 11 class Size; |
| 12 } |
| 13 |
| 14 namespace chromecast { |
| 15 namespace ozone { |
| 16 |
| 17 // Interface representing all the hardware-specific elements of an Ozone |
| 18 // implementation for Cast. Supply an implementation of this interface |
| 19 // to OzonePlatformCast to create a complete Ozone implementation. |
| 20 class CastEglPlatform { |
| 21 public: |
| 22 typedef ui::SurfaceFactoryOzone::AddGLLibraryCallback AddGLLibraryCallback; |
| 23 typedef ui::SurfaceFactoryOzone::SetGLGetProcAddressProcCallback |
| 24 SetGLGetProcAddressProcCallback; |
| 25 |
| 26 virtual ~CastEglPlatform() {} |
| 27 |
| 28 // Default display size is used for initial display and also as a minimum |
| 29 // resolution for applications. |
| 30 virtual gfx::Size GetDefaultDisplaySize() const = 0; |
| 31 |
| 32 // Returns an array of EGL properties, which can be used in any EGL function |
| 33 // used to select a display configuration. Note that all properties should be |
| 34 // immediately followed by the corresponding desired value and array should be |
| 35 // terminated with EGL_NONE. Ownership of the array is not transferred to |
| 36 // caller. desired_list contains list of desired EGL properties and values. |
| 37 virtual const int32* GetEGLSurfaceProperties(const int32* desired_list) = 0; |
| 38 |
| 39 // Initialize/ShutdownHardware are called at most once each over the object's |
| 40 // lifetime. Initialize will be called before creating display type or |
| 41 // window. If Initialize fails, return false (Shutdown will still be called). |
| 42 virtual bool InitializeHardware() = 0; |
| 43 virtual void ShutdownHardware() = 0; |
| 44 |
| 45 // Called once after hardware successfully initialized. Implementation needs |
| 46 // to add the EGL and GLES2 libraries through add_gl_library and also supply |
| 47 // a pointer to eglGetProcAddress (or equivalent function). |
| 48 virtual bool LoadEGLGLES2Bindings( |
| 49 AddGLLibraryCallback add_gl_library, |
| 50 SetGLGetProcAddressProcCallback set_gl_get_proc_address) = 0; |
| 51 |
| 52 // Create/destroy an EGLNativeDisplayType. These may be called multiple times |
| 53 // over the object's lifetime, for example to release the display when |
| 54 // switching to an external application. There will be at most one display |
| 55 // type at a time. |
| 56 virtual intptr_t CreateDisplayType(const gfx::Size& size) = 0; |
| 57 virtual void DestroyDisplayType(intptr_t display_type) = 0; |
| 58 |
| 59 // Create/destroy an EGLNativeWindow. There will be at most one window at a |
| 60 // time, created within a valid display type. |
| 61 virtual intptr_t CreateWindow(intptr_t display_type, |
| 62 const gfx::Size& size) = 0; |
| 63 virtual void DestroyWindow(intptr_t window) = 0; |
| 64 }; |
| 65 |
| 66 } // namespace ozone |
| 67 } // namespace chromecast |
| 68 |
| 69 #endif // CHROMECAST_OZONE_CAST_EGL_PLATFORM_H_ |
OLD | NEW |