Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(488)

Unified Diff: services/video_capture/video_capture_device_proxy_impl.cc

Issue 2378943002: Let clients interact with VideoCaptureDeviceClient instead of VideoCaptureDevice (Closed)
Patch Set: mcasas comments Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: services/video_capture/video_capture_device_proxy_impl.cc
diff --git a/services/video_capture/video_capture_device_proxy_impl.cc b/services/video_capture/video_capture_device_proxy_impl.cc
index 2fc33b170515e70a62f5d605d7d5cd942a976377..6dc99ede53c965f44f18840afb9be0de3785fb57 100644
--- a/services/video_capture/video_capture_device_proxy_impl.cc
+++ b/services/video_capture/video_capture_device_proxy_impl.cc
@@ -2,16 +2,24 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#include "services/video_capture/video_capture_device_proxy_impl.h"
+
#include "base/logging.h"
-#include "services/video_capture/device_client_mojo_to_media_adapter.h"
+#include "media/capture/video/video_capture_buffer_pool_impl.h"
+#include "media/capture/video/video_capture_jpeg_decoder.h"
+#include "services/video_capture/buffer_tracker_factory_impl.h"
#include "services/video_capture/mojo_media_conversions.h"
-#include "services/video_capture/video_capture_device_proxy_impl.h"
+#include "services/video_capture/receiver_mojo_to_media_adapter.h"
namespace video_capture {
VideoCaptureDeviceProxyImpl::VideoCaptureDeviceProxyImpl(
- std::unique_ptr<media::VideoCaptureDevice> device)
- : device_(std::move(device)) {}
+ std::unique_ptr<media::VideoCaptureDevice> device,
+ const media::VideoCaptureJpegDecoderFactoryCB&
+ jpeg_decoder_factory_callback)
+ : device_(std::move(device)),
+ jpeg_decoder_factory_callback_(jpeg_decoder_factory_callback),
+ device_running_(false) {}
VideoCaptureDeviceProxyImpl::~VideoCaptureDeviceProxyImpl() {
if (device_running_)
@@ -22,18 +30,31 @@ void VideoCaptureDeviceProxyImpl::Start(
mojom::VideoCaptureFormatPtr requested_format,
mojom::ResolutionChangePolicy resolution_change_policy,
mojom::PowerLineFrequency power_line_frequency,
- mojom::VideoCaptureDeviceClientPtr client) {
+ mojom::VideoFrameReceiverPtr receiver) {
media::VideoCaptureParams params;
params.requested_format = ConvertFromMojoToMedia(std::move(requested_format));
params.resolution_change_policy =
ConvertFromMojoToMedia(resolution_change_policy);
params.power_line_frequency = ConvertFromMojoToMedia(power_line_frequency);
- client.set_connection_error_handler(
+
+ receiver.set_connection_error_handler(
base::Bind(&VideoCaptureDeviceProxyImpl::OnClientConnectionErrorOrClose,
base::Unretained(this)));
- auto media_client =
- base::MakeUnique<DeviceClientMojoToMediaAdapter>(std::move(client));
- device_->AllocateAndStart(params, std::move(media_client));
+
+ auto media_receiver =
+ base::MakeUnique<ReceiverMojoToMediaAdapter>(std::move(receiver));
+
+ // Create a dedicated buffer pool for the device usage session.
+ const int kMaxBufferCount = 2;
+ auto buffer_tracker_factory = base::MakeUnique<BufferTrackerFactoryImpl>();
+ scoped_refptr<media::VideoCaptureBufferPool> buffer_pool(
+ new media::VideoCaptureBufferPoolImpl(std::move(buffer_tracker_factory),
+ kMaxBufferCount));
+
+ auto device_client = base::MakeUnique<media::VideoCaptureDeviceClient>(
+ std::move(media_receiver), buffer_pool, jpeg_decoder_factory_callback_);
+
+ device_->AllocateAndStart(params, std::move(device_client));
device_running_ = true;
}
@@ -43,7 +64,10 @@ void VideoCaptureDeviceProxyImpl::Stop() {
}
void VideoCaptureDeviceProxyImpl::OnClientConnectionErrorOrClose() {
- device_->StopAndDeAllocate();
+ if (device_running_) {
+ device_->StopAndDeAllocate();
+ device_running_ = false;
+ }
}
} // namespace video_capture

Powered by Google App Engine
This is Rietveld 408576698