#pragma once
#include "CallbackID.h"
#include "DrawingAreaInfo.h"
#include "LayerTreeContext.h"
#include "MessageReceiver.h"
#include <WebCore/ActivityState.h>
#include <WebCore/FloatRect.h>
#include <WebCore/IntRect.h>
#include <WebCore/LayerFlushThrottleState.h>
#include <WebCore/LayoutMilestones.h>
#include <WebCore/PlatformScreen.h>
#include <wtf/Forward.h>
#include <wtf/Noncopyable.h>
#include <wtf/TypeCasts.h>
#include <wtf/Vector.h>
namespace IPC {
class Connection;
class Decoder;
}
namespace WebCore {
class DisplayRefreshMonitor;
class Frame;
class FrameView;
class GraphicsLayer;
class GraphicsLayerFactory;
class MachSendRight;
struct ViewportAttributes;
}
namespace WebKit {
struct ColorSpaceData;
class LayerTreeHost;
class WebPage;
struct WebPageCreationParameters;
struct WebPreferencesStore;
class DrawingArea : public IPC::MessageReceiver {
WTF_MAKE_NONCOPYABLE(DrawingArea);
public:
static std::unique_ptr<DrawingArea> create(WebPage&, const WebPageCreationParameters&);
virtual ~DrawingArea();
DrawingAreaType type() const { return m_type; }
virtual void setNeedsDisplay() = 0;
virtual void setNeedsDisplayInRect(const WebCore::IntRect&) = 0;
virtual void scroll(const WebCore::IntRect& scrollRect, const WebCore::IntSize& scrollDelta) = 0;
virtual void pageBackgroundTransparencyChanged() { }
virtual void forceRepaint() { }
virtual bool forceRepaintAsync(CallbackID) { return false; }
virtual void setLayerTreeStateIsFrozen(bool) { }
virtual bool layerTreeStateIsFrozen() const { return false; }
virtual LayerTreeHost* layerTreeHost() const { return 0; }
virtual void setPaintingEnabled(bool) { }
virtual void updatePreferences(const WebPreferencesStore&) { }
virtual void mainFrameContentSizeChanged(const WebCore::IntSize&) { }
#if PLATFORM(COCOA)
virtual void setViewExposedRect(std::optional<WebCore::FloatRect>) = 0;
virtual std::optional<WebCore::FloatRect> viewExposedRect() const = 0;
virtual void acceleratedAnimationDidStart(uint64_t , const String& , double ) { }
virtual void acceleratedAnimationDidEnd(uint64_t , const String& ) { }
virtual void addFence(const WebCore::MachSendRight&) { }
#endif
#if PLATFORM(IOS)
virtual WebCore::FloatRect exposedContentRect() const = 0;
virtual void setExposedContentRect(const WebCore::FloatRect&) = 0;
#endif
virtual void mainFrameScrollabilityChanged(bool) { }
virtual bool supportsAsyncScrolling() { return false; }
virtual bool shouldUseTiledBackingForFrameView(const WebCore::FrameView&) { return false; }
virtual WebCore::GraphicsLayerFactory* graphicsLayerFactory() { return nullptr; }
virtual void setRootCompositingLayer(WebCore::GraphicsLayer*) = 0;
virtual void scheduleCompositingLayerFlush() = 0;
virtual void scheduleCompositingLayerFlushImmediately() = 0;
#if USE(REQUEST_ANIMATION_FRAME_DISPLAY_MONITOR)
virtual RefPtr<WebCore::DisplayRefreshMonitor> createDisplayRefreshMonitor(WebCore::PlatformDisplayID);
#endif
virtual void dispatchAfterEnsuringUpdatedScrollPosition(WTF::Function<void ()>&&);
virtual void activityStateDidChange(WebCore::ActivityState::Flags, bool , const Vector<CallbackID>&) { }
virtual void setLayerHostingMode(LayerHostingMode) { }
virtual bool markLayersVolatileImmediatelyIfPossible() { return true; }
virtual bool adjustLayerFlushThrottling(WebCore::LayerFlushThrottleState::Flags) { return false; }
virtual void attachViewOverlayGraphicsLayer(WebCore::Frame*, WebCore::GraphicsLayer*) { }
virtual void setShouldScaleViewToFitDocument(bool) { }
virtual bool dispatchDidReachLayoutMilestone(WebCore::LayoutMilestones) { return false; }
#if PLATFORM(COCOA)
virtual void updateGeometry(const WebCore::IntSize& viewSize, const WebCore::IntSize& layerPosition, bool flushSynchronously, const WebCore::MachSendRight& fencePort) { }
#endif
virtual void layerHostDidFlushLayers() { };
#if USE(COORDINATED_GRAPHICS)
virtual void didChangeViewportAttributes(WebCore::ViewportAttributes&&) = 0;
virtual void resetUpdateAtlasForTesting() = 0;
#endif
#if USE(COORDINATED_GRAPHICS) || USE(TEXTURE_MAPPER)
virtual void deviceOrPageScaleFactorChanged() = 0;
#endif
protected:
DrawingArea(DrawingAreaType, WebPage&);
DrawingAreaType m_type;
WebPage& m_webPage;
#if USE(TEXTURE_MAPPER_GL) && PLATFORM(GTK) && PLATFORM(X11) && !USE(REDIRECTED_XCOMPOSITE_WINDOW)
uint64_t m_nativeSurfaceHandleForCompositing { 0 };
#endif
private:
void didReceiveMessage(IPC::Connection&, IPC::Decoder&) override;
void didReceiveSyncMessage(IPC::Connection&, IPC::Decoder&, std::unique_ptr<IPC::Encoder>&) override;
virtual void updateBackingStoreState(uint64_t , bool , float , const WebCore::IntSize& ,
const WebCore::IntSize& ) { }
virtual void didUpdate() { }
#if PLATFORM(COCOA)
virtual void setDeviceScaleFactor(float) { }
virtual void setColorSpace(const ColorSpaceData&) { }
virtual void adjustTransientZoom(double scale, WebCore::FloatPoint origin) { }
virtual void commitTransientZoom(double scale, WebCore::FloatPoint origin) { }
virtual void addTransactionCallbackID(WebKit::CallbackID) { ASSERT_NOT_REACHED(); }
#endif
#if USE(TEXTURE_MAPPER_GL) && PLATFORM(GTK) && PLATFORM(X11) && !USE(REDIRECTED_XCOMPOSITE_WINDOW)
virtual void setNativeSurfaceHandleForCompositing(uint64_t) = 0;
virtual void destroyNativeSurfaceHandleForCompositing(bool&) = 0;
#endif
};
}
#define SPECIALIZE_TYPE_TRAITS_DRAWING_AREA(ToValueTypeName, AreaType) \
SPECIALIZE_TYPE_TRAITS_BEGIN(WebKit::ToValueTypeName) \
static bool isType(const WebKit::DrawingArea& area) { return area.type() == WebKit::AreaType; } \
SPECIALIZE_TYPE_TRAITS_END()