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

Side by Side Diff: content/public/browser/web_contents_media_capture_id.h

Issue 1503563004: Desktop chrome tab capture-chooseDesktopMedia() (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 11 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
OLDNEW
(Empty)
1 // Copyright 2016 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 #ifndef CONTENT_PUBLIC_BROWSER_WEB_CONTENTS_MEDIA_CAPTURE_ID_H_
6 #define CONTENT_PUBLIC_BROWSER_WEB_CONTENTS_MEDIA_CAPTURE_ID_H_
7
8 #include <string>
9
10 #include "content/common/content_export.h"
11 #include "ipc/ipc_message.h"
12
13 namespace content {
14
15 struct CONTENT_EXPORT WebContentsMediaCaptureId {
16 public:
17 WebContentsMediaCaptureId() = default;
18 WebContentsMediaCaptureId(int render_process_id, int main_render_frame_id)
19 : render_process_id(render_process_id),
20 main_render_frame_id(main_render_frame_id) {}
21
22 WebContentsMediaCaptureId(int render_process_id,
23 int main_render_frame_id,
24 bool enable_auto_throttling)
25 : render_process_id(render_process_id),
26 main_render_frame_id(main_render_frame_id),
27 enable_auto_throttling(enable_auto_throttling) {}
28
29 bool operator<(const WebContentsMediaCaptureId& other) const;
30 bool operator==(const WebContentsMediaCaptureId& other) const;
31
32 // Return true if render_process_id or main_render_frame_id is invalid.
33 bool is_null() const;
34
35 std::string ToString() const;
36
37 // Tab video and audio capture need render process id and render frame id.
38 int render_process_id = MSG_ROUTING_NONE;
39 int main_render_frame_id = MSG_ROUTING_NONE;
40
41 bool enable_auto_throttling = false;
42
43 // Create WebContentsMediaCaptureId based on a string.
44 static WebContentsMediaCaptureId Parse(const std::string& str);
45
46 // Check whether the device id indicates that this is a web contents stream.
47 static bool IsWebContentsDeviceId(const std::string& device_id);
48
49 // Function to extract the target render frame id's from a media stream
50 // request's device id.
51 static bool ExtractTabCaptureTarget(const std::string& device_id,
52 int* render_process_id,
53 int* main_render_frame_id);
54
55 // Parses the media stream request |device_id| and returns true if both 1) the
56 // format is valid, and 2) the throttling option is set to auto.
57 static bool IsAutoThrottlingOptionSet(const std::string& device_id);
58 };
59
60 } // namespace content
61
62 #endif // CONTENT_PUBLIC_BROWSER_WEB_CONTENTS_MEDIA_CAPTURE_ID_H_
OLDNEW
« no previous file with comments | « content/public/browser/desktop_media_id.cc ('k') | content/public/browser/web_contents_media_capture_id.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698