| /* |
| * Copyright (C) 2010 Apple Inc. All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions |
| * are met: |
| * 1. Redistributions of source code must retain the above copyright |
| * notice, this list of conditions and the following disclaimer. |
| * 2. Redistributions in binary form must reproduce the above copyright |
| * notice, this list of conditions and the following disclaimer in the |
| * documentation and/or other materials provided with the distribution. |
| * |
| * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' |
| * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, |
| * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS |
| * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF |
| * THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #ifndef DrawingArea_h |
| #define DrawingArea_h |
| |
| #include "DrawingAreaInfo.h" |
| #include "LayerTreeContext.h" |
| #include "MessageReceiver.h" |
| #include <WebCore/FloatRect.h> |
| #include <WebCore/IntRect.h> |
| #include <WebCore/LayerFlushThrottleState.h> |
| #include <WebCore/LayoutMilestones.h> |
| #include <WebCore/PlatformScreen.h> |
| #include <WebCore/ViewState.h> |
| #include <functional> |
| #include <wtf/Forward.h> |
| #include <wtf/Noncopyable.h> |
| #include <wtf/TypeCasts.h> |
| |
| namespace IPC { |
| class Connection; |
| class MessageDecoder; |
| } |
| |
| namespace WebCore { |
| class DisplayRefreshMonitor; |
| class Frame; |
| class FrameView; |
| class GraphicsLayer; |
| class GraphicsLayerFactory; |
| class MachSendRight; |
| } |
| |
| 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; |
| |
| // FIXME: These should be pure virtual. |
| virtual void pageBackgroundTransparencyChanged() { } |
| virtual void forceRepaint() { } |
| virtual bool forceRepaintAsync(uint64_t /*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 setExposedRect(const WebCore::FloatRect&) = 0; |
| virtual WebCore::FloatRect exposedRect() const = 0; |
| virtual void acceleratedAnimationDidStart(uint64_t /*layerID*/, const String& /*key*/, double /*startTime*/) { } |
| virtual void acceleratedAnimationDidEnd(uint64_t /*layerID*/, const String& /*key*/) { } |
| 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(PlatformDisplayID); |
| #endif |
| |
| #if USE(COORDINATED_GRAPHICS_MULTIPROCESS) |
| virtual void didReceiveCoordinatedLayerTreeHostMessage(IPC::Connection&, IPC::MessageDecoder&) = 0; |
| #endif |
| |
| virtual void dispatchAfterEnsuringUpdatedScrollPosition(std::function<void ()>); |
| |
| virtual void viewStateDidChange(WebCore::ViewState::Flags, bool /* wantsDidUpdateViewState */, const Vector<uint64_t>& /* callbackIDs */) { } |
| 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 dispatchDidLayout(WebCore::LayoutMilestones) { return false; } |
| |
| #if PLATFORM(COCOA) |
| // Used by TiledCoreAnimationDrawingArea. |
| virtual void updateGeometry(const WebCore::IntSize& viewSize, const WebCore::IntSize& layerPosition, bool flushSynchronously, const WebCore::MachSendRight& fencePort) { } |
| #endif |
| |
| protected: |
| DrawingArea(DrawingAreaType, WebPage&); |
| |
| DrawingAreaType m_type; |
| WebPage& m_webPage; |
| |
| #if USE(TEXTURE_MAPPER) && PLATFORM(GTK) |
| uint64_t m_nativeSurfaceHandleForCompositing; |
| #endif |
| |
| private: |
| // IPC::MessageReceiver. |
| void didReceiveMessage(IPC::Connection&, IPC::MessageDecoder&) override; |
| void didReceiveSyncMessage(IPC::Connection&, IPC::MessageDecoder&, std::unique_ptr<IPC::MessageEncoder>&) override; |
| |
| // Message handlers. |
| // FIXME: These should be pure virtual. |
| virtual void updateBackingStoreState(uint64_t /*backingStoreStateID*/, bool /*respondImmediately*/, float /*deviceScaleFactor*/, const WebCore::IntSize& /*size*/, |
| const WebCore::IntSize& /*scrollOffset*/) { } |
| virtual void didUpdate() { } |
| |
| #if PLATFORM(COCOA) |
| // Used by TiledCoreAnimationDrawingArea. |
| 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(uint64_t callbackID) { ASSERT_NOT_REACHED(); } |
| #endif |
| |
| #if USE(TEXTURE_MAPPER) && PLATFORM(GTK) |
| virtual void setNativeSurfaceHandleForCompositing(uint64_t) = 0; |
| virtual void destroyNativeSurfaceHandleForCompositing(bool&) = 0; |
| #endif |
| }; |
| |
| } // namespace WebKit |
| |
| #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() |
| |
| #endif // DrawingArea_h |