| 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_SURFACE_HOLDER_H_ | 5 #ifndef SKY_COMPOSITOR_SURFACE_HOLDER_H_ |
| 6 #define SKY_COMPOSITOR_SURFACE_HOLDER_H_ | 6 #define SKY_COMPOSITOR_SURFACE_HOLDER_H_ |
| 7 | 7 |
| 8 #include "base/callback_forward.h" | 8 #include "base/callback_forward.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/services/surfaces/public/interfaces/surface_id.mojom.h" | 11 #include "mojo/services/surfaces/public/interfaces/surface_id.mojom.h" |
| 12 #include "mojo/services/surfaces/public/interfaces/surfaces.mojom.h" | 12 #include "mojo/services/surfaces/public/interfaces/surfaces.mojom.h" |
| 13 #include "ui/gfx/geometry/rect.h" | 13 #include "ui/gfx/geometry/rect.h" |
| 14 | 14 |
| 15 namespace mojo { | 15 namespace mojo { |
| 16 class Shell; | 16 class Shell; |
| 17 } | 17 } |
| 18 | 18 |
| 19 namespace sky { | 19 namespace sky { |
| 20 class SurfaceAllocator; | 20 class SurfaceAllocator; |
| 21 | 21 |
| 22 class SurfaceHolder : public mojo::SurfaceClient { | 22 class SurfaceHolder : public mojo::ResourceReturner { |
| 23 public: | 23 public: |
| 24 class Client { | 24 class Client { |
| 25 public: | 25 public: |
| 26 virtual void OnSurfaceIdAvailable(mojo::SurfaceIdPtr surface_id) = 0; | 26 virtual void OnSurfaceIdAvailable(mojo::SurfaceIdPtr surface_id) = 0; |
| 27 virtual void ReturnResources( | 27 virtual void ReturnResources( |
| 28 mojo::Array<mojo::ReturnedResourcePtr> resources) = 0; | 28 mojo::Array<mojo::ReturnedResourcePtr> resources) = 0; |
| 29 | 29 |
| 30 protected: | 30 protected: |
| 31 virtual ~Client(); | 31 virtual ~Client(); |
| 32 }; | 32 }; |
| 33 | 33 |
| 34 explicit SurfaceHolder(Client* client, mojo::Shell* shell); | 34 explicit SurfaceHolder(Client* client, mojo::Shell* shell); |
| 35 ~SurfaceHolder() override; | 35 ~SurfaceHolder() override; |
| 36 | 36 |
| 37 void SetSize(const gfx::Size& size); | 37 void SetSize(const gfx::Size& size); |
| 38 void SubmitFrame(mojo::FramePtr frame, const base::Closure& callback); | 38 void SubmitFrame(mojo::FramePtr frame, const base::Closure& callback); |
| 39 | 39 |
| 40 private: | 40 private: |
| 41 // mojo::SurfaceClient | 41 // mojo::ResourceReturner |
| 42 void SetIdNamespace(uint32_t id_namespace) override; | |
| 43 void ReturnResources( | 42 void ReturnResources( |
| 44 mojo::Array<mojo::ReturnedResourcePtr> resources) override; | 43 mojo::Array<mojo::ReturnedResourcePtr> resources) override; |
| 45 | 44 |
| 45 void SetIdNamespace(uint32_t id_namespace); |
| 46 void SetQualifiedId(); | 46 void SetQualifiedId(); |
| 47 | 47 |
| 48 Client* client_; | 48 Client* client_; |
| 49 gfx::Size size_; | 49 gfx::Size size_; |
| 50 uint32_t id_namespace_; | 50 uint32_t id_namespace_; |
| 51 uint32_t local_id_; | 51 uint32_t local_id_; |
| 52 mojo::SurfacePtr surface_; | 52 mojo::SurfacePtr surface_; |
| 53 mojo::Binding<mojo::ResourceReturner> returner_binding_; |
| 53 | 54 |
| 54 base::WeakPtrFactory<SurfaceHolder> weak_factory_; | 55 base::WeakPtrFactory<SurfaceHolder> weak_factory_; |
| 55 | 56 |
| 56 DISALLOW_COPY_AND_ASSIGN(SurfaceHolder); | 57 DISALLOW_COPY_AND_ASSIGN(SurfaceHolder); |
| 57 }; | 58 }; |
| 58 | 59 |
| 59 } // namespace sky | 60 } // namespace sky |
| 60 | 61 |
| 61 #endif // SKY_COMPOSITOR_SURFACE_HOLDER_H_ | 62 #endif // SKY_COMPOSITOR_SURFACE_HOLDER_H_ |
| OLD | NEW |