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.
5 Redistribution and use in source and binary forms, with or without modification, are permitted
6 provided that the following conditions are met:
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.
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.
26 /** Constants for various commonly used colors. */
27 extern CGColorRef kBlackColor, kWhiteColor,
28 kTranslucentGrayColor, kTranslucentLightGrayColor,
29 kAlmostInvisibleWhiteColor,
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);
37 #define CreateGray CGColorCreateGenericGray
38 #define CreateRGB CGColorCreateGenericRGB
42 /** Moves a layer from one superlayer to another, without changing its position onscreen. */
43 void ChangeSuperlayer( CALayer *layer, CALayer *newSuperlayer, int index );
45 /** Removes a layer from its superlayer without any fade-out animation. */
46 void RemoveImmediately( CALayer *layer );
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
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 );
60 /** Loads image data from the pasteboard into a CGImage. */
61 CGImageRef GetCGImageFromPasteboard( NSPasteboard *pb );
64 /** Creates a CGPattern from a CGImage. Caller must release it. */
65 CGPatternRef CreateImagePattern( CGImageRef image );
67 /** Creates a CGColor that draws the given CGImage as a pattern. Caller must release it. */
68 CGColorRef CreatePatternColor( CGImageRef image );
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 );
73 /** Returns the center point of a CGRect. */
74 static inline CGPoint GetCGRectCenter( CGRect rect ) {
75 return CGPointMake(CGRectGetMidX(rect),CGRectGetMidY(rect));
78 void AddRoundRect( CGContextRef ctx, CGRect rect, CGFloat radius );