OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 // Implementation notes: This needs to work on a variety of hardware | 5 // Implementation notes: This needs to work on a variety of hardware |
6 // configurations where the speed of the CPU and GPU greatly affect overall | 6 // configurations where the speed of the CPU and GPU greatly affect overall |
7 // performance. Therefore, the process of capturing has been split up into a | 7 // performance. Therefore, the process of capturing has been split up into a |
8 // pipeline of three stages. Each stage executes on its own thread: | 8 // pipeline of three stages. Each stage executes on its own thread: |
9 // | 9 // |
10 // 1. Capture: A bitmap is snapshotted/copied from the RenderView's backing | 10 // 1. Capture: A bitmap is snapshotted/copied from the RenderView's backing |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
45 | 45 |
46 #include "base/basictypes.h" | 46 #include "base/basictypes.h" |
47 #include "base/bind.h" | 47 #include "base/bind.h" |
48 #include "base/bind_helpers.h" | 48 #include "base/bind_helpers.h" |
49 #include "base/callback_forward.h" | 49 #include "base/callback_forward.h" |
50 #include "base/debug/trace_event.h" | 50 #include "base/debug/trace_event.h" |
51 #include "base/logging.h" | 51 #include "base/logging.h" |
52 #include "base/memory/scoped_ptr.h" | 52 #include "base/memory/scoped_ptr.h" |
53 #include "base/string_number_conversions.h" | 53 #include "base/string_number_conversions.h" |
54 #include "base/string_piece.h" | 54 #include "base/string_piece.h" |
| 55 #include "base/string_util.h" |
55 #include "base/stringprintf.h" | 56 #include "base/stringprintf.h" |
56 #include "base/synchronization/lock.h" | 57 #include "base/synchronization/lock.h" |
57 #include "base/threading/thread.h" | 58 #include "base/threading/thread.h" |
58 #include "base/time.h" | 59 #include "base/time.h" |
59 #include "content/public/browser/browser_thread.h" | 60 #include "content/public/browser/browser_thread.h" |
60 #include "content/public/browser/render_process_host.h" | 61 #include "content/public/browser/render_process_host.h" |
61 #include "content/public/browser/render_view_host.h" | 62 #include "content/public/browser/render_view_host.h" |
62 #include "content/public/browser/render_widget_host_view.h" | 63 #include "content/public/browser/render_widget_host_view.h" |
63 #include "content/public/browser/web_contents.h" | 64 #include "content/public/browser/web_contents.h" |
64 #include "content/public/browser/web_contents_observer.h" | 65 #include "content/public/browser/web_contents_observer.h" |
| 66 #include "content/public/common/media_stream_request.h" |
65 #include "media/base/bind_to_loop.h" | 67 #include "media/base/bind_to_loop.h" |
66 #include "media/video/capture/video_capture_types.h" | 68 #include "media/video/capture/video_capture_types.h" |
67 #include "skia/ext/image_operations.h" | 69 #include "skia/ext/image_operations.h" |
68 #include "skia/ext/platform_canvas.h" | 70 #include "skia/ext/platform_canvas.h" |
69 #include "third_party/skia/include/core/SkBitmap.h" | 71 #include "third_party/skia/include/core/SkBitmap.h" |
70 #include "third_party/skia/include/core/SkColor.h" | 72 #include "third_party/skia/include/core/SkColor.h" |
71 #include "ui/gfx/rect.h" | 73 #include "ui/gfx/rect.h" |
72 | 74 |
73 // TODO(miu): The caller of Allocate() should use an appropriate heuristic to | 75 // TODO(miu): The caller of Allocate() should use an appropriate heuristic to |
74 // determine the frame size. For now, hard-code the capture device to 720p | 76 // determine the frame size. For now, hard-code the capture device to 720p |
(...skipping 888 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
963 device_name_.unique_id = "-1:-1"; | 965 device_name_.unique_id = "-1:-1"; |
964 capturer_->InitializeForTesting(test_source, destroy_cb); | 966 capturer_->InitializeForTesting(test_source, destroy_cb); |
965 } | 967 } |
966 | 968 |
967 WebContentsVideoCaptureDevice::~WebContentsVideoCaptureDevice() { | 969 WebContentsVideoCaptureDevice::~WebContentsVideoCaptureDevice() { |
968 DVLOG(2) << "WebContentsVideoCaptureDevice@" << this << " destroying."; | 970 DVLOG(2) << "WebContentsVideoCaptureDevice@" << this << " destroying."; |
969 } | 971 } |
970 | 972 |
971 // static | 973 // static |
972 media::VideoCaptureDevice* WebContentsVideoCaptureDevice::Create( | 974 media::VideoCaptureDevice* WebContentsVideoCaptureDevice::Create( |
973 const std::string& device_id) { | 975 const std::string& device_id_param) { |
| 976 DCHECK(StartsWithASCII(device_id_param, |
| 977 content::kMediaStreamTabDeviceScheme, true)); |
| 978 const std::string device_id = device_id_param.substr( |
| 979 strlen(content::kMediaStreamTabDeviceScheme), |
| 980 device_id_param.length()); |
| 981 |
974 // Parse device_id into render_process_id and render_view_id. | 982 // Parse device_id into render_process_id and render_view_id. |
975 const size_t sep_pos = device_id.find(':'); | 983 const size_t sep_pos = device_id.find(':'); |
976 if (sep_pos == std::string::npos) { | 984 if (sep_pos == std::string::npos) { |
977 return NULL; | 985 return NULL; |
978 } | 986 } |
979 const base::StringPiece component1(device_id.data(), sep_pos); | 987 const base::StringPiece component1(device_id.data(), sep_pos); |
980 const base::StringPiece component2(device_id.data() + sep_pos + 1, | 988 const base::StringPiece component2(device_id.data() + sep_pos + 1, |
981 device_id.length() - sep_pos - 1); | 989 device_id.length() - sep_pos - 1); |
982 int render_process_id = -1; | 990 int render_process_id = -1; |
983 int render_view_id = -1; | 991 int render_view_id = -1; |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1025 capturer_->SetConsumer(NULL); | 1033 capturer_->SetConsumer(NULL); |
1026 capturer_->DeAllocate(); | 1034 capturer_->DeAllocate(); |
1027 } | 1035 } |
1028 | 1036 |
1029 const media::VideoCaptureDevice::Name& | 1037 const media::VideoCaptureDevice::Name& |
1030 WebContentsVideoCaptureDevice::device_name() { | 1038 WebContentsVideoCaptureDevice::device_name() { |
1031 return device_name_; | 1039 return device_name_; |
1032 } | 1040 } |
1033 | 1041 |
1034 } // namespace content | 1042 } // namespace content |
OLD | NEW |