bc1ba1fe9d
* chore: bump chromium in DEPS to 120.0.6086.0 * chore: update patches * chore: rename FrameSubscriber::OnNewCropVersion() Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4905819 just a simple renaming * chore: rename ToJsTime() to .InMillisecondsFSinceUnixEpoch() Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4956111 function renamed upstream * chore: rename ToDoubleT() to .InSecondsFSinceUnixEpoch() Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4956111 function renamed upstream * chore: rename FromDoubleT() to .FromSecondsSinceUnixEpoch() Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4956111 function renamed upstream * chore: bump chromium in DEPS to 120.0.6088.2 * chore: update patches * chore: regen filenames.libcxx.gni * chore: migrate from (removed upstream) inputFormType to formControlType * chore: bump chromium in DEPS to 120.0.6089.0 * chore: update allow_disabling_blink_scheduler_throttling_per_renderview.patch Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4828507 manually sync to upstream changes + reduce diff size * chore: update patches * chore: bump chromium in DEPS to 120.0.6090.0 * chore: update fix_disabling_background_throttling_in_compositor.patch no manual changes; patch applied with fuzz 2 (4 lines) Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4944206 * chore: update fix_handle_no_top_level_aura_window_in_webcontentsimpl.patch Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4946653 do not patch WebContentsImpl::SetWindowShowState() any longer because it has been removed * chore: update patches * chore: bump chromium in DEPS to 120.0.6091.0 * chore: update patches * chore: bump chromium in DEPS to 120.0.6093.0 * chore: bump chromium in DEPS to 120.0.6095.0 * chore: bump chromium in DEPS to 120.0.6096.0 * chore: bump chromium in DEPS to 120.0.6097.0 * chore: update patches * chore: update patch after rebase * 4961495: [document pip] Focus the window when opened manually https://chromium-review.googlesource.com/c/chromium/src/+/4961495 * [Extensions UserScripts] Store extensions with user scripts in tracker | https://chromium-review.googlesource.com/c/chromium/src/+/4950530 * chore: bump chromium in DEPS to 120.0.6099.0 * chore: update patches * chore: update filenames.libcxx.gni * chore: remove trailing space --------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Charles Kerr <charles@charleskerr.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org>
81 lines
2.6 KiB
C++
81 lines
2.6 KiB
C++
// Copyright (c) 2015 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#ifndef ELECTRON_SHELL_BROWSER_API_FRAME_SUBSCRIBER_H_
|
|
#define ELECTRON_SHELL_BROWSER_API_FRAME_SUBSCRIBER_H_
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
#include "base/functional/callback.h"
|
|
#include "base/memory/raw_ptr.h"
|
|
#include "base/memory/weak_ptr.h"
|
|
#include "components/viz/host/client_frame_sink_video_capturer.h"
|
|
#include "content/public/browser/web_contents.h"
|
|
#include "content/public/browser/web_contents_observer.h"
|
|
#include "media/capture/mojom/video_capture_buffer.mojom-forward.h"
|
|
#include "mojo/public/cpp/bindings/pending_remote.h"
|
|
#include "v8/include/v8.h"
|
|
|
|
namespace gfx {
|
|
class Image;
|
|
class Rect;
|
|
} // namespace gfx
|
|
|
|
namespace electron::api {
|
|
|
|
class WebContents;
|
|
|
|
class FrameSubscriber : public content::WebContentsObserver,
|
|
public viz::mojom::FrameSinkVideoConsumer {
|
|
public:
|
|
using FrameCaptureCallback =
|
|
base::RepeatingCallback<void(const gfx::Image&, const gfx::Rect&)>;
|
|
|
|
FrameSubscriber(content::WebContents* web_contents,
|
|
const FrameCaptureCallback& callback,
|
|
bool only_dirty);
|
|
~FrameSubscriber() override;
|
|
|
|
// disable copy
|
|
FrameSubscriber(const FrameSubscriber&) = delete;
|
|
FrameSubscriber& operator=(const FrameSubscriber&) = delete;
|
|
|
|
private:
|
|
void AttachToHost(content::RenderWidgetHost* host);
|
|
void DetachFromHost();
|
|
|
|
void RenderFrameCreated(content::RenderFrameHost* render_frame_host) override;
|
|
void PrimaryPageChanged(content::Page& page) override;
|
|
void RenderViewDeleted(content::RenderViewHost* host) override;
|
|
|
|
// viz::mojom::FrameSinkVideoConsumer implementation.
|
|
void OnFrameCaptured(
|
|
::media::mojom::VideoBufferHandlePtr data,
|
|
::media::mojom::VideoFrameInfoPtr info,
|
|
const gfx::Rect& content_rect,
|
|
mojo::PendingRemote<viz::mojom::FrameSinkVideoConsumerFrameCallbacks>
|
|
callbacks) override;
|
|
void OnNewSubCaptureTargetVersion(uint32_t crop_version) override;
|
|
void OnFrameWithEmptyRegionCapture() override;
|
|
void OnStopped() override;
|
|
void OnLog(const std::string& message) override;
|
|
|
|
void Done(const gfx::Rect& damage, const SkBitmap& frame);
|
|
|
|
// Get the pixel size of render view.
|
|
gfx::Size GetRenderViewSize() const;
|
|
|
|
FrameCaptureCallback callback_;
|
|
bool only_dirty_;
|
|
|
|
raw_ptr<content::RenderWidgetHost> host_;
|
|
std::unique_ptr<viz::ClientFrameSinkVideoCapturer> video_capturer_;
|
|
|
|
base::WeakPtrFactory<FrameSubscriber> weak_ptr_factory_{this};
|
|
};
|
|
|
|
} // namespace electron::api
|
|
|
|
#endif // ELECTRON_SHELL_BROWSER_API_FRAME_SUBSCRIBER_H_
|