OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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_BROWSER_AURA_SOFTWARE_OUTPUT_SURFACE_H_ | 5 #ifndef CONTENT_BROWSER_AURA_SOFTWARE_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ |
6 #define CONTENT_BROWSER_AURA_SOFTWARE_OUTPUT_SURFACE_H_ | 6 #define CONTENT_BROWSER_AURA_SOFTWARE_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ |
7 | 7 |
8 #include "cc/output/output_surface.h" | 8 #include "base/memory/weak_ptr.h" |
| 9 #include "content/browser/aura/browser_compositor_output_surface.h" |
| 10 #include "content/common/content_export.h" |
| 11 #include "ui/compositor/compositor.h" |
9 | 12 |
10 namespace cc { class SoftwareOutputDevice; } | 13 namespace base { |
| 14 class MessageLoopProxy; |
| 15 } |
| 16 |
| 17 namespace cc { |
| 18 class SoftwareOutputDevice; |
| 19 } |
11 | 20 |
12 namespace content { | 21 namespace content { |
13 | 22 |
14 // TODO(danakj): Inherit from BrowserCompositorOutputSurface to share stuff like | 23 class BrowserCompositorOutputSurfaceProxy; |
15 // reflectors, when we split the GL-specific stuff out of the class. | 24 |
16 class SoftwareBrowserCompositorOutputSurface : public cc::OutputSurface { | 25 class CONTENT_EXPORT SoftwareBrowserCompositorOutputSurface |
| 26 : public BrowserCompositorOutputSurface { |
17 public: | 27 public: |
18 static scoped_ptr<SoftwareBrowserCompositorOutputSurface> Create( | 28 SoftwareBrowserCompositorOutputSurface( |
19 scoped_ptr<cc::SoftwareOutputDevice> software_device) { | 29 scoped_refptr<BrowserCompositorOutputSurfaceProxy> surface_proxy, |
20 return make_scoped_ptr( | 30 scoped_ptr<cc::SoftwareOutputDevice> software_device, |
21 new SoftwareBrowserCompositorOutputSurface(software_device.Pass())); | 31 int surface_id, |
22 } | 32 IDMap<BrowserCompositorOutputSurface>* output_surface_map, |
| 33 base::MessageLoopProxy* compositor_message_loop, |
| 34 base::WeakPtr<ui::Compositor> compositor); |
| 35 |
| 36 virtual ~SoftwareBrowserCompositorOutputSurface(); |
23 | 37 |
24 private: | 38 private: |
25 explicit SoftwareBrowserCompositorOutputSurface( | 39 virtual void SwapBuffers(cc::CompositorFrame* frame) OVERRIDE; |
26 scoped_ptr<cc::SoftwareOutputDevice> software_device); | |
27 | 40 |
28 virtual void SwapBuffers(cc::CompositorFrame* frame) OVERRIDE; | 41 // On the software path we need to explicitly call the proxy to update the |
| 42 // VSync parameters. |
| 43 scoped_refptr<BrowserCompositorOutputSurfaceProxy> output_surface_proxy_; |
| 44 |
| 45 DISALLOW_COPY_AND_ASSIGN(SoftwareBrowserCompositorOutputSurface); |
29 }; | 46 }; |
30 | 47 |
31 } // namespace content | 48 } // namespace content |
32 | 49 |
33 #endif // CONTENT_BROWSER_AURA_SOFTWARE_OUTPUT_SURFACE_H_ | 50 #endif // CONTENT_BROWSER_AURA_SOFTWARE_BROWSER_COMPOSITOR_OUTPUT_SURFACE_H_ |
OLD | NEW |