| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 SKY_COMPOSITOR_LAYER_HOST_H_ | 5 #ifndef SKY_COMPOSITOR_LAYER_HOST_H_ |
| 6 #define SKY_COMPOSITOR_LAYER_HOST_H_ | 6 #define SKY_COMPOSITOR_LAYER_HOST_H_ |
| 7 | 7 |
| 8 #include "base/memory/ref_counted.h" | 8 #include "base/memory/ref_counted.h" |
| 9 #include "base/memory/scoped_ptr.h" | 9 #include "base/memory/scoped_ptr.h" |
| 10 #include "base/memory/weak_ptr.h" | 10 #include "base/memory/weak_ptr.h" |
| 11 #include "mojo/gpu/gl_context_owner.h" |
| 11 #include "mojo/skia/ganesh_context.h" | 12 #include "mojo/skia/ganesh_context.h" |
| 12 #include "sky/compositor/layer_host_client.h" | 13 #include "sky/compositor/layer_host_client.h" |
| 13 #include "sky/compositor/resource_manager.h" | 14 #include "sky/compositor/resource_manager.h" |
| 14 #include "sky/compositor/surface_holder.h" | 15 #include "sky/compositor/surface_holder.h" |
| 15 | 16 |
| 16 namespace sky { | 17 namespace sky { |
| 17 class ResourceManager; | 18 class ResourceManager; |
| 18 class Layer; | 19 class Layer; |
| 19 class LayerHostClient; | 20 class LayerHostClient; |
| 20 | 21 |
| 21 class LayerHost : public SurfaceHolder::Client { | 22 class LayerHost : public SurfaceHolder::Client { |
| 22 public: | 23 public: |
| 23 explicit LayerHost(LayerHostClient* client); | 24 explicit LayerHost(LayerHostClient* client); |
| 24 ~LayerHost(); | 25 ~LayerHost(); |
| 25 | 26 |
| 26 LayerHostClient* client() const { return client_; } | 27 LayerHostClient* client() const { return client_; } |
| 27 | 28 |
| 28 const base::WeakPtr<mojo::GLContext>& gl_context() const { | 29 const base::WeakPtr<mojo::GLContext>& gl_context() const { |
| 29 return gl_context_; | 30 return gl_context_owner_.context(); |
| 30 } | 31 } |
| 31 | 32 |
| 32 mojo::GaneshContext* ganesh_context() const { | 33 mojo::GaneshContext* ganesh_context() const { |
| 33 return const_cast<mojo::GaneshContext*>(&ganesh_context_); | 34 return const_cast<mojo::GaneshContext*>(&ganesh_context_); |
| 34 } | 35 } |
| 35 | 36 |
| 36 ResourceManager* resource_manager() const { | 37 ResourceManager* resource_manager() const { |
| 37 return const_cast<ResourceManager*>(&resource_manager_); | 38 return const_cast<ResourceManager*>(&resource_manager_); |
| 38 } | 39 } |
| 39 | 40 |
| (...skipping 16 matching lines...) Expand all Loading... |
| 56 void BeginFrameSoon(); | 57 void BeginFrameSoon(); |
| 57 void BeginFrame(); | 58 void BeginFrame(); |
| 58 | 59 |
| 59 void Upload(Layer* layer); | 60 void Upload(Layer* layer); |
| 60 void DidCompleteFrame(); | 61 void DidCompleteFrame(); |
| 61 | 62 |
| 62 LayerHostClient* client_; | 63 LayerHostClient* client_; |
| 63 State state_; | 64 State state_; |
| 64 bool frame_requested_; | 65 bool frame_requested_; |
| 65 SurfaceHolder surface_holder_; | 66 SurfaceHolder surface_holder_; |
| 66 base::WeakPtr<mojo::GLContext> gl_context_; | 67 mojo::GLContextOwner gl_context_owner_; |
| 67 mojo::GaneshContext ganesh_context_; | 68 mojo::GaneshContext ganesh_context_; |
| 68 ResourceManager resource_manager_; | 69 ResourceManager resource_manager_; |
| 69 scoped_refptr<Layer> root_layer_; | 70 scoped_refptr<Layer> root_layer_; |
| 70 | 71 |
| 71 base::WeakPtrFactory<LayerHost> weak_factory_; | 72 base::WeakPtrFactory<LayerHost> weak_factory_; |
| 72 | 73 |
| 73 DISALLOW_COPY_AND_ASSIGN(LayerHost); | 74 DISALLOW_COPY_AND_ASSIGN(LayerHost); |
| 74 }; | 75 }; |
| 75 | 76 |
| 76 } // namespace sky | 77 } // namespace sky |
| 77 | 78 |
| 78 #endif // SKY_COMPOSITOR_LAYER_HOST_H_ | 79 #endif // SKY_COMPOSITOR_LAYER_HOST_H_ |
| OLD | NEW |