mirror of
https://github.com/electron/electron.git
synced 2026-04-10 03:01:51 -04:00
* chore: bump chromium in DEPS to 144.0.7543.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * Pass PipScreenCaptureCoordinatorProxy to ScreenCaptureKitDeviceMac https://chromium-review.googlesource.com/c/chromium/src/+/7157590 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * chore: update patches Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * chore: update filenames.libcxx.gni Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * 7142359: Spanification of process_singleton_posix.cc https: //chromium-review.googlesource.com/c/chromium/src/+/7142359 Co-Authored-By: Charles Kerr <70381+ckerr@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * Move logging::LoggingSettings to base/logging/logging_settings.h https://chromium-review.googlesource.com/c/chromium/src/+/7173024 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * chore: bump chromium in DEPS to 144.0.7545.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * 7159368: update PluginService API for sync GetPlugins Upstream removed async PluginService APIs: - GetPluginsAsync() removed, use synchronous GetPlugins() - RegisterInternalPlugin() now takes single argument (remove add_at_beginning) - RefreshPlugins() removed entirely Updated ElectronPluginInfoHostImpl to use synchronous plugin loading and simplified ElectronBrowserMainParts internal plugin registration. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7159368 Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7159328 Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7159056 (cherry picked from commit88cdf50b0a) Co-authored-by: Samuel Attard <sattard@anthropic.com> * 7159184: add missing base/files/file_path.h include Add explicit include for base/files/file_path.h in electron_browser_context.h. After removal of superfluous Mojo includes from content headers, base::FilePath is no longer transitively included via content/public/browser/browser_context.h. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7159184 (cherry picked from commit6ca8ea03ec) Co-authored-by: Samuel Attard <sattard@anthropic.com> * 7126479: add ShouldForceRefreshTextCheckService parameter to SpellCheckClient Upstream added a force-refresh parameter to WebTextCheckClient::RequestCheckingOfText to bypass spell check cache. Add the new ShouldForceRefreshTextCheckService parameter to SpellCheckClient's override (currently unused in Electron). Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7126479 (cherry picked from commit879c0401c4) Co-authored-by: Samuel Attard <sattard@anthropic.com> * 7083663: remove fingerprinting_protection_ruleset_service override Upstream deleted external references to Fingerprinting Protection Filter (FPF) component. Remove the fingerprinting_protection_ruleset_service() override from BrowserProcessImpl as the method no longer exists in the base class. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7083663 (cherry picked from commit8350d152f9) Co-authored-by: Samuel Attard <sattard@anthropic.com> * 7155287: implement WebContentsView::GetSize and Resize Upstream delegated WebContents::GetSize() and Resize() to WebContentsView, making them pure virtual. Add const qualifier to GetSize() and implement the Resize() override in OffScreenWebContentsView (no-op for offscreen). Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7155287 (cherry picked from commit084eaa568e) Co-authored-by: Samuel Attard <sattard@anthropic.com> * 7184238: add OnUnconfirmedTapConvertedToTap override Upstream added OnUnconfirmedTapConvertedToTap as a pure virtual method to RenderWidgetHostViewBase to inform root view when child frame converts an unconfirmed tap. Add empty override for offscreen rendering. Ref: https://chromium-review.googlesource.com/c/chromium/src/+/7184238 (cherry picked from commitef03400d9a) Co-authored-by: Samuel Attard <sattard@anthropic.com> * 7143586: add widget parameter to OnCommandsChanged GlobalAcceleratorListener::OnCommandsChanged gained a gfx::AcceleratedWidget parameter for window association in the GlobalShortcutListenerLinux implementation. Pass gfx::kNullAcceleratedWidget for Electron's usage. Ref: : Pass parent handle to GlobalAcceleratorListenerLinux::BindShortcuts | https://chromium-review.googlesource.com/c/chromium/src/+/7143586 (cherry picked from commit38306e2bfc) Co-Authored-By: Samuel Attard <MarshallOfSound@users.noreply.github.com> Co-authored-by: Samuel Attard <sattard@anthropic.com> * chore: update patches Co-Authored-By: Samuel Attard <MarshallOfSound@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * chore: bump chromium in DEPS to 144.0.7547.0 Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> * chore: update patches Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * 7189232: Add support for UnownedUserData in GlobalFeatures https: //chromium-review.googlesource.com/c/chromium/src/+/7189232 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * Refactor: Use std::u16string for extension load error messages https://chromium-review.googlesource.com/c/chromium/src/+/7185844 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * fixup Add support for UnownedUserData in GlobalFeatures Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * 7165650: Remove ResourceContext https://chromium-review.googlesource.com/c/chromium/src/+/7165650 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * fixup BUILD.gn for lint Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * 7202164: Reland "Reland "Remove GenericScopedHandle:IsValid"" https://chromium-review.googlesource.com/c/chromium/src/+/7202164 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * advance deprecation of v8::ReturnValue<void>::Set(Local<S>). 7168624: [runtime][api] Relax requirements for setter/definer/deleter callbacks | https://chromium-review.googlesource.com/c/v8/v8/+/7168624 Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * fixup advance deprecation of v8::ReturnValue<void>::Set(Local<S>) Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * chore: skip setting LPAC ACLs Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> * Revert "chore: skip setting LPAC ACLs" This reverts commite187aec488. Co-authored-by: John Kleinschmidt <kleinschmidtorama@gmail.com> * chore: revert Convert to UNSAFE_TODO in sandbox revert https://chromium-review.googlesource.com/c/chromium/src/+/7131661 to see if it fixes the Windows sandbox issue. Co-authored-by: John Kleinschmidt <kleinschmidtorama@gmail.com> * Revert "chore: revert Convert to UNSAFE_TODO in sandbox" This reverts commit57afbfefe5. Co-authored-by: John Kleinschmidt <kleinschmidtorama@gmail.com> * chore: Revert "Enable network sandbox by default on Windows" see if this fixes the Windows sandbox issue Co-authored-by: John Kleinschmidt <kleinschmidtorama@gmail.com> * Enable network sandbox by default on Windows https://chromium-review.googlesource.com/c/chromium/src/+/7204292 Co-authored-by: John Kleinschmidt <kleinschmidtorama@gmail.com> * Revert "chore: Revert "Enable network sandbox by default on Windows"" This reverts commit530ab6af82. Co-authored-by: John Kleinschmidt <kleinschmidtorama@gmail.com> * fixup! Enable network sandbox by default on Windows | https://chromium-review.googlesource.com/c/chromium/src/+/7204292 Co-authored-by: Keeley Hammond <khammond@slack-corp.com> * fixup!: Correct flag name, add kLocalNetworkAccessChecks to all platforms Co-authored-by: Keeley Hammond <khammond@slack-corp.com> * chore: remove patch that hasn't been backported See https://github.com/electron/electron/pull/48675 --------- Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: John Kleinschmidt <jkleinsc@electronjs.org> Co-authored-by: Samuel Attard <sattard@anthropic.com> Co-authored-by: John Kleinschmidt <kleinschmidtorama@gmail.com> Co-authored-by: Keeley Hammond <khammond@slack-corp.com> Co-authored-by: Niklas Wenzel <dev@nikwen.de>
351 lines
12 KiB
C++
351 lines
12 KiB
C++
// Copyright (c) 2016 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_OSR_OSR_RENDER_WIDGET_HOST_VIEW_H_
|
|
#define ELECTRON_SHELL_BROWSER_OSR_OSR_RENDER_WIDGET_HOST_VIEW_H_
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "build/build_config.h"
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
#include <windows.h>
|
|
#endif
|
|
|
|
#include "base/functional/callback_forward.h"
|
|
#include "base/memory/raw_ptr.h"
|
|
#include "components/viz/common/quads/compositor_frame.h"
|
|
#include "components/viz/common/surfaces/parent_local_surface_id_allocator.h"
|
|
#include "content/browser/renderer_host/delegated_frame_host.h" // nogncheck
|
|
#include "content/browser/renderer_host/input/mouse_wheel_phase_handler.h" // nogncheck
|
|
#include "content/browser/renderer_host/render_widget_host_impl.h" // nogncheck
|
|
#include "content/browser/renderer_host/render_widget_host_view_base.h" // nogncheck
|
|
#include "content/browser/web_contents/web_contents_view.h" // nogncheck
|
|
#include "shell/browser/osr/osr_host_display_client.h"
|
|
#include "shell/browser/osr/osr_video_consumer.h"
|
|
#include "shell/browser/osr/osr_view_proxy.h"
|
|
#include "third_party/abseil-cpp/absl/container/flat_hash_set.h"
|
|
#include "third_party/blink/public/mojom/widget/record_content_to_visible_time_request.mojom-forward.h"
|
|
#include "third_party/skia/include/core/SkBitmap.h"
|
|
#include "ui/base/ime/text_input_client.h"
|
|
#include "ui/compositor/compositor.h"
|
|
#include "ui/compositor/layer_delegate.h"
|
|
#include "ui/compositor/layer_owner.h"
|
|
#include "ui/gfx/geometry/point.h"
|
|
|
|
#include "components/viz/host/host_display_client.h"
|
|
|
|
#if BUILDFLAG(IS_WIN)
|
|
#include "ui/gfx/win/window_impl.h"
|
|
#endif
|
|
|
|
class SkBitmap;
|
|
|
|
namespace gfx {
|
|
class Point;
|
|
class PointF;
|
|
class Rect;
|
|
} // namespace gfx
|
|
|
|
namespace input {
|
|
class CursorManager;
|
|
}
|
|
|
|
namespace electron {
|
|
|
|
class ElectronBeginFrameTimer;
|
|
class ElectronCopyFrameGenerator;
|
|
class ElectronDelegatedFrameHostClient;
|
|
class OffScreenHostDisplayClient;
|
|
|
|
using OnPopupPaintCallback = base::RepeatingCallback<void(const gfx::Rect&)>;
|
|
|
|
class OffScreenRenderWidgetHostView
|
|
: public content::RenderWidgetHostViewBase,
|
|
private content::RenderFrameMetadataProvider::Observer,
|
|
public ui::CompositorDelegate,
|
|
private OffscreenViewProxyObserver {
|
|
public:
|
|
OffScreenRenderWidgetHostView(
|
|
bool transparent,
|
|
bool offscreen_use_shared_texture,
|
|
const std::string& offscreen_shared_texture_pixel_format,
|
|
bool painting,
|
|
int frame_rate,
|
|
const OnPaintCallback& callback,
|
|
content::RenderWidgetHost* render_widget_host,
|
|
OffScreenRenderWidgetHostView* parent_host_view,
|
|
gfx::Size initial_size);
|
|
~OffScreenRenderWidgetHostView() override;
|
|
|
|
// disable copy
|
|
OffScreenRenderWidgetHostView(const OffScreenRenderWidgetHostView&) = delete;
|
|
OffScreenRenderWidgetHostView& operator=(
|
|
const OffScreenRenderWidgetHostView&) = delete;
|
|
|
|
// content::RenderWidgetHostView:
|
|
void InitAsChild(gfx::NativeView) override;
|
|
void SetSize(const gfx::Size&) override;
|
|
void SetBounds(const gfx::Rect&) override;
|
|
gfx::NativeView GetNativeView() override;
|
|
gfx::NativeViewAccessible GetNativeViewAccessible() override;
|
|
ui::TextInputClient* GetTextInputClient() override;
|
|
void Focus() override {}
|
|
bool HasFocus() override;
|
|
uint32_t GetCaptureSequenceNumber() const override;
|
|
bool IsSurfaceAvailableForCopy() override;
|
|
void Hide() override;
|
|
bool IsShowing() override;
|
|
void EnsureSurfaceSynchronizedForWebTest() override;
|
|
gfx::Rect GetViewBounds() override;
|
|
gfx::Size GetVisibleViewportSize() override;
|
|
void SetInsets(const gfx::Insets&) override {}
|
|
void SetBackgroundColor(SkColor color) override;
|
|
std::optional<SkColor> GetBackgroundColor() override;
|
|
void UpdateBackgroundColor() override {}
|
|
blink::mojom::PointerLockResult LockPointer(
|
|
bool request_unadjusted_movement) override;
|
|
blink::mojom::PointerLockResult ChangePointerLock(
|
|
bool request_unadjusted_movement) override;
|
|
void UnlockPointer() override {}
|
|
void TakeFallbackContentFrom(content::RenderWidgetHostView* view) override;
|
|
#if BUILDFLAG(IS_MAC)
|
|
void SetActive(bool active) override {}
|
|
void ShowDefinitionForSelection() override {}
|
|
void SpeakSelection() override {}
|
|
void SetWindowFrameInScreen(const gfx::Rect& rect) override {}
|
|
void ShowSharePicker(
|
|
const std::string& title,
|
|
const std::string& text,
|
|
const GURL& url,
|
|
const std::vector<std::string>& file_paths,
|
|
blink::mojom::ShareService::ShareCallback callback) override {}
|
|
uint64_t GetNSViewId() const override;
|
|
bool UpdateNSViewAndDisplay();
|
|
#endif // BUILDFLAG(IS_MAC)
|
|
|
|
// content::RenderWidgetHostViewBase:
|
|
void UpdateFrameSinkIdRegistration() override;
|
|
void InvalidateLocalSurfaceIdAndAllocationGroup() override;
|
|
void ResetFallbackToFirstNavigationSurface() override;
|
|
void InitAsPopup(content::RenderWidgetHostView* parent_host_view,
|
|
const gfx::Rect& bounds,
|
|
const gfx::Rect& anchor_rect) override;
|
|
void UpdateCursor(const ui::Cursor&) override {}
|
|
void SetIsLoading(bool is_loading) override {}
|
|
void TextInputStateChanged(const ui::mojom::TextInputState& params) override {
|
|
}
|
|
void ImeCancelComposition() override {}
|
|
void RenderProcessGone() override;
|
|
void ShowWithVisibility(content::PageVisibilityState page_visibility) final;
|
|
void Destroy() override;
|
|
void UpdateTooltipUnderCursor(const std::u16string&) override {}
|
|
void OnUnconfirmedTapConvertedToTap() override {}
|
|
input::CursorManager* GetCursorManager() override;
|
|
void CopyFromSurface(
|
|
const gfx::Rect& src_rect,
|
|
const gfx::Size& output_size,
|
|
base::OnceCallback<void(const viz::CopyOutputBitmapWithMetadata&)>
|
|
callback) override;
|
|
display::ScreenInfo GetScreenInfo() const override;
|
|
void TransformPointToRootSurface(gfx::PointF* point) override {}
|
|
gfx::Rect GetBoundsInRootWindow() override;
|
|
std::optional<content::DisplayFeature> GetDisplayFeature() override;
|
|
void DisableDisplayFeatureOverrideForEmulation() override {}
|
|
void OverrideDisplayFeatureForEmulation(
|
|
const content::DisplayFeature* display_feature) override {}
|
|
void NotifyHostAndDelegateOnWasShown(
|
|
blink::mojom::RecordContentToVisibleTimeRequestPtr) final;
|
|
void RequestSuccessfulPresentationTimeFromHostOrDelegate(
|
|
blink::mojom::RecordContentToVisibleTimeRequestPtr) final;
|
|
void CancelSuccessfulPresentationTimeRequestForHostAndDelegate() final;
|
|
viz::SurfaceId GetCurrentSurfaceId() const override;
|
|
std::unique_ptr<content::SyntheticGestureTarget>
|
|
CreateSyntheticGestureTarget() override;
|
|
void ImeCompositionRangeChanged(
|
|
const gfx::Range&,
|
|
const std::optional<std::vector<gfx::Rect>>& character_bounds) override {}
|
|
gfx::Size GetCompositorViewportPixelSize() override;
|
|
ui::Compositor* GetCompositor() override;
|
|
|
|
content::RenderWidgetHostViewBase* CreateViewForWidget(
|
|
content::RenderWidgetHost*,
|
|
content::RenderWidgetHost*,
|
|
content::WebContentsView*);
|
|
|
|
const viz::LocalSurfaceId& GetLocalSurfaceId() const override;
|
|
const viz::FrameSinkId& GetFrameSinkId() const override;
|
|
|
|
void DidNavigate() override;
|
|
|
|
bool TransformPointToCoordSpaceForView(
|
|
const gfx::PointF& point,
|
|
RenderWidgetHostViewInput* target_view,
|
|
gfx::PointF* transformed_point) override;
|
|
|
|
// RenderFrameMetadataProvider::Observer:
|
|
void OnRenderFrameMetadataChangedBeforeActivation(
|
|
const cc::RenderFrameMetadata& metadata) override {}
|
|
void OnRenderFrameMetadataChangedAfterActivation(
|
|
base::TimeTicks activation_time) override {}
|
|
void OnRenderFrameSubmission() override {}
|
|
void OnLocalSurfaceIdChanged(
|
|
const cc::RenderFrameMetadata& metadata) override;
|
|
|
|
// ui::CompositorDelegate:
|
|
bool IsOffscreen() const override;
|
|
std::unique_ptr<viz::HostDisplayClient> CreateHostDisplayClient(
|
|
ui::Compositor* compositor) override;
|
|
|
|
bool InstallTransparency();
|
|
|
|
void CancelWidget();
|
|
void AddGuestHostView(OffScreenRenderWidgetHostView* guest_host);
|
|
void RemoveGuestHostView(OffScreenRenderWidgetHostView* guest_host);
|
|
void AddViewProxy(OffscreenViewProxy* proxy);
|
|
void RemoveViewProxy(OffscreenViewProxy* proxy);
|
|
void ProxyViewDestroyed(OffscreenViewProxy* proxy) override;
|
|
|
|
void OnPaint(const gfx::Rect& damage_rect,
|
|
const SkBitmap& bitmap,
|
|
const OffscreenSharedTexture& texture);
|
|
void OnPopupPaint(const gfx::Rect& damage_rect);
|
|
void OnProxyViewPaint(const gfx::Rect& damage_rect) override;
|
|
|
|
gfx::Size SizeInPixels();
|
|
|
|
void CompositeFrame(const gfx::Rect& damage_rect);
|
|
|
|
bool IsPopupWidget() const {
|
|
return widget_type_ == content::WidgetType::kPopup;
|
|
}
|
|
|
|
const SkBitmap& GetBacking() { return *backing_.get(); }
|
|
|
|
void HoldResize();
|
|
void ReleaseResize();
|
|
void SynchronizeVisualProperties();
|
|
|
|
void SendMouseEvent(const blink::WebMouseEvent& event);
|
|
void SendMouseWheelEvent(const blink::WebMouseWheelEvent& event);
|
|
|
|
void SetPainting(bool painting);
|
|
bool is_painting() const { return painting_; }
|
|
|
|
void SetFrameRate(int frame_rate);
|
|
int frame_rate() const { return frame_rate_; }
|
|
|
|
bool offscreen_use_shared_texture() const {
|
|
return offscreen_use_shared_texture_;
|
|
}
|
|
|
|
const std::string offscreen_shared_texture_pixel_format() const {
|
|
return offscreen_shared_texture_pixel_format_;
|
|
}
|
|
|
|
ui::Layer* root_layer() const { return root_layer_.get(); }
|
|
|
|
content::DelegatedFrameHost* delegated_frame_host() const {
|
|
return delegated_frame_host_.get();
|
|
}
|
|
|
|
void Invalidate();
|
|
void InvalidateBounds(const gfx::Rect&);
|
|
|
|
content::RenderWidgetHostImpl* render_widget_host() const {
|
|
return render_widget_host_;
|
|
}
|
|
|
|
gfx::Size size() const { return size_; }
|
|
|
|
void set_popup_host_view(OffScreenRenderWidgetHostView* popup_view) {
|
|
popup_host_view_ = popup_view;
|
|
}
|
|
|
|
void set_child_host_view(OffScreenRenderWidgetHostView* child_view) {
|
|
child_host_view_ = child_view;
|
|
}
|
|
|
|
private:
|
|
void ReleaseCompositor();
|
|
void SetupFrameRate(bool force);
|
|
void ResizeRootLayer(bool force);
|
|
|
|
viz::FrameSinkId AllocateFrameSinkId();
|
|
|
|
// Applies background color without notifying the RenderWidget about
|
|
// opaqueness changes.
|
|
void UpdateBackgroundColorFromRenderer(SkColor color);
|
|
|
|
// Weak ptrs.
|
|
raw_ptr<content::RenderWidgetHostImpl> render_widget_host_;
|
|
|
|
raw_ptr<OffScreenRenderWidgetHostView> parent_host_view_ = nullptr;
|
|
raw_ptr<OffScreenRenderWidgetHostView> popup_host_view_ = nullptr;
|
|
raw_ptr<OffScreenRenderWidgetHostView> child_host_view_ = nullptr;
|
|
absl::flat_hash_set<OffScreenRenderWidgetHostView*> guest_host_views_;
|
|
absl::flat_hash_set<OffscreenViewProxy*> proxy_views_;
|
|
|
|
const bool transparent_;
|
|
const bool offscreen_use_shared_texture_;
|
|
const std::string offscreen_shared_texture_pixel_format_;
|
|
OnPaintCallback callback_;
|
|
OnPopupPaintCallback parent_callback_;
|
|
|
|
int frame_rate_ = 0;
|
|
int frame_rate_threshold_us_ = 0;
|
|
|
|
gfx::Size size_;
|
|
bool painting_;
|
|
|
|
bool is_showing_ = false;
|
|
bool is_destroyed_ = false;
|
|
gfx::Rect popup_position_;
|
|
|
|
bool hold_resize_ = false;
|
|
bool pending_resize_ = false;
|
|
|
|
viz::LocalSurfaceId delegated_frame_host_surface_id_;
|
|
viz::ParentLocalSurfaceIdAllocator delegated_frame_host_allocator_;
|
|
|
|
viz::LocalSurfaceId compositor_surface_id_;
|
|
viz::ParentLocalSurfaceIdAllocator compositor_allocator_;
|
|
|
|
std::unique_ptr<ui::Layer> root_layer_;
|
|
|
|
// depends-on: root_layer_
|
|
std::unique_ptr<ui::Compositor> compositor_;
|
|
|
|
// depends-on: render_widget_host_, root_layer_
|
|
const std::unique_ptr<ElectronDelegatedFrameHostClient>
|
|
delegated_frame_host_client_;
|
|
|
|
// depends-on: delegated_frame_host_client_
|
|
std::unique_ptr<content::DelegatedFrameHost> delegated_frame_host_;
|
|
|
|
std::unique_ptr<input::CursorManager> cursor_manager_;
|
|
|
|
raw_ptr<OffScreenHostDisplayClient> host_display_client_;
|
|
std::unique_ptr<OffScreenVideoConsumer> video_consumer_;
|
|
|
|
content::MouseWheelPhaseHandler mouse_wheel_phase_handler_;
|
|
|
|
// Latest capture sequence number which is incremented when the caller
|
|
// requests surfaces be synchronized via
|
|
// EnsureSurfaceSynchronizedForWebTest().
|
|
uint32_t latest_capture_sequence_number_ = 0u;
|
|
|
|
SkColor background_color_ = SkColor();
|
|
|
|
std::unique_ptr<SkBitmap> backing_;
|
|
|
|
base::WeakPtrFactory<OffScreenRenderWidgetHostView> weak_ptr_factory_{this};
|
|
};
|
|
|
|
} // namespace electron
|
|
|
|
#endif // ELECTRON_SHELL_BROWSER_OSR_OSR_RENDER_WIDGET_HOST_VIEW_H_
|