Source/QuartzUtils.h
author Jens Alfke <jens@mooseyard.com>
Wed Mar 12 15:51:32 2008 -0700 (2008-03-12)
changeset 6 af9b2b929b03
parent 0 e9f7ba4718e1
child 8 45c82a071aca
permissions -rw-r--r--
Fixed: An exception in the Go game if you mouse down on the board but then drag to the captured-pieces area and release the mouse.
     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                   kAlmostInvisibleWhiteColor,
    30                   kHighlightColor;
    31 
    32 #if TARGET_OS_ASPEN
    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 /** Moves a layer from one superlayer to another, without changing its position onscreen. */
    43 void ChangeSuperlayer( CALayer *layer, CALayer *newSuperlayer, int index );
    44 
    45 /** Removes a layer from its superlayer without any fade-out animation. */
    46 void RemoveImmediately( CALayer *layer );
    47 
    48 
    49 /** Loads an image or pattern file into a CGImage or CGPattern.
    50     If the name begins with "/", it's interpreted as an absolute filesystem path.
    51     Otherwise, it's the name of a resource that's looked up in the app bundle.
    52     The image must exist, or an assertion-failure exception will be raised!
    53     Loaded images/patterns are cached in memory, so subsequent calls with the same name
    54     are very fast.
    55     The caller must NOT release the result, since it's retained in the cache. */
    56 CGImageRef GetCGImageNamed( NSString *name );
    57 CGColorRef GetCGPatternNamed( NSString *name );
    58 
    59 #if ! TARGET_OS_ASPEN
    60 /** Loads image data from the pasteboard into a CGImage. */
    61 CGImageRef GetCGImageFromPasteboard( NSPasteboard *pb );
    62 #endif
    63 
    64 /** Creates a CGPattern from a CGImage. Caller must release it. */
    65 CGPatternRef CreateImagePattern( CGImageRef image );
    66 
    67 /** Creates a CGColor that draws the given CGImage as a pattern. Caller must release it. */
    68 CGColorRef CreatePatternColor( CGImageRef image );
    69 
    70 /** Returns the alpha value of a single pixel in a CGImage, scaled to a particular size. */
    71 float GetPixelAlpha( CGImageRef image, CGSize imageSize, CGPoint pt );
    72 
    73 /** Returns the center point of a CGRect. */
    74 static inline CGPoint GetCGRectCenter( CGRect rect ) {
    75     return CGPointMake(CGRectGetMidX(rect),CGRectGetMidY(rect));
    76 }
    77 
    78 void AddRoundRect( CGContextRef ctx, CGRect rect, CGFloat radius );