OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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 CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_ | 5 #ifndef CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_ |
6 #define CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_ | 6 #define CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_ |
7 | 7 |
8 #include "base/callback.h" | 8 #include "base/callback.h" |
9 #include "cc/resources/ui_resource_bitmap.h" | 9 #include "cc/resources/ui_resource_bitmap.h" |
10 #include "cc/resources/ui_resource_client.h" | 10 #include "cc/resources/ui_resource_client.h" |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
65 virtual void SetHasTransparentBackground(bool flag) = 0; | 65 virtual void SetHasTransparentBackground(bool flag) = 0; |
66 | 66 |
67 // Attempts to composite and read back the result into the provided buffer. | 67 // Attempts to composite and read back the result into the provided buffer. |
68 // The buffer must be at least window width * height * 4 (RGBA) bytes large. | 68 // The buffer must be at least window width * height * 4 (RGBA) bytes large. |
69 // The buffer is not modified if false is returned. | 69 // The buffer is not modified if false is returned. |
70 virtual bool CompositeAndReadback(void *pixels, const gfx::Rect& rect) = 0; | 70 virtual bool CompositeAndReadback(void *pixels, const gfx::Rect& rect) = 0; |
71 | 71 |
72 // Composite immediately. Used in single-threaded mode. | 72 // Composite immediately. Used in single-threaded mode. |
73 virtual void Composite() = 0; | 73 virtual void Composite() = 0; |
74 | 74 |
75 // Generates a UIResource and returns a UIResourceId. May return 0. | 75 // Generates a UIResource and returns a UIResourceId. |is_transient| |
76 // indicates whether or not to release the resource once the bitmap | |
77 // has been uploaded. May return 0. | |
76 virtual cc::UIResourceId GenerateUIResource( | 78 virtual cc::UIResourceId GenerateUIResource( |
77 const cc::UIResourceBitmap& bitmap) = 0; | 79 const cc::UIResourceBitmap& bitmap, |
aelias_OOO_until_Jul13
2014/01/31 05:50:10
Since GenerateCompressedUIResource takes a void* d
powei
2014/02/01 01:30:49
Done. Removed UIResourceBitmap references downstr
| |
80 bool is_transient) = 0; | |
81 | |
82 // Generates a compressed UIResource. See above for |is_transient|. May | |
aelias_OOO_until_Jul13
2014/01/31 05:50:10
"ETC1 compressed"
powei
2014/02/01 01:30:49
Done.
| |
83 // return 0. | |
84 virtual cc::UIResourceId GenerateCompressedUIResource(gfx::Size& size, | |
85 int data_size, | |
86 void* data, | |
87 bool is_transient) = 0; | |
78 | 88 |
79 // Deletes a UIResource. | 89 // Deletes a UIResource. |
80 virtual void DeleteUIResource(cc::UIResourceId resource_id) = 0; | 90 virtual void DeleteUIResource(cc::UIResourceId resource_id) = 0; |
81 | 91 |
82 // Generates an OpenGL texture and returns a texture handle. May return 0 | |
83 // if the current context is lost. | |
84 virtual blink::WebGLId GenerateTexture(gfx::JavaBitmap& bitmap) = 0; | |
85 | |
86 // Generates an OpenGL compressed texture and returns a texture handle. May | |
87 // return 0 if the current context is lost. | |
88 virtual blink::WebGLId GenerateCompressedTexture(gfx::Size& size, | |
89 int data_size, | |
90 void* data) = 0; | |
91 | |
92 // Deletes an OpenGL texture. | |
93 virtual void DeleteTexture(blink::WebGLId texture_id) = 0; | |
94 | |
95 // Grabs a copy of |texture_id| and saves it into |bitmap|. No scaling is | |
96 // done. It is assumed that the texture size matches that of the bitmap. | |
97 virtual bool CopyTextureToBitmap(blink::WebGLId texture_id, | |
98 gfx::JavaBitmap& bitmap) = 0; | |
99 | |
100 // Grabs a copy of |texture_id| and saves it into |bitmap|. No scaling is | |
101 // done. |src_rect| allows the caller to specify which rect of |texture_id| | |
102 // to copy to |bitmap|. It needs to match the size of |bitmap|. Returns | |
103 // true if the |texture_id| was copied into |bitmap|, false if not. | |
104 virtual bool CopyTextureToBitmap(blink::WebGLId texture_id, | |
105 const gfx::Rect& src_rect, | |
106 gfx::JavaBitmap& bitmap) = 0; | |
107 protected: | 92 protected: |
108 Compositor() {} | 93 Compositor() {} |
109 }; | 94 }; |
110 | 95 |
111 } // namespace content | 96 } // namespace content |
112 | 97 |
113 #endif // CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_ | 98 #endif // CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_ |
OLD | NEW |