OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 #ifndef CC_LAYERS_TEXTURE_LAYER_CLIENT_H_ | 5 #ifndef CC_LAYERS_TEXTURE_LAYER_CLIENT_H_ |
6 #define CC_LAYERS_TEXTURE_LAYER_CLIENT_H_ | 6 #define CC_LAYERS_TEXTURE_LAYER_CLIENT_H_ |
7 | 7 |
8 namespace WebKit { class WebGraphicsContext3D; } | 8 namespace WebKit { class WebGraphicsContext3D; } |
9 | 9 |
10 namespace cc { | 10 namespace cc { |
11 class ResourceUpdateQueue; | 11 class ResourceUpdateQueue; |
12 class TextureMailbox; | 12 class TextureMailbox; |
13 | 13 |
14 class TextureLayerClient { | 14 class TextureLayerClient { |
15 public: | 15 public: |
16 // Called to prepare this layer's texture for compositing. The client may | 16 // Called to prepare this layer's texture for compositing. The client may |
17 // queue a texture upload or copy on the ResourceUpdateQueue. | 17 // queue a texture upload or copy on the ResourceUpdateQueue. |
18 // Returns the texture ID to be used for compositing. | 18 // Returns the texture ID to be used for compositing. |
19 virtual unsigned PrepareTexture(ResourceUpdateQueue* queue) = 0; | 19 virtual unsigned PrepareTexture(ResourceUpdateQueue* queue) = 0; |
20 | 20 |
21 // Returns the context that is providing the texture. Used for rate limiting | 21 // Returns the context that is providing the texture. Used for rate limiting |
22 // and detecting lost context. | 22 // and detecting lost context. |
23 virtual WebKit::WebGraphicsContext3D* Context3d() = 0; | 23 virtual WebKit::WebGraphicsContext3D* Context3d() = 0; |
24 | 24 |
25 // Returns true and provides a mailbox if a new frame is available. | 25 // Returns true and provides a mailbox if a new frame is available. |
26 // Returns false if no new data is available | 26 // Returns false if no new data is available |
27 // and the old mailbox is to be reused. | 27 // and the old mailbox is to be reused. |
28 virtual bool PrepareTextureMailbox(TextureMailbox* mailbox) = 0; | 28 virtual bool PrepareTextureMailbox(TextureMailbox* mailbox, |
| 29 bool use_shared_memory) = 0; |
29 | 30 |
30 protected: | 31 protected: |
31 virtual ~TextureLayerClient() {} | 32 virtual ~TextureLayerClient() {} |
32 }; | 33 }; |
33 | 34 |
34 } // namespace cc | 35 } // namespace cc |
35 | 36 |
36 #endif // CC_LAYERS_TEXTURE_LAYER_CLIENT_H_ | 37 #endif // CC_LAYERS_TEXTURE_LAYER_CLIENT_H_ |
OLD | NEW |