Integrate ScreenCapturerSck with SCContentSharingPicker

This patch at a high level does the following:
- Hooks CreateGenericCapturer to create a ScreenCapturerSck with
  SCContentSharingPicker if allowed by options and runtime checks (macOS
  14). It allows both single display and multiple windows picker modes.
- Creates a new SckPickerHandle singleton class that manages the number
  of active pickers, and sets the `active` flag on the shared system
  picker. It also generates a unique SourceId for each capturer, since
  the source of a capturer that uses the picker isn't constant and
  therefore cannot be shared across multiple clients.
- Hooks up SCContentSharingPickerObserver callbacks to expose a
  permanent error in case of an error or picker cancellation.

The API for the generic capturer is as any other desktop capture
backend:
- GetSourceList() and SelectSource() works as normal but don't do
  anything useful.
- Start() displays the picker and makes CaptureFrame() start returning
  temporary errors.
- On selection, capture starts and CaptureFrame() starts returning
  frames.
- On cancelling the picker, or if there's an error, CaptureFrame()
  starts returning permanent errors.

Bug: webrtc:367915807
Change-Id: I75cd78897f2e7c9702a5f5683d21ee1a7ea914d5
Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/365094
Reviewed-by: Johannes Kron <kron@webrtc.org>
Reviewed-by: Alexander Cooper <alcooper@chromium.org>
Reviewed-by: Tomas Gunnarsson <tommi@webrtc.org>
Commit-Queue: Andreas Pehrson <apehrson@mozilla.com>
Cr-Commit-Position: refs/heads/main@{#44426}
8 files changed
tree: da8824b2be9eeb9b4f118575f35f94a67b27c34a
  1. api/
  2. audio/
  3. build_overrides/
  4. call/
  5. common_audio/
  6. common_video/
  7. data/
  8. docs/
  9. examples/
  10. experiments/
  11. g3doc/
  12. infra/
  13. logging/
  14. media/
  15. modules/
  16. net/
  17. p2p/
  18. pc/
  19. resources/
  20. rtc_base/
  21. rtc_tools/
  22. sdk/
  23. stats/
  24. system_wrappers/
  25. test/
  26. tools_webrtc/
  27. video/
  28. .clang-format
  29. .git-blame-ignore-revs
  30. .gitignore
  31. .gn
  32. .mailmap
  33. .rustfmt.toml
  34. .style.yapf
  35. .vpython3
  36. AUTHORS
  37. BUILD.gn
  38. CODE_OF_CONDUCT.md
  39. codereview.settings
  40. DEPS
  41. DIR_METADATA
  42. ENG_REVIEW_OWNERS
  43. LICENSE
  44. license_template.txt
  45. native-api.md
  46. OWNERS
  47. OWNERS_INFRA
  48. PATENTS
  49. PRESUBMIT.py
  50. presubmit_test.py
  51. presubmit_test_mocks.py
  52. pylintrc
  53. pylintrc_old_style
  54. README.chromium
  55. README.md
  56. WATCHLISTS
  57. webrtc.gni
  58. webrtc_lib_link_test.cc
  59. whitespace.txt
README.md

WebRTC is a free, open software project that provides browsers and mobile applications with Real-Time Communications (RTC) capabilities via simple APIs. The WebRTC components have been optimized to best serve this purpose.

Our mission: To enable rich, high-quality RTC applications to be developed for the browser, mobile platforms, and IoT devices, and allow them all to communicate via a common set of protocols.

The WebRTC initiative is a project supported by Google, Mozilla and Opera, amongst others.

Development

See here for instructions on how to get started developing with the native code.

Authoritative list of directories that contain the native API header files.

More info