(Auto)update libjingle 72407428-> 72430895

git-svn-id: http://webrtc.googlecode.com/svn/trunk@6812 4adac7df-926f-26a2-2b94-8c16560cd09d
This commit is contained in:
buildbot@webrtc.org 2014-08-01 22:03:36 +00:00
parent 3bc48247b7
commit 7cb60ccae1
17 changed files with 413 additions and 225 deletions

View File

@ -480,6 +480,8 @@
'media/base/cpuid.cc', 'media/base/cpuid.cc',
'media/base/cpuid.h', 'media/base/cpuid.h',
'media/base/cryptoparams.h', 'media/base/cryptoparams.h',
'media/base/device.h',
'media/base/fakescreencapturerfactory.h',
'media/base/filemediaengine.cc', 'media/base/filemediaengine.cc',
'media/base/filemediaengine.h', 'media/base/filemediaengine.h',
'media/base/hybriddataengine.h', 'media/base/hybriddataengine.h',
@ -502,6 +504,7 @@
'media/base/videoadapter.h', 'media/base/videoadapter.h',
'media/base/videocapturer.cc', 'media/base/videocapturer.cc',
'media/base/videocapturer.h', 'media/base/videocapturer.h',
'media/base/videocapturerfactory.h',
'media/base/videocommon.cc', 'media/base/videocommon.cc',
'media/base/videocommon.h', 'media/base/videocommon.h',
'media/base/videoframe.cc', 'media/base/videoframe.cc',
@ -533,6 +536,8 @@
'media/webrtc/webrtctexturevideoframe.cc', 'media/webrtc/webrtctexturevideoframe.cc',
'media/webrtc/webrtctexturevideoframe.h', 'media/webrtc/webrtctexturevideoframe.h',
'media/webrtc/webrtcvideocapturer.cc', 'media/webrtc/webrtcvideocapturer.cc',
'media/webrtc/webrtcvideocapturerfactory.h',
'media/webrtc/webrtcvideocapturerfactory.cc',
'media/webrtc/webrtcvideocapturer.h', 'media/webrtc/webrtcvideocapturer.h',
'media/webrtc/webrtcvideodecoderfactory.h', 'media/webrtc/webrtcvideodecoderfactory.h',
'media/webrtc/webrtcvideoencoderfactory.h', 'media/webrtc/webrtcvideoencoderfactory.h',

50
talk/media/base/device.h Executable file
View File

@ -0,0 +1,50 @@
// libjingle
// Copyright 2014 Google Inc.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// 3. The name of the author may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
#ifndef TALK_MEDIA_BASE_DEVICE_H_
#define TALK_MEDIA_BASE_DEVICE_H_
#include "webrtc/base/stringencode.h"
namespace cricket {
// Used to represent an audio or video capture or render device.
struct Device {
Device() {}
Device(const std::string& name, int id)
: name(name),
id(rtc::ToString(id)) {
}
Device(const std::string& name, const std::string& id)
: name(name), id(id) {}
std::string name;
std::string id;
};
} // namespace cricket
#endif // TALK_MEDIA_BASE_DEVICE_H_

View File

@ -0,0 +1,80 @@
/*
* libjingle
* Copyright 2012 Google Inc.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef TALK_MEDIA_BASE_FAKESCREENCAPTURERFACTORY_H_
#define TALK_MEDIA_BASE_FAKESCREENCAPTURERFACTORY_H_
#include "talk/media/base/fakevideocapturer.h"
#include "talk/media/base/videocapturerfactory.h"
namespace cricket {
class FakeScreenCapturerFactory
: public cricket::ScreenCapturerFactory,
public sigslot::has_slots<> {
public:
FakeScreenCapturerFactory()
: window_capturer_(NULL),
capture_state_(cricket::CS_STOPPED) {}
virtual cricket::VideoCapturer* Create(const ScreencastId& window) {
if (window_capturer_ != NULL) {
// Class is only designed to handle one fake screencapturer.
ADD_FAILURE();
return NULL;
}
window_capturer_ = new cricket::FakeVideoCapturer;
window_capturer_->SignalDestroyed.connect(
this,
&FakeScreenCapturerFactory::OnWindowCapturerDestroyed);
window_capturer_->SignalStateChange.connect(
this,
&FakeScreenCapturerFactory::OnStateChange);
return window_capturer_;
}
cricket::FakeVideoCapturer* window_capturer() { return window_capturer_; }
cricket::CaptureState capture_state() { return capture_state_; }
private:
void OnWindowCapturerDestroyed(cricket::FakeVideoCapturer* capturer) {
if (capturer == window_capturer_) {
window_capturer_ = NULL;
}
}
void OnStateChange(cricket::VideoCapturer*, cricket::CaptureState state) {
capture_state_ = state;
}
cricket::FakeVideoCapturer* window_capturer_;
cricket::CaptureState capture_state_;
};
} // namespace cricket
#endif // TALK_MEDIA_BASE_FAKESCREENCAPTURERFACTORY_H_

View File

@ -0,0 +1,55 @@
// libjingle
// Copyright 2014 Google Inc.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// 3. The name of the author may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
#ifndef TALK_MEDIA_BASE_VIDEOCAPTURERFACTORY_H_
#define TALK_MEDIA_BASE_VIDEOCAPTURERFACTORY_H_
#include "talk/media/base/device.h"
#include "talk/media/base/screencastid.h"
namespace cricket {
class VideoCapturer;
class VideoDeviceCapturerFactory {
public:
VideoDeviceCapturerFactory() {}
virtual ~VideoDeviceCapturerFactory() {}
virtual VideoCapturer* Create(const Device& device) = 0;
};
class ScreenCapturerFactory {
public:
ScreenCapturerFactory() {}
virtual ~ScreenCapturerFactory() {}
virtual VideoCapturer* Create(const ScreencastId& screenid) = 0;
};
} // namespace cricket
#endif // TALK_MEDIA_BASE_VIDEOCAPTURERFACTORY_H_

View File

@ -35,19 +35,14 @@
#include "webrtc/base/windowpicker.h" #include "webrtc/base/windowpicker.h"
#include "webrtc/base/windowpickerfactory.h" #include "webrtc/base/windowpickerfactory.h"
#include "talk/media/base/mediacommon.h" #include "talk/media/base/mediacommon.h"
#include "talk/media/base/videocapturerfactory.h"
#include "talk/media/devices/deviceinfo.h" #include "talk/media/devices/deviceinfo.h"
#include "talk/media/devices/filevideocapturer.h" #include "talk/media/devices/filevideocapturer.h"
#include "talk/media/devices/yuvframescapturer.h" #include "talk/media/devices/yuvframescapturer.h"
#if defined(HAVE_WEBRTC_VIDEO) #ifdef HAVE_WEBRTC_VIDEO
#include "talk/media/webrtc/webrtcvideocapturer.h" #include "talk/media/webrtc/webrtcvideocapturerfactory.h"
#endif #endif // HAVE_WEBRTC_VIDEO
#if defined(HAVE_WEBRTC_VIDEO)
#define VIDEO_CAPTURER_NAME WebRtcVideoCapturer
#endif
namespace { namespace {
@ -64,29 +59,12 @@ namespace cricket {
// Initialize to empty string. // Initialize to empty string.
const char DeviceManagerInterface::kDefaultDeviceName[] = ""; const char DeviceManagerInterface::kDefaultDeviceName[] = "";
class DefaultVideoCapturerFactory : public VideoCapturerFactory {
public:
DefaultVideoCapturerFactory() {}
virtual ~DefaultVideoCapturerFactory() {}
VideoCapturer* Create(const Device& device) {
#if defined(VIDEO_CAPTURER_NAME)
VIDEO_CAPTURER_NAME* return_value = new VIDEO_CAPTURER_NAME;
if (!return_value->Init(device)) {
delete return_value;
return NULL;
}
return return_value;
#else
return NULL;
#endif
}
};
DeviceManager::DeviceManager() DeviceManager::DeviceManager()
: initialized_(false), : initialized_(false),
device_video_capturer_factory_(new DefaultVideoCapturerFactory),
window_picker_(rtc::WindowPickerFactory::CreateWindowPicker()) { window_picker_(rtc::WindowPickerFactory::CreateWindowPicker()) {
#ifdef HAVE_WEBRTC_VIDEO
SetVideoDeviceCapturerFactory(new WebRtcVideoDeviceCapturerFactory());
#endif // HAVE_WEBRTC_VIDEO
} }
DeviceManager::~DeviceManager() { DeviceManager::~DeviceManager() {
@ -212,12 +190,16 @@ void DeviceManager::ClearVideoCaptureDeviceMaxFormat(
} }
VideoCapturer* DeviceManager::CreateVideoCapturer(const Device& device) const { VideoCapturer* DeviceManager::CreateVideoCapturer(const Device& device) const {
VideoCapturer* capturer = ConstructFakeVideoCapturer(device); VideoCapturer* capturer = MaybeConstructFakeVideoCapturer(device);
if (capturer) { if (capturer) {
return capturer; return capturer;
} }
capturer = device_video_capturer_factory_->Create(device); if (!video_device_capturer_factory_) {
LOG(LS_ERROR) << "No video capturer factory for devices.";
return NULL;
}
capturer = video_device_capturer_factory_->Create(device);
if (!capturer) { if (!capturer) {
return NULL; return NULL;
} }
@ -231,7 +213,7 @@ VideoCapturer* DeviceManager::CreateVideoCapturer(const Device& device) const {
return capturer; return capturer;
} }
VideoCapturer* DeviceManager::ConstructFakeVideoCapturer( VideoCapturer* DeviceManager::MaybeConstructFakeVideoCapturer(
const Device& device) const { const Device& device) const {
// TODO(hellner): Throw out the creation of a file video capturer once the // TODO(hellner): Throw out the creation of a file video capturer once the
// refactoring is completed. // refactoring is completed.
@ -262,19 +244,6 @@ bool DeviceManager::GetWindows(
return window_picker_->GetWindowList(descriptions); return window_picker_->GetWindowList(descriptions);
} }
VideoCapturer* DeviceManager::CreateWindowCapturer(rtc::WindowId window) {
#if defined(WINDOW_CAPTURER_NAME)
WINDOW_CAPTURER_NAME* window_capturer = new WINDOW_CAPTURER_NAME();
if (!window_capturer->Init(window)) {
delete window_capturer;
return NULL;
}
return window_capturer;
#else
return NULL;
#endif
}
bool DeviceManager::GetDesktops( bool DeviceManager::GetDesktops(
std::vector<rtc::DesktopDescription>* descriptions) { std::vector<rtc::DesktopDescription>* descriptions) {
if (!window_picker_) { if (!window_picker_) {
@ -283,18 +252,13 @@ bool DeviceManager::GetDesktops(
return window_picker_->GetDesktopList(descriptions); return window_picker_->GetDesktopList(descriptions);
} }
VideoCapturer* DeviceManager::CreateDesktopCapturer( VideoCapturer* DeviceManager::CreateScreenCapturer(
rtc::DesktopId desktop) { const ScreencastId& screenid) const {
#if defined(DESKTOP_CAPTURER_NAME) if (!screen_capturer_factory_) {
DESKTOP_CAPTURER_NAME* desktop_capturer = new DESKTOP_CAPTURER_NAME(); LOG(LS_ERROR) << "No video capturer factory for screens.";
if (!desktop_capturer->Init(desktop.index())) {
delete desktop_capturer;
return NULL; return NULL;
} }
return desktop_capturer; return screen_capturer_factory_->Create(screenid);
#else
return NULL;
#endif
} }
bool DeviceManager::GetAudioDevices(bool input, bool DeviceManager::GetAudioDevices(bool input,

View File

@ -32,11 +32,14 @@
#include <string> #include <string>
#include <vector> #include <vector>
#include "talk/media/base/device.h"
#include "talk/media/base/screencastid.h"
#include "talk/media/base/videocommon.h"
#include "talk/media/base/videocapturerfactory.h"
#include "webrtc/base/scoped_ptr.h" #include "webrtc/base/scoped_ptr.h"
#include "webrtc/base/sigslot.h" #include "webrtc/base/sigslot.h"
#include "webrtc/base/stringencode.h" #include "webrtc/base/stringencode.h"
#include "webrtc/base/window.h" #include "webrtc/base/window.h"
#include "talk/media/base/videocommon.h"
namespace rtc { namespace rtc {
@ -49,28 +52,6 @@ namespace cricket {
class VideoCapturer; class VideoCapturer;
// Used to represent an audio or video capture or render device.
struct Device {
Device() {}
Device(const std::string& first, int second)
: name(first),
id(rtc::ToString(second)) {
}
Device(const std::string& first, const std::string& second)
: name(first), id(second) {}
std::string name;
std::string id;
};
class VideoCapturerFactory {
public:
VideoCapturerFactory() {}
virtual ~VideoCapturerFactory() {}
virtual VideoCapturer* Create(const Device& device) = 0;
};
// DeviceManagerInterface - interface to manage the audio and // DeviceManagerInterface - interface to manage the audio and
// video devices on the system. // video devices on the system.
class DeviceManagerInterface { class DeviceManagerInterface {
@ -94,6 +75,14 @@ class DeviceManagerInterface {
virtual bool GetVideoCaptureDevices(std::vector<Device>* devs) = 0; virtual bool GetVideoCaptureDevices(std::vector<Device>* devs) = 0;
virtual bool GetVideoCaptureDevice(const std::string& name, Device* out) = 0; virtual bool GetVideoCaptureDevice(const std::string& name, Device* out) = 0;
// If the device manager needs to create video capturers, here is
// how to control which video capturers are created. These take
// ownership of the factories.
virtual void SetVideoDeviceCapturerFactory(
VideoDeviceCapturerFactory* video_device_capturer_factory) = 0;
virtual void SetScreenCapturerFactory(
ScreenCapturerFactory* screen_capturer_factory) = 0;
// Caps the capture format according to max format for capturers created // Caps the capture format according to max format for capturers created
// by CreateVideoCapturer(). See ConstrainSupportedFormats() in // by CreateVideoCapturer(). See ConstrainSupportedFormats() in
// videocapturer.h for more detail. // videocapturer.h for more detail.
@ -109,12 +98,10 @@ class DeviceManagerInterface {
virtual bool GetWindows( virtual bool GetWindows(
std::vector<rtc::WindowDescription>* descriptions) = 0; std::vector<rtc::WindowDescription>* descriptions) = 0;
virtual VideoCapturer* CreateWindowCapturer(rtc::WindowId window) = 0;
virtual bool GetDesktops( virtual bool GetDesktops(
std::vector<rtc::DesktopDescription>* descriptions) = 0; std::vector<rtc::DesktopDescription>* descriptions) = 0;
virtual VideoCapturer* CreateDesktopCapturer( virtual VideoCapturer* CreateScreenCapturer(
rtc::DesktopId desktop) = 0; const ScreencastId& screenid) const = 0;
sigslot::signal0<> SignalDevicesChange; sigslot::signal0<> SignalDevicesChange;
@ -142,11 +129,6 @@ class DeviceManager : public DeviceManagerInterface {
DeviceManager(); DeviceManager();
virtual ~DeviceManager(); virtual ~DeviceManager();
void set_device_video_capturer_factory(
VideoCapturerFactory* device_video_capturer_factory) {
device_video_capturer_factory_.reset(device_video_capturer_factory);
}
// Initialization // Initialization
virtual bool Init(); virtual bool Init();
virtual void Terminate(); virtual void Terminate();
@ -164,19 +146,29 @@ class DeviceManager : public DeviceManagerInterface {
virtual bool GetVideoCaptureDevices(std::vector<Device>* devs); virtual bool GetVideoCaptureDevices(std::vector<Device>* devs);
virtual bool GetVideoCaptureDevice(const std::string& name, Device* out); virtual bool GetVideoCaptureDevice(const std::string& name, Device* out);
virtual void SetVideoDeviceCapturerFactory(
VideoDeviceCapturerFactory* video_device_capturer_factory) {
video_device_capturer_factory_.reset(video_device_capturer_factory);
}
virtual void SetScreenCapturerFactory(
ScreenCapturerFactory* screen_capturer_factory) {
screen_capturer_factory_.reset(screen_capturer_factory);
}
virtual void SetVideoCaptureDeviceMaxFormat(const std::string& usb_id, virtual void SetVideoCaptureDeviceMaxFormat(const std::string& usb_id,
const VideoFormat& max_format); const VideoFormat& max_format);
virtual void ClearVideoCaptureDeviceMaxFormat(const std::string& usb_id); virtual void ClearVideoCaptureDeviceMaxFormat(const std::string& usb_id);
// TODO(pthatcher): Rename to CreateVideoDeviceCapturer.
virtual VideoCapturer* CreateVideoCapturer(const Device& device) const; virtual VideoCapturer* CreateVideoCapturer(const Device& device) const;
virtual bool GetWindows( virtual bool GetWindows(
std::vector<rtc::WindowDescription>* descriptions); std::vector<rtc::WindowDescription>* descriptions);
virtual VideoCapturer* CreateWindowCapturer(rtc::WindowId window);
virtual bool GetDesktops( virtual bool GetDesktops(
std::vector<rtc::DesktopDescription>* descriptions); std::vector<rtc::DesktopDescription>* descriptions);
virtual VideoCapturer* CreateDesktopCapturer(rtc::DesktopId desktop); virtual VideoCapturer* CreateScreenCapturer(
const ScreencastId& screenid) const;
// The exclusion_list MUST be a NULL terminated list. // The exclusion_list MUST be a NULL terminated list.
static bool FilterDevices(std::vector<Device>* devices, static bool FilterDevices(std::vector<Device>* devices,
@ -202,10 +194,13 @@ class DeviceManager : public DeviceManagerInterface {
static bool ShouldDeviceBeIgnored(const std::string& device_name, static bool ShouldDeviceBeIgnored(const std::string& device_name,
const char* const exclusion_list[]); const char* const exclusion_list[]);
bool GetFakeVideoCaptureDevice(const std::string& name, Device* out) const; bool GetFakeVideoCaptureDevice(const std::string& name, Device* out) const;
VideoCapturer* ConstructFakeVideoCapturer(const Device& device) const; VideoCapturer* MaybeConstructFakeVideoCapturer(const Device& device) const;
bool initialized_; bool initialized_;
rtc::scoped_ptr<VideoCapturerFactory> device_video_capturer_factory_; rtc::scoped_ptr<
VideoDeviceCapturerFactory> video_device_capturer_factory_;
rtc::scoped_ptr<
ScreenCapturerFactory> screen_capturer_factory_;
std::map<std::string, VideoFormat> max_formats_; std::map<std::string, VideoFormat> max_formats_;
rtc::scoped_ptr<DeviceWatcher> watcher_; rtc::scoped_ptr<DeviceWatcher> watcher_;
rtc::scoped_ptr<rtc::WindowPicker> window_picker_; rtc::scoped_ptr<rtc::WindowPicker> window_picker_;

View File

@ -41,7 +41,9 @@
#include "webrtc/base/stream.h" #include "webrtc/base/stream.h"
#include "webrtc/base/windowpickerfactory.h" #include "webrtc/base/windowpickerfactory.h"
#include "talk/media/base/fakevideocapturer.h" #include "talk/media/base/fakevideocapturer.h"
#include "talk/media/base/screencastid.h"
#include "talk/media/base/testutils.h" #include "talk/media/base/testutils.h"
#include "talk/media/base/videocapturerfactory.h"
#include "talk/media/devices/filevideocapturer.h" #include "talk/media/devices/filevideocapturer.h"
#include "talk/media/devices/v4llookup.h" #include "talk/media/devices/v4llookup.h"
@ -65,24 +67,38 @@ const cricket::VideoFormat kHdFormat(1280, 720,
cricket::VideoFormat::FpsToInterval(30), cricket::VideoFormat::FpsToInterval(30),
cricket::FOURCC_I420); cricket::FOURCC_I420);
class FakeVideoCapturerFactory : public cricket::VideoCapturerFactory { class FakeVideoDeviceCapturerFactory :
public cricket::VideoDeviceCapturerFactory {
public: public:
FakeVideoCapturerFactory() {} FakeVideoDeviceCapturerFactory() {}
virtual ~FakeVideoCapturerFactory() {} virtual ~FakeVideoDeviceCapturerFactory() {}
virtual cricket::VideoCapturer* Create(const cricket::Device& device) { virtual cricket::VideoCapturer* Create(const cricket::Device& device) {
return new cricket::FakeVideoCapturer; return new cricket::FakeVideoCapturer;
} }
}; };
class FakeScreenCapturerFactory : public cricket::ScreenCapturerFactory {
public:
FakeScreenCapturerFactory() {}
virtual ~FakeScreenCapturerFactory() {}
virtual cricket::VideoCapturer* Create(
const cricket::ScreencastId& screenid) {
return new cricket::FakeVideoCapturer;
}
};
class DeviceManagerTestFake : public testing::Test { class DeviceManagerTestFake : public testing::Test {
public: public:
virtual void SetUp() { virtual void SetUp() {
dm_.reset(DeviceManagerFactory::Create()); dm_.reset(DeviceManagerFactory::Create());
EXPECT_TRUE(dm_->Init()); EXPECT_TRUE(dm_->Init());
DeviceManager* device_manager = static_cast<DeviceManager*>(dm_.get()); DeviceManager* device_manager = static_cast<DeviceManager*>(dm_.get());
device_manager->set_device_video_capturer_factory( device_manager->SetVideoDeviceCapturerFactory(
new FakeVideoCapturerFactory()); new FakeVideoDeviceCapturerFactory());
device_manager->SetScreenCapturerFactory(
new FakeScreenCapturerFactory());
} }
virtual void TearDown() { virtual void TearDown() {
@ -371,6 +387,7 @@ TEST(DeviceManagerTest, GetWindows) {
return; return;
} }
scoped_ptr<DeviceManagerInterface> dm(DeviceManagerFactory::Create()); scoped_ptr<DeviceManagerInterface> dm(DeviceManagerFactory::Create());
dm->SetScreenCapturerFactory(new FakeScreenCapturerFactory());
std::vector<rtc::WindowDescription> descriptions; std::vector<rtc::WindowDescription> descriptions;
EXPECT_TRUE(dm->Init()); EXPECT_TRUE(dm->Init());
if (!dm->GetWindows(&descriptions) || descriptions.empty()) { if (!dm->GetWindows(&descriptions) || descriptions.empty()) {
@ -378,8 +395,8 @@ TEST(DeviceManagerTest, GetWindows) {
<< "windows to capture."; << "windows to capture.";
return; return;
} }
scoped_ptr<cricket::VideoCapturer> capturer(dm->CreateWindowCapturer( scoped_ptr<cricket::VideoCapturer> capturer(dm->CreateScreenCapturer(
descriptions.front().id())); cricket::ScreencastId(descriptions.front().id())));
EXPECT_FALSE(capturer.get() == NULL); EXPECT_FALSE(capturer.get() == NULL);
// TODO(hellner): creating a window capturer and immediately deleting it // TODO(hellner): creating a window capturer and immediately deleting it
// results in "Continuous Build and Test Mainline - Mac opt" failure (crash). // results in "Continuous Build and Test Mainline - Mac opt" failure (crash).
@ -394,6 +411,7 @@ TEST(DeviceManagerTest, GetDesktops) {
return; return;
} }
scoped_ptr<DeviceManagerInterface> dm(DeviceManagerFactory::Create()); scoped_ptr<DeviceManagerInterface> dm(DeviceManagerFactory::Create());
dm->SetScreenCapturerFactory(new FakeScreenCapturerFactory());
std::vector<rtc::DesktopDescription> descriptions; std::vector<rtc::DesktopDescription> descriptions;
EXPECT_TRUE(dm->Init()); EXPECT_TRUE(dm->Init());
if (!dm->GetDesktops(&descriptions) || descriptions.empty()) { if (!dm->GetDesktops(&descriptions) || descriptions.empty()) {
@ -401,8 +419,8 @@ TEST(DeviceManagerTest, GetDesktops) {
<< "desktops to capture."; << "desktops to capture.";
return; return;
} }
scoped_ptr<cricket::VideoCapturer> capturer(dm->CreateDesktopCapturer( scoped_ptr<cricket::VideoCapturer> capturer(dm->CreateScreenCapturer(
descriptions.front().id())); cricket::ScreencastId(descriptions.front().id())));
EXPECT_FALSE(capturer.get() == NULL); EXPECT_FALSE(capturer.get() == NULL);
} }
#endif // !WIN32 #endif // !WIN32

View File

@ -79,6 +79,12 @@ class FakeDeviceManager : public DeviceManagerInterface {
*devs = vidcap_devices_; *devs = vidcap_devices_;
return true; return true;
} }
virtual void SetVideoDeviceCapturerFactory(
VideoDeviceCapturerFactory* video_device_capturer_factory) {
}
virtual void SetScreenCapturerFactory(
ScreenCapturerFactory* screen_capturer_factory) {
}
virtual void SetVideoCaptureDeviceMaxFormat(const std::string& usb_id, virtual void SetVideoCaptureDeviceMaxFormat(const std::string& usb_id,
const VideoFormat& max_format) { const VideoFormat& max_format) {
max_formats_[usb_id] = max_format; max_formats_[usb_id] = max_format;
@ -97,6 +103,10 @@ class FakeDeviceManager : public DeviceManagerInterface {
virtual VideoCapturer* CreateVideoCapturer(const Device& device) const { virtual VideoCapturer* CreateVideoCapturer(const Device& device) const {
return new FakeVideoCapturer(); return new FakeVideoCapturer();
} }
virtual VideoCapturer* CreateScreenCapturer(
const ScreencastId& screenid) const {
return new FakeVideoCapturer();
}
virtual bool GetWindows( virtual bool GetWindows(
std::vector<rtc::WindowDescription>* descriptions) { std::vector<rtc::WindowDescription>* descriptions) {
descriptions->clear(); descriptions->clear();

View File

@ -0,0 +1,43 @@
/*
* libjingle
* Copyright 2014 Google Inc.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
*
* 1. Redistributions of source code must retain the above copyright notice,
* this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* 3. The name of the author may not be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
* EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#include "talk/base/scoped_ptr.h"
#include "talk/media/webrtc/webrtcvideocapturer.h"
#include "talk/media/webrtc/webrtcvideocapturerfactory.h"
namespace cricket {
VideoCapturer* WebRtcVideoDeviceCapturerFactory::Create(const Device& device) {
talk_base::scoped_ptr<WebRtcVideoCapturer> capturer(
new WebRtcVideoCapturer());
if (!capturer->Init(device)) {
return NULL;
}
return capturer.release();
}
} // namespace cricket

View File

@ -0,0 +1,43 @@
// libjingle
// Copyright 2014 Google Inc.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are met:
//
// 1. Redistributions of source code must retain the above copyright notice,
// this list of conditions and the following disclaimer.
// 2. Redistributions in binary form must reproduce the above copyright notice,
// this list of conditions and the following disclaimer in the documentation
// and/or other materials provided with the distribution.
// 3. The name of the author may not be used to endorse or promote products
// derived from this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
// WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
// MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
// EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
// OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
// ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
//
// TODO(pthatcher): Reneme file to match class name.
#ifndef TALK_MEDIA_WEBRTC_WEBRTCVIDEOCAPTURERFACTORY_H_
#define TALK_MEDIA_WEBRTC_WEBRTCVIDEOCAPTURERFACTORY_H_
#include "talk/media/base/videocapturerfactory.h"
namespace cricket {
// Creates instances of cricket::WebRtcVideoCapturer.
class WebRtcVideoDeviceCapturerFactory : public VideoDeviceCapturerFactory {
public:
virtual VideoCapturer* Create(const Device& device);
};
} // namespace cricket
#endif // TALK_MEDIA_WEBRTC_WEBRTCVIDEOCAPTURERFACTORY_H_

View File

@ -493,7 +493,7 @@ cricket::VideoFormat ScreencastFormatFromFps(int fps) {
bool Call::StartScreencast(Session* session, bool Call::StartScreencast(Session* session,
const std::string& streamid, uint32 ssrc, const std::string& streamid, uint32 ssrc,
const ScreencastId& screencastid, int fps) { const ScreencastId& screenid, int fps) {
MediaSessionMap::iterator it = media_session_map_.find(session->id()); MediaSessionMap::iterator it = media_session_map_.find(session->id());
if (it == media_session_map_.end()) { if (it == media_session_map_.end()) {
return false; return false;
@ -506,12 +506,19 @@ bool Call::StartScreencast(Session* session,
return false; return false;
} }
VideoCapturer *capturer = video_channel->AddScreencast(ssrc, screencastid); VideoCapturer* capturer = session_client_->channel_manager()->
if (capturer == NULL) { CreateScreenCapturer(screenid);
if (!capturer) {
LOG(LS_WARNING) << "Could not create screencast capturer."; LOG(LS_WARNING) << "Could not create screencast capturer.";
return false; return false;
} }
if (!video_channel->AddScreencast(ssrc, capturer)) {
delete capturer;
LOG(LS_WARNING) << "Could not add screencast capturer.";
return false;
}
VideoFormat format = ScreencastFormatFromFps(fps); VideoFormat format = ScreencastFormatFromFps(fps);
if (!session_client_->channel_manager()->StartVideoCapture( if (!session_client_->channel_manager()->StartVideoCapture(
capturer, format)) { capturer, format)) {

View File

@ -115,7 +115,7 @@ class Call : public rtc::MessageHandler, public sigslot::has_slots<> {
void PressDTMF(int event); void PressDTMF(int event);
bool StartScreencast(Session* session, bool StartScreencast(Session* session,
const std::string& stream_name, uint32 ssrc, const std::string& stream_name, uint32 ssrc,
const ScreencastId& screencastid, int fps); const ScreencastId& screenid, int fps);
bool StopScreencast(Session* session, bool StopScreencast(Session* session,
const std::string& stream_name, uint32 ssrc); const std::string& stream_name, uint32 ssrc);

View File

@ -73,20 +73,6 @@ static void SafeSetError(const std::string& message, std::string* error_desc) {
} }
} }
// TODO(hellner): use the device manager for creation of screen capturers when
// the cl enabling it has landed.
class NullScreenCapturerFactory : public VideoChannel::ScreenCapturerFactory {
public:
VideoCapturer* CreateScreenCapturer(const ScreencastId& window) {
return NULL;
}
};
VideoChannel::ScreenCapturerFactory* CreateScreenCapturerFactory() {
return new NullScreenCapturerFactory();
}
struct PacketMessageData : public rtc::MessageData { struct PacketMessageData : public rtc::MessageData {
rtc::Buffer packet; rtc::Buffer packet;
rtc::DiffServCodePoint dscp; rtc::DiffServCodePoint dscp;
@ -1674,7 +1660,6 @@ VideoChannel::VideoChannel(rtc::Thread* thread,
rtcp), rtcp),
voice_channel_(voice_channel), voice_channel_(voice_channel),
renderer_(NULL), renderer_(NULL),
screencapture_factory_(CreateScreenCapturerFactory()),
previous_we_(rtc::WE_CLOSE) { previous_we_(rtc::WE_CLOSE) {
} }
@ -1729,10 +1714,9 @@ bool VideoChannel::ApplyViewRequest(const ViewRequest& request) {
return InvokeOnWorker(Bind(&VideoChannel::ApplyViewRequest_w, this, request)); return InvokeOnWorker(Bind(&VideoChannel::ApplyViewRequest_w, this, request));
} }
VideoCapturer* VideoChannel::AddScreencast( bool VideoChannel::AddScreencast(uint32 ssrc, VideoCapturer* capturer) {
uint32 ssrc, const ScreencastId& id) { return worker_thread()->Invoke<bool>(Bind(
return worker_thread()->Invoke<VideoCapturer*>(Bind( &VideoChannel::AddScreencast_w, this, ssrc, capturer));
&VideoChannel::AddScreencast_w, this, ssrc, id));
} }
bool VideoChannel::SetCapturer(uint32 ssrc, VideoCapturer* capturer) { bool VideoChannel::SetCapturer(uint32 ssrc, VideoCapturer* capturer) {
@ -1774,13 +1758,6 @@ bool VideoChannel::RequestIntraFrame() {
return true; return true;
} }
void VideoChannel::SetScreenCaptureFactory(
ScreenCapturerFactory* screencapture_factory) {
worker_thread()->Invoke<void>(Bind(
&VideoChannel::SetScreenCaptureFactory_w,
this, screencapture_factory));
}
void VideoChannel::ChangeState() { void VideoChannel::ChangeState() {
// Render incoming data if we're the active call, and we have the local // Render incoming data if we're the active call, and we have the local
// content. We receive data on the default channel and multiplexed streams. // content. We receive data on the default channel and multiplexed streams.
@ -1960,20 +1937,13 @@ bool VideoChannel::ApplyViewRequest_w(const ViewRequest& request) {
return ret; return ret;
} }
VideoCapturer* VideoChannel::AddScreencast_w( bool VideoChannel::AddScreencast_w(uint32 ssrc, VideoCapturer* capturer) {
uint32 ssrc, const ScreencastId& id) {
if (screencast_capturers_.find(ssrc) != screencast_capturers_.end()) { if (screencast_capturers_.find(ssrc) != screencast_capturers_.end()) {
return NULL; return false;
} }
VideoCapturer* screen_capturer = capturer->SignalStateChange.connect(this, &VideoChannel::OnStateChange);
screencapture_factory_->CreateScreenCapturer(id); screencast_capturers_[ssrc] = capturer;
if (!screen_capturer) { return true;
return NULL;
}
screen_capturer->SignalStateChange.connect(this,
&VideoChannel::OnStateChange);
screencast_capturers_[ssrc] = screen_capturer;
return screen_capturer;
} }
bool VideoChannel::RemoveScreencast_w(uint32 ssrc) { bool VideoChannel::RemoveScreencast_w(uint32 ssrc) {
@ -2003,15 +1973,6 @@ void VideoChannel::GetScreencastDetails_w(
data->screencast_max_pixels = capturer->screencast_max_pixels(); data->screencast_max_pixels = capturer->screencast_max_pixels();
} }
void VideoChannel::SetScreenCaptureFactory_w(
ScreenCapturerFactory* screencapture_factory) {
if (screencapture_factory == NULL) {
screencapture_factory_.reset(CreateScreenCapturerFactory());
} else {
screencapture_factory_.reset(screencapture_factory);
}
}
void VideoChannel::OnScreencastWindowEvent_s(uint32 ssrc, void VideoChannel::OnScreencastWindowEvent_s(uint32 ssrc,
rtc::WindowEvent we) { rtc::WindowEvent we) {
ASSERT(signaling_thread() == rtc::Thread::Current()); ASSERT(signaling_thread() == rtc::Thread::Current());

View File

@ -38,7 +38,6 @@
#include "webrtc/base/window.h" #include "webrtc/base/window.h"
#include "talk/media/base/mediachannel.h" #include "talk/media/base/mediachannel.h"
#include "talk/media/base/mediaengine.h" #include "talk/media/base/mediaengine.h"
#include "talk/media/base/screencastid.h"
#include "talk/media/base/streamparams.h" #include "talk/media/base/streamparams.h"
#include "talk/media/base/videocapturer.h" #include "talk/media/base/videocapturer.h"
#include "talk/p2p/base/session.h" #include "talk/p2p/base/session.h"
@ -508,14 +507,6 @@ class VoiceChannel : public BaseChannel {
// VideoChannel is a specialization for video. // VideoChannel is a specialization for video.
class VideoChannel : public BaseChannel { class VideoChannel : public BaseChannel {
public: public:
// Make screen capturer virtual so that it can be overriden in testing.
// E.g. used to test that window events are triggered correctly.
class ScreenCapturerFactory {
public:
virtual VideoCapturer* CreateScreenCapturer(const ScreencastId& window) = 0;
virtual ~ScreenCapturerFactory() {}
};
VideoChannel(rtc::Thread* thread, MediaEngineInterface* media_engine, VideoChannel(rtc::Thread* thread, MediaEngineInterface* media_engine,
VideoMediaChannel* channel, BaseSession* session, VideoMediaChannel* channel, BaseSession* session,
const std::string& content_name, bool rtcp, const std::string& content_name, bool rtcp,
@ -528,7 +519,8 @@ class VideoChannel : public BaseChannel {
// TODO(pthatcher): Refactor to use a "capture id" instead of an // TODO(pthatcher): Refactor to use a "capture id" instead of an
// ssrc here as the "key". // ssrc here as the "key".
VideoCapturer* AddScreencast(uint32 ssrc, const ScreencastId& id); // Passes ownership of the capturer to the channel.
bool AddScreencast(uint32 ssrc, VideoCapturer* capturer);
bool SetCapturer(uint32 ssrc, VideoCapturer* capturer); bool SetCapturer(uint32 ssrc, VideoCapturer* capturer);
bool RemoveScreencast(uint32 ssrc); bool RemoveScreencast(uint32 ssrc);
// True if we've added a screencast. Doesn't matter if the capturer // True if we've added a screencast. Doesn't matter if the capturer
@ -552,9 +544,6 @@ class VideoChannel : public BaseChannel {
sigslot::signal3<VideoChannel*, uint32, VideoMediaChannel::Error> sigslot::signal3<VideoChannel*, uint32, VideoMediaChannel::Error>
SignalMediaError; SignalMediaError;
void SetScreenCaptureFactory(
ScreenCapturerFactory* screencapture_factory);
// Configuration and setting. // Configuration and setting.
bool SetChannelOptions(const VideoOptions& options); bool SetChannelOptions(const VideoOptions& options);
@ -579,13 +568,11 @@ class VideoChannel : public BaseChannel {
std::string* error_desc); std::string* error_desc);
bool ApplyViewRequest_w(const ViewRequest& request); bool ApplyViewRequest_w(const ViewRequest& request);
VideoCapturer* AddScreencast_w(uint32 ssrc, const ScreencastId& id); bool AddScreencast_w(uint32 ssrc, VideoCapturer* capturer);
bool RemoveScreencast_w(uint32 ssrc); bool RemoveScreencast_w(uint32 ssrc);
void OnScreencastWindowEvent_s(uint32 ssrc, rtc::WindowEvent we); void OnScreencastWindowEvent_s(uint32 ssrc, rtc::WindowEvent we);
bool IsScreencasting_w() const; bool IsScreencasting_w() const;
void GetScreencastDetails_w(ScreencastDetailsData* d) const; void GetScreencastDetails_w(ScreencastDetailsData* d) const;
void SetScreenCaptureFactory_w(
ScreenCapturerFactory* screencapture_factory);
bool GetStats_w(VideoMediaInfo* stats); bool GetStats_w(VideoMediaInfo* stats);
virtual void OnMessage(rtc::Message* pmsg); virtual void OnMessage(rtc::Message* pmsg);
@ -604,7 +591,6 @@ class VideoChannel : public BaseChannel {
VoiceChannel* voice_channel_; VoiceChannel* voice_channel_;
VideoRenderer* renderer_; VideoRenderer* renderer_;
rtc::scoped_ptr<ScreenCapturerFactory> screencapture_factory_;
ScreencastMap screencast_capturers_; ScreencastMap screencast_capturers_;
rtc::scoped_ptr<VideoMediaMonitor> media_monitor_; rtc::scoped_ptr<VideoMediaMonitor> media_monitor_;

View File

@ -33,6 +33,7 @@
#include "webrtc/base/sslidentity.h" #include "webrtc/base/sslidentity.h"
#include "webrtc/base/window.h" #include "webrtc/base/window.h"
#include "talk/media/base/fakemediaengine.h" #include "talk/media/base/fakemediaengine.h"
#include "talk/media/base/fakescreencapturerfactory.h"
#include "talk/media/base/fakertp.h" #include "talk/media/base/fakertp.h"
#include "talk/media/base/fakevideocapturer.h" #include "talk/media/base/fakevideocapturer.h"
#include "talk/media/base/mediachannel.h" #include "talk/media/base/mediachannel.h"
@ -88,49 +89,6 @@ class Traits {
typedef MediaInfoT MediaInfo; typedef MediaInfoT MediaInfo;
}; };
class FakeScreenCaptureFactory
: public cricket::VideoChannel::ScreenCapturerFactory,
public sigslot::has_slots<> {
public:
FakeScreenCaptureFactory()
: window_capturer_(NULL),
capture_state_(cricket::CS_STOPPED) {}
virtual cricket::VideoCapturer* CreateScreenCapturer(
const ScreencastId& window) {
if (window_capturer_ != NULL) {
// Class is only designed to handle one fake screencapturer.
ADD_FAILURE();
return NULL;
}
window_capturer_ = new cricket::FakeVideoCapturer;
window_capturer_->SignalDestroyed.connect(
this,
&FakeScreenCaptureFactory::OnWindowCapturerDestroyed);
window_capturer_->SignalStateChange.connect(
this,
&FakeScreenCaptureFactory::OnStateChange);
return window_capturer_;
}
cricket::FakeVideoCapturer* window_capturer() { return window_capturer_; }
cricket::CaptureState capture_state() { return capture_state_; }
private:
void OnWindowCapturerDestroyed(cricket::FakeVideoCapturer* capturer) {
if (capturer == window_capturer_) {
window_capturer_ = NULL;
}
}
void OnStateChange(cricket::VideoCapturer*, cricket::CaptureState state) {
capture_state_ = state;
}
cricket::FakeVideoCapturer* window_capturer_;
cricket::CaptureState capture_state_;
};
// Controls how long we wait for a session to send messages that we // Controls how long we wait for a session to send messages that we
// expect, in milliseconds. We put it high to avoid flaky tests. // expect, in milliseconds. We put it high to avoid flaky tests.
static const int kEventTimeout = 5000; static const int kEventTimeout = 5000;
@ -2469,28 +2427,31 @@ TEST_F(VideoChannelTest, TestStreams) {
TEST_F(VideoChannelTest, TestScreencastEvents) { TEST_F(VideoChannelTest, TestScreencastEvents) {
const int kTimeoutMs = 500; const int kTimeoutMs = 500;
TestInit(); TestInit();
FakeScreenCaptureFactory* screencapture_factory =
new FakeScreenCaptureFactory();
channel1_->SetScreenCaptureFactory(screencapture_factory);
cricket::ScreencastEventCatcher catcher; cricket::ScreencastEventCatcher catcher;
channel1_->SignalScreencastWindowEvent.connect( channel1_->SignalScreencastWindowEvent.connect(
&catcher, &catcher,
&cricket::ScreencastEventCatcher::OnEvent); &cricket::ScreencastEventCatcher::OnEvent);
EXPECT_TRUE(channel1_->AddScreencast(0, ScreencastId(WindowId(0))) != NULL);
ASSERT_TRUE(screencapture_factory->window_capturer() != NULL); rtc::scoped_ptr<cricket::FakeScreenCapturerFactory>
EXPECT_EQ_WAIT(cricket::CS_STOPPED, screencapture_factory->capture_state(), screen_capturer_factory(new cricket::FakeScreenCapturerFactory());
cricket::VideoCapturer* screen_capturer = screen_capturer_factory->Create(
ScreencastId(WindowId(0)));
ASSERT_TRUE(screen_capturer != NULL);
EXPECT_TRUE(channel1_->AddScreencast(0, screen_capturer));
EXPECT_EQ_WAIT(cricket::CS_STOPPED, screen_capturer_factory->capture_state(),
kTimeoutMs); kTimeoutMs);
screencapture_factory->window_capturer()->SignalStateChange(
screencapture_factory->window_capturer(), cricket::CS_PAUSED); screen_capturer->SignalStateChange(screen_capturer, cricket::CS_PAUSED);
EXPECT_EQ_WAIT(rtc::WE_MINIMIZE, catcher.event(), kTimeoutMs); EXPECT_EQ_WAIT(rtc::WE_MINIMIZE, catcher.event(), kTimeoutMs);
screencapture_factory->window_capturer()->SignalStateChange(
screencapture_factory->window_capturer(), cricket::CS_RUNNING); screen_capturer->SignalStateChange(screen_capturer, cricket::CS_RUNNING);
EXPECT_EQ_WAIT(rtc::WE_RESTORE, catcher.event(), kTimeoutMs); EXPECT_EQ_WAIT(rtc::WE_RESTORE, catcher.event(), kTimeoutMs);
screencapture_factory->window_capturer()->SignalStateChange(
screencapture_factory->window_capturer(), cricket::CS_STOPPED); screen_capturer->SignalStateChange(screen_capturer, cricket::CS_STOPPED);
EXPECT_EQ_WAIT(rtc::WE_CLOSE, catcher.event(), kTimeoutMs); EXPECT_EQ_WAIT(rtc::WE_CLOSE, catcher.event(), kTimeoutMs);
EXPECT_TRUE(channel1_->RemoveScreencast(0)); EXPECT_TRUE(channel1_->RemoveScreencast(0));
ASSERT_TRUE(screencapture_factory->window_capturer() == NULL);
} }
TEST_F(VideoChannelTest, TestUpdateStreamsInLocalContent) { TEST_F(VideoChannelTest, TestUpdateStreamsInLocalContent) {

View File

@ -710,6 +710,11 @@ VideoCapturer* ChannelManager::CreateVideoCapturer() {
return capturer; return capturer;
} }
VideoCapturer* ChannelManager::CreateScreenCapturer(
const ScreencastId& screenid) {
return device_manager_->CreateScreenCapturer(screenid);
}
bool ChannelManager::SetCaptureDevice_w(const Device* cam_device) { bool ChannelManager::SetCaptureDevice_w(const Device* cam_device) {
ASSERT(worker_thread_ == rtc::Thread::Current()); ASSERT(worker_thread_ == rtc::Thread::Current());
ASSERT(initialized_); ASSERT(initialized_);

View File

@ -157,6 +157,8 @@ class ChannelManager : public rtc::MessageHandler,
bool GetVideoCaptureDevice(Device* device); bool GetVideoCaptureDevice(Device* device);
// Create capturer based on what has been set in SetCaptureDevice(). // Create capturer based on what has been set in SetCaptureDevice().
VideoCapturer* CreateVideoCapturer(); VideoCapturer* CreateVideoCapturer();
// Create capturer from a screen.
VideoCapturer* CreateScreenCapturer(const ScreencastId& screenid);
bool SetCaptureDevice(const std::string& cam_device); bool SetCaptureDevice(const std::string& cam_device);
bool SetDefaultVideoEncoderConfig(const VideoEncoderConfig& config); bool SetDefaultVideoEncoderConfig(const VideoEncoderConfig& config);
// RTX will be enabled/disabled in engines that support it. The supporting // RTX will be enabled/disabled in engines that support it. The supporting
@ -240,6 +242,9 @@ class ChannelManager : public rtc::MessageHandler,
const AudioOptions& options, const AudioOptions& options,
int delay_offset); int delay_offset);
int audio_delay_offset() const { return audio_delay_offset_; } int audio_delay_offset() const { return audio_delay_offset_; }
// This is here so that ChannelManager subclasses can set the video
// capturer factories to use.
DeviceManagerInterface* device_manager() { return device_manager_.get(); }
private: private:
typedef std::vector<VoiceChannel*> VoiceChannels; typedef std::vector<VoiceChannel*> VoiceChannels;