2018-10-24 18:24:11 +00:00
|
|
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
|
|
|
From: deepak1556 <hop2deep@gmail.com>
|
|
|
|
Date: Thu, 18 Oct 2018 17:07:01 -0700
|
|
|
|
Subject: desktop_media_list.patch
|
|
|
|
|
2021-09-03 23:37:36 +00:00
|
|
|
* Use our grit resources instead of the chrome ones.
|
2021-08-24 00:52:17 +00:00
|
|
|
* Disabled WindowCaptureMacV2 feature for https://github.com/electron/electron/pull/30507
|
2021-11-30 23:12:39 +00:00
|
|
|
* Ensure "OnRefreshComplete()" even if there are no items in the list
|
2021-05-18 22:44:46 +00:00
|
|
|
|
2018-10-03 12:26:42 +00:00
|
|
|
diff --git a/chrome/browser/media/webrtc/desktop_media_list.h b/chrome/browser/media/webrtc/desktop_media_list.h
|
2022-01-12 07:39:49 +00:00
|
|
|
index 57cfc646f8ea545271c22d79ec158a04b148bc9c..c5339603930f68e7019ca33d8b9f148cf4ac86af 100644
|
2018-10-03 12:26:42 +00:00
|
|
|
--- a/chrome/browser/media/webrtc/desktop_media_list.h
|
|
|
|
+++ b/chrome/browser/media/webrtc/desktop_media_list.h
|
2022-01-12 07:39:49 +00:00
|
|
|
@@ -94,7 +94,8 @@ class DesktopMediaList {
|
2021-09-03 23:37:36 +00:00
|
|
|
// once per DesktopMediaList instance. It should not be called after
|
|
|
|
// StartUpdating(), and StartUpdating() should not be called until |callback|
|
|
|
|
// has been called.
|
|
|
|
- virtual void Update(UpdateCallback callback) = 0;
|
2022-01-12 07:39:49 +00:00
|
|
|
+ virtual void Update(UpdateCallback callback,
|
|
|
|
+ bool refresh_thumbnails = false) = 0;
|
2018-10-03 12:26:42 +00:00
|
|
|
|
|
|
|
virtual int GetSourceCount() const = 0;
|
|
|
|
virtual const Source& GetSource(int index) const = 0;
|
|
|
|
diff --git a/chrome/browser/media/webrtc/desktop_media_list_base.cc b/chrome/browser/media/webrtc/desktop_media_list_base.cc
|
2021-10-21 18:51:36 +00:00
|
|
|
index 24bd95b79479c21182a0d1a61364e1794f900261..2b2a7494ee9bd88fd5c8ebf50a5e29738b2dffd0 100644
|
2018-10-03 12:26:42 +00:00
|
|
|
--- a/chrome/browser/media/webrtc/desktop_media_list_base.cc
|
|
|
|
+++ b/chrome/browser/media/webrtc/desktop_media_list_base.cc
|
2021-10-21 18:51:36 +00:00
|
|
|
@@ -63,12 +63,12 @@ void DesktopMediaListBase::StartUpdating(DesktopMediaListObserver* observer) {
|
2021-09-03 23:37:36 +00:00
|
|
|
Refresh(true);
|
|
|
|
}
|
2019-10-28 22:12:35 +00:00
|
|
|
|
2021-09-03 23:37:36 +00:00
|
|
|
-void DesktopMediaListBase::Update(UpdateCallback callback) {
|
|
|
|
+void DesktopMediaListBase::Update(UpdateCallback callback, bool refresh_thumbnails) {
|
2021-10-21 18:51:36 +00:00
|
|
|
DCHECK_CURRENTLY_ON(BrowserThread::UI);
|
2019-10-18 19:57:34 +00:00
|
|
|
DCHECK(sources_.empty());
|
|
|
|
DCHECK(!refresh_callback_);
|
|
|
|
refresh_callback_ = std::move(callback);
|
|
|
|
- Refresh(false);
|
2021-09-03 23:37:36 +00:00
|
|
|
+ Refresh(refresh_thumbnails);
|
2018-10-03 12:26:42 +00:00
|
|
|
}
|
|
|
|
|
2019-10-18 19:57:34 +00:00
|
|
|
int DesktopMediaListBase::GetSourceCount() const {
|
2018-10-03 12:26:42 +00:00
|
|
|
diff --git a/chrome/browser/media/webrtc/desktop_media_list_base.h b/chrome/browser/media/webrtc/desktop_media_list_base.h
|
2022-01-10 22:31:39 +00:00
|
|
|
index c56bc6dcc73cf0e0d5e0e64d45436ccac833cd66..69aaecca38ede55ee71310698710e3f17b04abff 100644
|
2018-10-03 12:26:42 +00:00
|
|
|
--- a/chrome/browser/media/webrtc/desktop_media_list_base.h
|
|
|
|
+++ b/chrome/browser/media/webrtc/desktop_media_list_base.h
|
2022-01-10 22:31:39 +00:00
|
|
|
@@ -36,7 +36,7 @@ class DesktopMediaListBase : public DesktopMediaList {
|
2019-10-28 22:12:35 +00:00
|
|
|
void SetThumbnailSize(const gfx::Size& thumbnail_size) override;
|
|
|
|
void SetViewDialogWindowId(content::DesktopMediaID dialog_id) override;
|
2021-09-03 23:37:36 +00:00
|
|
|
void StartUpdating(DesktopMediaListObserver* observer) override;
|
|
|
|
- void Update(UpdateCallback callback) override;
|
|
|
|
+ void Update(UpdateCallback callback, bool refresh_thumbnails) override;
|
2018-10-03 12:26:42 +00:00
|
|
|
int GetSourceCount() const override;
|
|
|
|
const Source& GetSource(int index) const override;
|
2021-03-04 23:46:13 +00:00
|
|
|
DesktopMediaList::Type GetMediaListType() const override;
|
2022-01-12 07:39:49 +00:00
|
|
|
diff --git a/chrome/browser/media/webrtc/fake_desktop_media_list.cc b/chrome/browser/media/webrtc/fake_desktop_media_list.cc
|
|
|
|
index b1db454db6b7982962541cef18c09425b8f5fa5a..1e37f85d7f786807af331ccc347d84d9b4d7177c 100644
|
|
|
|
--- a/chrome/browser/media/webrtc/fake_desktop_media_list.cc
|
|
|
|
+++ b/chrome/browser/media/webrtc/fake_desktop_media_list.cc
|
|
|
|
@@ -75,7 +75,8 @@ void FakeDesktopMediaList::StartUpdating(DesktopMediaListObserver* observer) {
|
|
|
|
thumbnail_ = gfx::ImageSkia::CreateFrom1xBitmap(bitmap);
|
|
|
|
}
|
|
|
|
|
|
|
|
-void FakeDesktopMediaList::Update(UpdateCallback callback) {
|
|
|
|
+void FakeDesktopMediaList::Update(UpdateCallback callback,
|
|
|
|
+ bool refresh_thumbnails) {
|
|
|
|
std::move(callback).Run();
|
|
|
|
}
|
|
|
|
|
|
|
|
diff --git a/chrome/browser/media/webrtc/fake_desktop_media_list.h b/chrome/browser/media/webrtc/fake_desktop_media_list.h
|
|
|
|
index 1e4a652634fbde2ca9a256baca840bbc5a0e001f..546f5bc3a2f79035f0eec196d9e704b849992a6f 100644
|
|
|
|
--- a/chrome/browser/media/webrtc/fake_desktop_media_list.h
|
|
|
|
+++ b/chrome/browser/media/webrtc/fake_desktop_media_list.h
|
|
|
|
@@ -32,7 +32,8 @@ class FakeDesktopMediaList : public DesktopMediaList {
|
|
|
|
void SetThumbnailSize(const gfx::Size& thumbnail_size) override;
|
|
|
|
void SetViewDialogWindowId(content::DesktopMediaID dialog_id) override;
|
|
|
|
void StartUpdating(DesktopMediaListObserver* observer) override;
|
|
|
|
- void Update(UpdateCallback callback) override;
|
|
|
|
+ void Update(UpdateCallback callback,
|
|
|
|
+ bool refresh_thumbnails = false) override;
|
|
|
|
int GetSourceCount() const override;
|
|
|
|
const Source& GetSource(int index) const override;
|
|
|
|
DesktopMediaList::Type GetMediaListType() const override;
|
2018-10-03 12:26:42 +00:00
|
|
|
diff --git a/chrome/browser/media/webrtc/native_desktop_media_list.cc b/chrome/browser/media/webrtc/native_desktop_media_list.cc
|
2022-02-10 02:58:52 +00:00
|
|
|
index 91da584747d5afc3f07e51ae77b002d91c4ff7ac..bbf37f733a6e1831017f171edf162ab8aac3f0a4 100644
|
2018-10-03 12:26:42 +00:00
|
|
|
--- a/chrome/browser/media/webrtc/native_desktop_media_list.cc
|
|
|
|
+++ b/chrome/browser/media/webrtc/native_desktop_media_list.cc
|
2022-01-10 22:31:39 +00:00
|
|
|
@@ -17,7 +17,7 @@
|
2018-10-24 23:25:48 +00:00
|
|
|
#include "build/build_config.h"
|
2022-01-10 22:31:39 +00:00
|
|
|
#include "build/chromeos_buildflags.h"
|
2019-10-18 19:57:34 +00:00
|
|
|
#include "chrome/browser/media/webrtc/desktop_media_list.h"
|
2018-10-03 20:50:07 +00:00
|
|
|
-#include "chrome/grit/generated_resources.h"
|
2021-09-03 23:37:36 +00:00
|
|
|
+#include "electron/grit/electron_resources.h"
|
2019-01-12 01:00:43 +00:00
|
|
|
#include "content/public/browser/browser_task_traits.h"
|
2018-10-03 12:26:42 +00:00
|
|
|
#include "content/public/browser/browser_thread.h"
|
2021-03-15 18:32:18 +00:00
|
|
|
#include "content/public/common/content_features.h"
|
2022-01-10 22:31:39 +00:00
|
|
|
@@ -95,8 +95,9 @@ gfx::ImageSkia ScaleDesktopFrame(std::unique_ptr<webrtc::DesktopFrame> frame,
|
2021-08-24 00:52:17 +00:00
|
|
|
}
|
|
|
|
|
2022-02-10 02:58:52 +00:00
|
|
|
#if BUILDFLAG(IS_MAC)
|
2021-08-24 00:52:17 +00:00
|
|
|
+// Refs https://github.com/electron/electron/pull/30507
|
|
|
|
const base::Feature kWindowCaptureMacV2{"WindowCaptureMacV2",
|
2021-11-24 08:45:59 +00:00
|
|
|
- base::FEATURE_ENABLED_BY_DEFAULT};
|
|
|
|
+ base::FEATURE_DISABLED_BY_DEFAULT};
|
2021-08-24 00:52:17 +00:00
|
|
|
#endif
|
2021-11-24 08:45:59 +00:00
|
|
|
|
|
|
|
} // namespace
|
2022-01-13 15:21:28 +00:00
|
|
|
@@ -274,6 +275,9 @@ void NativeDesktopMediaList::Worker::RefreshNextThumbnail() {
|
|
|
|
FROM_HERE,
|
|
|
|
base::BindOnce(&NativeDesktopMediaList::UpdateNativeThumbnailsFinished,
|
|
|
|
media_list_));
|
|
|
|
+
|
|
|
|
+ // This call is necessary to release underlying OS screen capture mechanisms.
|
|
|
|
+ capturer_.reset();
|
|
|
|
}
|
|
|
|
|
|
|
|
void NativeDesktopMediaList::Worker::OnCaptureResult(
|
|
|
|
@@ -435,6 +439,11 @@ void NativeDesktopMediaList::RefreshForVizFrameSinkWindows(
|
2021-09-03 23:37:36 +00:00
|
|
|
FROM_HERE, base::BindOnce(&Worker::RefreshThumbnails,
|
|
|
|
base::Unretained(worker_.get()),
|
|
|
|
std::move(native_ids), thumbnail_size_));
|
|
|
|
+ } else {
|
2021-11-30 23:12:39 +00:00
|
|
|
+#if defined(USE_AURA)
|
|
|
|
+ pending_native_thumbnail_capture_ = true;
|
|
|
|
+#endif
|
|
|
|
+ UpdateNativeThumbnailsFinished();
|
2021-09-03 23:37:36 +00:00
|
|
|
}
|
2019-09-18 20:20:41 +00:00
|
|
|
}
|
|
|
|
|