Chromium Code Reviews| Index: webkit/plugins/ppapi/ppb_video_capture_impl.h |
| diff --git a/webkit/plugins/ppapi/ppb_video_capture_impl.h b/webkit/plugins/ppapi/ppb_video_capture_impl.h |
| index 7486e1764d615b45db8da75b8b830c4826a33f20..820f5625e47a571ca6b89ca80252aeac430cd62d 100644 |
| --- a/webkit/plugins/ppapi/ppb_video_capture_impl.h |
| +++ b/webkit/plugins/ppapi/ppb_video_capture_impl.h |
| @@ -1,4 +1,4 @@ |
| -// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| @@ -9,10 +9,11 @@ |
| #include "base/basictypes.h" |
| #include "base/compiler_specific.h" |
| -#include "base/memory/scoped_ptr.h" |
| +#include "base/memory/ref_counted.h" |
| #include "media/video/capture/video_capture.h" |
| #include "ppapi/c/dev/ppp_video_capture_dev.h" |
| #include "ppapi/shared_impl/resource.h" |
| +#include "ppapi/shared_impl/tracked_callback.h" |
| #include "ppapi/thunk/ppb_video_capture_api.h" |
| #include "webkit/plugins/ppapi/plugin_delegate.h" |
| #include "webkit/plugins/ppapi/ppb_buffer_impl.h" |
| @@ -22,9 +23,10 @@ struct PP_VideoCaptureDeviceInfo_Dev; |
| namespace webkit { |
| namespace ppapi { |
| -class PPB_VideoCapture_Impl : public ::ppapi::Resource, |
| - public ::ppapi::thunk::PPB_VideoCapture_API, |
| - public media::VideoCapture::EventHandler { |
| +class PPB_VideoCapture_Impl |
| + : public ::ppapi::Resource, |
| + public ::ppapi::thunk::PPB_VideoCapture_API, |
| + public PluginDelegate::PlatformVideoCaptureEventHandler { |
| public: |
| explicit PPB_VideoCapture_Impl(PP_Instance instance); |
| virtual ~PPB_VideoCapture_Impl(); |
| @@ -33,16 +35,20 @@ class PPB_VideoCapture_Impl : public ::ppapi::Resource, |
| // Resource overrides. |
| virtual PPB_VideoCapture_API* AsPPB_VideoCapture_API() OVERRIDE; |
| - virtual void LastPluginRefWasDeleted() OVERRIDE; |
| - // PPB_VideoCapture implementation. |
| + // PPB_VideoCapture_API implementation. |
| + virtual int32_t EnumerateDevices(PP_CompletionCallback callback) OVERRIDE; |
| + virtual PP_Resource GetDevices() OVERRIDE; |
| virtual int32_t StartCapture( |
| + const std::string& device_id, |
| const PP_VideoCaptureDeviceInfo_Dev& requested_info, |
| uint32_t buffer_count) OVERRIDE; |
| virtual int32_t ReuseBuffer(uint32_t buffer) OVERRIDE; |
| virtual int32_t StopCapture() OVERRIDE; |
| + virtual const std::vector<::ppapi::DeviceRefData>& GetDeviceRefData( |
| + ) const OVERRIDE; |
| - // media::VideoCapture::EventHandler implementation. |
| + // PluginDelegate::PlatformVideoCaptureEventHandler implementation. |
| virtual void OnStarted(media::VideoCapture* capture) OVERRIDE; |
| virtual void OnStopped(media::VideoCapture* capture) OVERRIDE; |
| virtual void OnPaused(media::VideoCapture* capture) OVERRIDE; |
| @@ -54,12 +60,22 @@ class PPB_VideoCapture_Impl : public ::ppapi::Resource, |
| virtual void OnDeviceInfoReceived( |
| media::VideoCapture* capture, |
| const media::VideoCaptureParams& device_info) OVERRIDE; |
| + virtual void OnInitialized(media::VideoCapture* capture, |
| + bool succeeded) OVERRIDE; |
| private: |
| void ReleaseBuffers(); |
| void SendStatus(); |
| - scoped_ptr<PluginDelegate::PlatformVideoCapture> platform_video_capture_; |
| + void ClearCachedDeviceResourceArray(); |
| + void DetachPlatformVideoCapture(); |
| + |
| + void OnEnumerateDevicesComplete( |
| + int request_id, |
| + bool succeeded, |
| + const std::vector<::ppapi::DeviceRefData>& devices); |
| + |
| + scoped_refptr<PluginDelegate::PlatformVideoCapture> platform_video_capture_; |
| size_t buffer_count_hint_; |
| struct BufferInfo { |
| @@ -75,11 +91,16 @@ class PPB_VideoCapture_Impl : public ::ppapi::Resource, |
| const PPP_VideoCapture_Dev* ppp_videocapture_; |
| PP_VideoCaptureStatus_Dev status_; |
| - // Signifies that the plugin has given up all its refs, but the object is |
| - // still alive, possibly because the backend hasn't released the object as |
| - // |EventHandler| yet. It can be removed if/when |EventHandler| is made to be |
| - // refcounted (and made into a "member" of this object instead). |
| - bool is_dead_; |
| + scoped_refptr<::ppapi::TrackedCallback> enumerate_devices_callback_; |
| + |
| + base::WeakPtrFactory<PPB_VideoCapture_Impl> weak_ptr_factory_; |
|
piman
2012/01/28 08:26:55
Same here: do we need this, given that the class i
yzshen1
2012/01/29 21:58:32
I prefer using weak pointer in this case. I would
|
| + |
| + // A resource array holding the enumeration result. When nonzero, we're |
| + // holding a reference to it. |
| + PP_Resource devices_; |
| + std::vector<::ppapi::DeviceRefData> devices_data_; |
| + |
| + media::VideoCapture::VideoCaptureCapability capability_; |
| DISALLOW_COPY_AND_ASSIGN(PPB_VideoCapture_Impl); |
| }; |