/* * 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 ShareableBitmap_h #define ShareableBitmap_h #include "SharedMemory.h" #include #include #include #include #include #if USE(CG) #include #endif namespace WebCore { class GraphicsContext; } namespace WebKit { class ShareableBitmap : public RefCounted { public: enum Flag { SupportsAlpha = 1 << 0, }; typedef unsigned Flags; class Handle { WTF_MAKE_NONCOPYABLE(Handle); public: Handle(); bool isNull() const { return m_handle.isNull(); } void encode(CoreIPC::ArgumentEncoder*) const; static bool decode(CoreIPC::ArgumentDecoder*, Handle&); private: friend class ShareableBitmap; mutable SharedMemory::Handle m_handle; WebCore::IntSize m_size; Flags m_flags; }; // Create a shareable bitmap that uses malloced memory. static PassRefPtr create(const WebCore::IntSize&, Flags); // Create a shareable bitmap whose backing memory can be shared with another process. static PassRefPtr createShareable(const WebCore::IntSize&, Flags); // Create a shareable bitmap from an already existing shared memory block. static PassRefPtr create(const WebCore::IntSize&, Flags, PassRefPtr); // Create a shareable bitmap from a handle. static PassRefPtr create(const Handle&); // Create a handle. bool createHandle(Handle&); ~ShareableBitmap(); const WebCore::IntSize& size() const { return m_size; } WebCore::IntRect bounds() const { return WebCore::IntRect(WebCore::IntPoint(), size()); } bool resize(const WebCore::IntSize& size); // Create a graphics context that can be used to paint into the backing store. PassOwnPtr createGraphicsContext(); // Paint the backing store into the given context. void paint(WebCore::GraphicsContext&, const WebCore::IntPoint& dstPoint, const WebCore::IntRect& srcRect); bool isBackedBySharedMemory() const { return m_sharedMemory; } #if USE(CG) // This creates a copied CGImageRef (most likely a copy-on-write) of the shareable bitmap. RetainPtr makeCGImageCopy(); // This creates a CGImageRef that directly references the shared bitmap data. // This is only safe to use when we know that the contents of the shareable bitmap won't change. RetainPtr makeCGImage(); #endif private: ShareableBitmap(const WebCore::IntSize&, Flags, void*); ShareableBitmap(const WebCore::IntSize&, Flags, PassRefPtr); static size_t numBytesForSize(const WebCore::IntSize& size) { return size.width() * size.height() * 4; } #if USE(CG) static void releaseBitmapContextData(void* typelessBitmap, void* typelessData); static void releaseDataProviderData(void* typelessBitmap, const void* typelessData, size_t); #endif void* data() const; size_t sizeInBytes() const { return numBytesForSize(m_size); } WebCore::IntSize m_size; Flags m_flags; // If the shareable bitmap is backed by shared memory, this points to the shared memory object. RefPtr m_sharedMemory; // If the shareable bitmap is backed by fastMalloced memory, this points to the data. void* m_data; }; } // namespace WebKit #endif // ShareableBitmap_h