| 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_OUTPUT_SURFACE_H_ |
| 6 #define CONTENT_BROWSER_AURA_SOFTWARE_OUTPUT_SURFACE_H_ | 6 #define CONTENT_BROWSER_AURA_SOFTWARE_OUTPUT_SURFACE_H_ |
| 7 | 7 |
| 8 #include "base/memory/weak_ptr.h" |
| 8 #include "cc/output/output_surface.h" | 9 #include "cc/output/output_surface.h" |
| 10 #include "ui/compositor/compositor.h" |
| 9 | 11 |
| 10 namespace cc { class SoftwareOutputDevice; } | 12 namespace base { |
| 13 class MessageLoopProxy; |
| 14 } |
| 15 |
| 16 namespace cc { |
| 17 class SoftwareOutputDevice; |
| 18 } |
| 11 | 19 |
| 12 namespace content { | 20 namespace content { |
| 13 | 21 |
| 22 class VSyncListener; |
| 23 |
| 14 // TODO(danakj): Inherit from BrowserCompositorOutputSurface to share stuff like | 24 // TODO(danakj): Inherit from BrowserCompositorOutputSurface to share stuff like |
| 15 // reflectors, when we split the GL-specific stuff out of the class. | 25 // reflectors, when we split the GL-specific stuff out of the class. |
| 16 class SoftwareBrowserCompositorOutputSurface : public cc::OutputSurface { | 26 class SoftwareBrowserCompositorOutputSurface : public cc::OutputSurface { |
| 17 public: | 27 public: |
| 18 static scoped_ptr<SoftwareBrowserCompositorOutputSurface> Create( | 28 static scoped_ptr<SoftwareBrowserCompositorOutputSurface> Create( |
| 19 scoped_ptr<cc::SoftwareOutputDevice> software_device) { | 29 scoped_ptr<cc::SoftwareOutputDevice> software_device, |
| 30 base::MessageLoopProxy* compositor_message_loop, |
| 31 base::WeakPtr<ui::Compositor> compositor) { |
| 20 return make_scoped_ptr( | 32 return make_scoped_ptr( |
| 21 new SoftwareBrowserCompositorOutputSurface(software_device.Pass())); | 33 new SoftwareBrowserCompositorOutputSurface(software_device.Pass(), |
| 34 compositor_message_loop, |
| 35 compositor)); |
| 22 } | 36 } |
| 23 | 37 |
| 38 virtual ~SoftwareBrowserCompositorOutputSurface(); |
| 39 |
| 24 private: | 40 private: |
| 25 explicit SoftwareBrowserCompositorOutputSurface( | 41 friend class VSyncListener; |
| 26 scoped_ptr<cc::SoftwareOutputDevice> software_device); | 42 |
| 43 SoftwareBrowserCompositorOutputSurface( |
| 44 scoped_ptr<cc::SoftwareOutputDevice> software_device, |
| 45 base::MessageLoopProxy* compositor_message_loop, |
| 46 base::WeakPtr<ui::Compositor> compositor); |
| 27 | 47 |
| 28 virtual void SwapBuffers(cc::CompositorFrame* frame) OVERRIDE; | 48 virtual void SwapBuffers(cc::CompositorFrame* frame) OVERRIDE; |
| 49 |
| 50 scoped_refptr<VSyncListener> vsync_listener_; |
| 29 }; | 51 }; |
| 30 | 52 |
| 31 } // namespace content | 53 } // namespace content |
| 32 | 54 |
| 33 #endif // CONTENT_BROWSER_AURA_SOFTWARE_OUTPUT_SURFACE_H_ | 55 #endif // CONTENT_BROWSER_AURA_SOFTWARE_OUTPUT_SURFACE_H_ |
| OLD | NEW |