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

Side by Side Diff: content/renderer/media/video_capture_impl_manager.cc

Issue 6902166: Add VideoCaptureImpl (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 years, 7 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 unified diff | Download patch | Annotate | Revision Log
Property Changes:
Added: svn:eol-style
+ LF
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "content/renderer/media/video_capture_impl_manager.h"
6
7 #include "base/memory/singleton.h"
8 #include "content/common/child_process.h"
9 #include "content/common/child_thread.h"
10 #include "content/common/video_capture_messages.h"
11 #include "content/common/view_messages.h"
12 #include "media/base/message_loop_factory_impl.h"
13
14 namespace {
15
16 // VideoCaptureMessageFilterCreator is to be used as a singleton so we can get
17 // access to a shared VideoCaptureMessageFilter.
18 // Example usage:
19 // VideoCaptureMessageFilter* filter =
20 // VideoCaptureMessageFilterCreator::SharedFilter();
21
22 class VideoCaptureMessageFilterCreator {
23 public:
24 VideoCaptureMessageFilterCreator() {
25 int routing_id;
26 ChildThread::current()->Send(
27 new ViewHostMsg_GenerateRoutingID(&routing_id));
28 filter_ = new VideoCaptureMessageFilter(routing_id);
29 filter_->AddFilter();
30 }
31
32 static VideoCaptureMessageFilter* SharedFilter() {
33 return GetInstance()->filter_.get();
34 }
35
36 static VideoCaptureMessageFilterCreator* GetInstance() {
37 return Singleton<VideoCaptureMessageFilterCreator>::get();
38 }
39
40 private:
41 scoped_refptr<VideoCaptureMessageFilter> filter_;
42 };
43
44 } // namespace
45
46 VideoCaptureImplManager::VideoCaptureImplManager() {
47 ml_factory_.reset(new media::MessageLoopFactoryImpl());
48 ml_proxy_ = ml_factory_->GetMessageLoopProxy("VC manager");
49 }
50
51 // static
52 media::VideoCapture* VideoCaptureImplManager::AddDevice(
53 media::VideoCaptureSessionId id,
54 media::VideoCapture::EventHandler* handler) {
55 DCHECK(handler);
56 VideoCaptureImplManager* manager = GetInstance();
57
58 base::AutoLock auto_lock(manager->lock_);
59 Devices::iterator it = manager->devices_.find(id);
60 if (it == manager->devices_.end()) {
61 VideoCaptureImpl* vc =
62 new VideoCaptureImpl(id, manager->ml_proxy_,
63 VideoCaptureMessageFilterCreator::SharedFilter());
64 manager->devices_[id] = Device(vc, handler);
65 vc->Init();
66 return vc;
67 }
68
69 manager->devices_[id].clients.push_front(handler);
70 return it->second.vc;
71 }
72
73 // static
74 void VideoCaptureImplManager::RemoveDevice(
75 media::VideoCaptureSessionId id,
76 media::VideoCapture::EventHandler* handler) {
77 DCHECK(handler);
78 VideoCaptureImplManager* manager = GetInstance();
79
80 base::AutoLock auto_lock(manager->lock_);
81 Devices::iterator it = manager->devices_.find(id);
82 if (it == manager->devices_.end())
83 return;
84
85 size_t size = it->second.clients.size();
86 it->second.clients.remove(handler);
87
88 if (size == it->second.clients.size() || size > 1)
89 return;
90
91 manager->devices_[id].vc->DeInit(NewRunnableMethod(manager,
92 &VideoCaptureImplManager::FreeDevice, manager->devices_[id].vc));
93 manager->devices_.erase(id);
94 return;
95 }
96
97 // static
98 VideoCaptureImplManager* VideoCaptureImplManager::GetInstance() {
99 return Singleton<VideoCaptureImplManager>::get();
100 }
101
102 void VideoCaptureImplManager::FreeDevice(VideoCaptureImpl* vc) {
103 delete vc;
104 }
105
106 VideoCaptureImplManager::Device::Device() : vc(NULL) {}
107
108 VideoCaptureImplManager::Device::Device(
109 VideoCaptureImpl* device,
110 media::VideoCapture::EventHandler* handler)
111 : vc(device) {
112 clients.push_front(handler);
113 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698