Source/QuartzUtils.h
author Jens Alfke <jens@mooseyard.com>
Tue Jul 07 08:44:33 2009 -0700 (2009-07-07)
changeset 28 06160a812d43
parent 10 6c78cc6bd7a6
permissions -rw-r--r--
Fixed: Bits with odd heights or widths could be blurry when placed on a Grid (thanks to David Hoyos for the fix!)
     1 /*  This code is based on Apple's "GeekGameBoard" sample code, version 1.0.
     2     http://developer.apple.com/samplecode/GeekGameBoard/
     3     Copyright © 2007 Apple Inc. Copyright © 2008 Jens Alfke. All Rights Reserved.
     4 
     5     Redistribution and use in source and binary forms, with or without modification, are permitted
     6     provided that the following conditions are met:
     7 
     8     * Redistributions of source code must retain the above copyright notice, this list of conditions
     9       and the following disclaimer.
    10     * Redistributions in binary form must reproduce the above copyright notice, this list of
    11       conditions and the following disclaimer in the documentation and/or other materials provided
    12       with the distribution.
    13 
    14     THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
    15     IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND 
    16     FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRI-
    17     BUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
    18     (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
    19     PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 
    20     CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF 
    21     THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
    22 */
    23 #import "GGBLayer.h"
    24 
    25 
    26 /** Constants for various commonly used colors. */
    27 extern CGColorRef kBlackColor, kWhiteColor, 
    28                   kTranslucentGrayColor, kTranslucentLightGrayColor, 
    29                   kTranslucentWhiteColor, kAlmostInvisibleWhiteColor,
    30                   kHighlightColor;
    31 
    32 #if TARGET_OS_IPHONE
    33 // These don't exist on iPhone, so I implement them:
    34 CGColorRef CreateGray(CGFloat gray, CGFloat alpha);
    35 CGColorRef CreateRGB(CGFloat red, CGFloat green, CGFloat blue, CGFloat alpha);
    36 #else
    37 #define CreateGray  CGColorCreateGenericGray
    38 #define CreateRGB   CGColorCreateGenericRGB
    39 #endif
    40 
    41 
    42 /** Loads an image or pattern file into a CGImage or CGPattern.
    43     If the name begins with "/", it's interpreted as an absolute filesystem path.
    44     Otherwise, it's the name of a resource that's looked up in the app bundle.
    45     The image must exist, or an assertion-failure exception will be raised!
    46     Loaded images/patterns are cached in memory, so subsequent calls with the same name
    47     are very fast.
    48     The caller must NOT release the result, since it's retained in the cache. */
    49 CGImageRef GetCGImageNamed( NSString *name );
    50 CGColorRef GetCGPatternNamed( NSString *name );
    51 
    52 #if ! TARGET_OS_IPHONE
    53 /** Is it possible to read a CGImage from this pasteboard? */
    54 BOOL CanGetCGImageFromPasteboard( NSPasteboard *pb );
    55 /** Loads image data from the pasteboard into a CGImage. */
    56 CGImageRef GetCGImageFromPasteboard( NSPasteboard *pb, id<NSDraggingInfo>dragInfo );
    57 #endif
    58 
    59 CGImageRef CreateScaledImage( CGImageRef srcImage, CGFloat scale );
    60 CGImageRef GetScaledImageNamed( NSString *imageName, CGFloat scale );
    61 
    62 /** Creates a CGPattern from a CGImage. Caller must release it. */
    63 CGPatternRef CreateImagePattern( CGImageRef image );
    64 
    65 /** Creates a CGColor that draws the given CGImage as a pattern. Caller must release it. */
    66 CGColorRef CreatePatternColor( CGImageRef image );
    67 
    68 /** Returns the alpha value of a single pixel in a CGImage, scaled to a particular size. */
    69 float GetPixelAlpha( CGImageRef image, CGSize imageSize, CGPoint pt );
    70 
    71 /** Returns the center point of a CGRect. */
    72 static inline CGPoint GetCGRectCenter( CGRect rect ) {
    73     return CGPointMake(CGRectGetMidX(rect),CGRectGetMidY(rect));
    74 }
    75 
    76 void AddRoundRect( CGContextRef ctx, CGRect rect, CGFloat radius );