| |
| /* |
| * Copyright 2011 Google Inc. |
| * |
| * Use of this source code is governed by a BSD-style license that can be |
| * found in the LICENSE file. |
| */ |
| #ifndef SkCGUtils_DEFINED |
| #define SkCGUtils_DEFINED |
| |
| #include "SkTypes.h" |
| |
| #ifdef SK_BUILD_FOR_MAC |
| #include <ApplicationServices/ApplicationServices.h> |
| #endif |
| |
| #ifdef SK_BUILD_FOR_IOS |
| #include <CoreGraphics/CoreGraphics.h> |
| #endif |
| |
| class SkBitmap; |
| class SkStream; |
| |
| /** |
| * Create an imageref from the specified bitmap using the specified colorspace. |
| * If space is NULL, then CGColorSpaceCreateDeviceRGB() is used. |
| */ |
| CGImageRef SkCreateCGImageRefWithColorspace(const SkBitmap& bm, |
| CGColorSpaceRef space); |
| |
| /** |
| * Create an imageref from the specified bitmap using the colorspace returned |
| * by CGColorSpaceCreateDeviceRGB() |
| */ |
| static inline CGImageRef SkCreateCGImageRef(const SkBitmap& bm) { |
| return SkCreateCGImageRefWithColorspace(bm, NULL); |
| } |
| |
| /** |
| * Draw the bitmap into the specified CG context. The bitmap will be converted |
| * to a CGImage using the generic RGB colorspace. (x,y) specifies the position |
| * of the top-left corner of the bitmap. The bitmap is converted using the |
| * colorspace returned by CGColorSpaceCreateDeviceRGB() |
| */ |
| void SkCGDrawBitmap(CGContextRef, const SkBitmap&, float x, float y); |
| |
| bool SkPDFDocumentToBitmap(SkStream* stream, SkBitmap* output); |
| |
| #endif |