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
3 // found in the LICENSE file.
5 #ifndef CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_
6 #define CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_
8 #include "base/callback.h"
9 #include "cc/resources/ui_resource_bitmap.h"
10 #include "cc/resources/ui_resource_client.h"
11 #include "content/common/content_export.h"
12 #include "ui/gfx/native_widget_types.h"
13 #include "ui/gfx/rect.h"
14 #include "ui/gfx/size.h"
16 #include "third_party/WebKit/public/platform/WebGraphicsContext3D.h"
27 class CompositorClient
;
29 // An interface to the browser-side compositor.
30 class CONTENT_EXPORT Compositor
{
32 virtual ~Compositor() {}
34 // Performs the global initialization needed before any compositor
35 // instance can be used. This should be called only once.
36 static void Initialize();
38 // Creates and returns a compositor instance.
39 static Compositor
* Create(CompositorClient
* client
);
41 // Attaches the layer tree.
42 virtual void SetRootLayer(scoped_refptr
<cc::Layer
> root
) = 0;
44 // Set the scale factor from DIP to pixel.
45 virtual void setDeviceScaleFactor(float factor
) = 0;
47 // Set the output surface bounds.
48 virtual void SetWindowBounds(const gfx::Size
& size
) = 0;
50 // Sets the window visibility. When becoming invisible, resources will get
51 // freed and other calls into the compositor are not allowed until after
52 // having been made visible again.
53 virtual void SetVisible(bool visible
) = 0;
55 // Set the output surface handle which the compositor renders into.
56 // DEPRECATED: Use SetSurface() which takes a Java Surface object.
57 virtual void SetWindowSurface(ANativeWindow
* window
) = 0;
59 // Set the output surface which the compositor renders into.
60 virtual void SetSurface(jobject surface
) = 0;
62 // Attempts to composite and read back the result into the provided buffer.
63 // The buffer must be at least window width * height * 4 (RGBA) bytes large.
64 // The buffer is not modified if false is returned.
65 virtual bool CompositeAndReadback(void *pixels
, const gfx::Rect
& rect
) = 0;
67 // Composite immediately. Used in single-threaded mode.
68 virtual void Composite() = 0;
70 // Generates a UIResource and returns a UIResourceId. May return 0.
71 virtual cc::UIResourceId
GenerateUIResource(
72 const cc::UIResourceBitmap
& bitmap
) = 0;
74 // Deletes a UIResource.
75 virtual void DeleteUIResource(cc::UIResourceId resource_id
) = 0;
77 // Generates an OpenGL texture and returns a texture handle. May return 0
78 // if the current context is lost.
79 virtual WebKit::WebGLId
GenerateTexture(gfx::JavaBitmap
& bitmap
) = 0;
81 // Generates an OpenGL compressed texture and returns a texture handle. May
82 // return 0 if the current context is lost.
83 virtual WebKit::WebGLId
GenerateCompressedTexture(gfx::Size
& size
,
87 // Deletes an OpenGL texture.
88 virtual void DeleteTexture(WebKit::WebGLId texture_id
) = 0;
90 // Grabs a copy of |texture_id| and saves it into |bitmap|. No scaling is
91 // done. It is assumed that the texture size matches that of the bitmap.
92 virtual bool CopyTextureToBitmap(WebKit::WebGLId texture_id
,
93 gfx::JavaBitmap
& bitmap
) = 0;
95 // Grabs a copy of |texture_id| and saves it into |bitmap|. No scaling is
96 // done. |src_rect| allows the caller to specify which rect of |texture_id|
97 // to copy to |bitmap|. It needs to match the size of |bitmap|. Returns
98 // true if the |texture_id| was copied into |bitmap|, false if not.
99 virtual bool CopyTextureToBitmap(WebKit::WebGLId texture_id
,
100 const gfx::Rect
& src_rect
,
101 gfx::JavaBitmap
& bitmap
) = 0;
106 } // namespace content
108 #endif // CONTENT_PUBLIC_BROWSER_ANDROID_COMPOSITOR_H_