diff options
author | Steve Block <steveblock@google.com> | 2011-05-06 11:45:16 +0100 |
---|---|---|
committer | Steve Block <steveblock@google.com> | 2011-05-12 13:44:10 +0100 |
commit | cad810f21b803229eb11403f9209855525a25d57 (patch) | |
tree | 29a6fd0279be608e0fe9ffe9841f722f0f4e4269 /WebCore/platform/image-decoders/cg | |
parent | 121b0cf4517156d0ac5111caf9830c51b69bae8f (diff) | |
download | external_webkit-cad810f21b803229eb11403f9209855525a25d57.zip external_webkit-cad810f21b803229eb11403f9209855525a25d57.tar.gz external_webkit-cad810f21b803229eb11403f9209855525a25d57.tar.bz2 |
Merge WebKit at r75315: Initial merge by git.
Change-Id: I570314b346ce101c935ed22a626b48c2af266b84
Diffstat (limited to 'WebCore/platform/image-decoders/cg')
-rw-r--r-- | WebCore/platform/image-decoders/cg/ImageDecoderCG.cpp | 104 |
1 files changed, 0 insertions, 104 deletions
diff --git a/WebCore/platform/image-decoders/cg/ImageDecoderCG.cpp b/WebCore/platform/image-decoders/cg/ImageDecoderCG.cpp deleted file mode 100644 index 3974f0e..0000000 --- a/WebCore/platform/image-decoders/cg/ImageDecoderCG.cpp +++ /dev/null @@ -1,104 +0,0 @@ -/* - * Copyright (C) 2010 Google, Inc. - * - * 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 COMPUTER, INC. ``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 COMPUTER, INC. OR - * 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. - */ - -#include "config.h" -#include "ImageDecoder.h" - -#include <CoreGraphics/CGColorSpace.h> -#include <CoreGraphics/CGImage.h> - -namespace WebCore { - -static RGBA32Buffer::PixelData* getPtrAsPixelData(CFMutableDataRef data) -{ - return data ? reinterpret_cast<RGBA32Buffer::PixelData*>(CFDataGetMutableBytePtr(data)) : 0; -} - -void RGBA32Buffer::copyReferenceToBitmapData(const RGBA32Buffer& other) -{ - ASSERT(this != &other); - m_backingStore = other.m_backingStore; - m_bytes = getPtrAsPixelData(m_backingStore.get()); - // FIXME: The rest of this function seems redundant with RGBA32Buffer::copyBitmapData. - m_size = other.m_size; - setHasAlpha(other.m_hasAlpha); -} - -bool RGBA32Buffer::copyBitmapData(const RGBA32Buffer& other) -{ - if (this == &other) - return true; - - m_backingStore.adoptCF(CFDataCreateMutableCopy(kCFAllocatorDefault, 0, other.m_backingStore.get())); - m_bytes = getPtrAsPixelData(m_backingStore.get()); - m_size = other.m_size; - setHasAlpha(other.m_hasAlpha); - return true; -} - -bool RGBA32Buffer::setSize(int newWidth, int newHeight) -{ - ASSERT(!m_backingStore); - size_t backingStoreSize = newWidth * newHeight * sizeof(PixelData); - CFMutableDataRef backingStoreRef = CFDataCreateMutable(kCFAllocatorDefault, backingStoreSize); - if (!backingStoreRef) - return false; - m_backingStore.adoptCF(backingStoreRef); - CFDataSetLength(backingStoreRef, backingStoreSize); - m_bytes = reinterpret_cast<PixelData*>(CFDataGetMutableBytePtr(m_backingStore.get())); - m_size = IntSize(newWidth, newHeight); - - zeroFill(); - return true; -} - -static CGColorSpaceRef createColorSpace(const ColorProfile& colorProfile) -{ - if (colorProfile.isEmpty()) - return CGColorSpaceCreateDeviceRGB(); - - RetainPtr<CFDataRef> data(AdoptCF, CFDataCreate(kCFAllocatorDefault, reinterpret_cast<const UInt8*>(colorProfile.data()), colorProfile.size())); -#if !defined(TARGETING_TIGER) && !defined(TARGETING_LEOPARD) - return CGColorSpaceCreateWithICCProfile(data.get()); -#else - RetainPtr<CGColorSpaceRef> deviceColorSpace(AdoptCF, CGColorSpaceCreateDeviceRGB()); - RetainPtr<CGDataProviderRef> profileDataProvider(AdoptCF, CGDataProviderCreateWithCFData(data.get())); - CGFloat ranges[] = {0.0, 255.0, 0.0, 255.0, 0.0, 255.0}; - return CGColorSpaceCreateICCBased(3, ranges, profileDataProvider.get(), deviceColorSpace.get()); -#endif -} - -NativeImagePtr RGBA32Buffer::asNewNativeImage() const -{ - RetainPtr<CGColorSpaceRef> colorSpace(AdoptCF, createColorSpace(m_colorProfile)); - RetainPtr<CGDataProviderRef> dataProvider(AdoptCF, CGDataProviderCreateWithCFData(m_backingStore.get())); - - CGImageAlphaInfo alphaInfo = m_premultiplyAlpha ? kCGImageAlphaPremultipliedFirst : kCGImageAlphaFirst; - - return CGImageCreate(width(), height(), 8, 32, width() * sizeof(PixelData), colorSpace.get(), - alphaInfo | kCGBitmapByteOrder32Host, dataProvider.get(), 0, /*shouldInterpolate=*/true, kCGRenderingIntentDefault); -} - -} // namespace WebCore |