diff options
Diffstat (limited to 'libs/cocos2d/CCMenuItem.h')
| -rwxr-xr-x | libs/cocos2d/CCMenuItem.h | 377 |
1 files changed, 377 insertions, 0 deletions
| diff --git a/libs/cocos2d/CCMenuItem.h b/libs/cocos2d/CCMenuItem.h new file mode 100755 index 0000000..2437394 --- /dev/null +++ b/libs/cocos2d/CCMenuItem.h | |||
| @@ -0,0 +1,377 @@ | |||
| 1 | /* | ||
| 2 | * cocos2d for iPhone: http://www.cocos2d-iphone.org | ||
| 3 | * | ||
| 4 | * Copyright (c) 2008-2011 Ricardo Quesada | ||
| 5 | * Copyright (c) 2011 Zynga Inc. | ||
| 6 | * | ||
| 7 | * Permission is hereby granted, free of charge, to any person obtaining a copy | ||
| 8 | * of this software and associated documentation files (the "Software"), to deal | ||
| 9 | * in the Software without restriction, including without limitation the rights | ||
| 10 | * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
| 11 | * copies of the Software, and to permit persons to whom the Software is | ||
| 12 | * furnished to do so, subject to the following conditions: | ||
| 13 | * | ||
| 14 | * The above copyright notice and this permission notice shall be included in | ||
| 15 | * all copies or substantial portions of the Software. | ||
| 16 | * | ||
| 17 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
| 18 | * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
| 19 | * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
| 20 | * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
| 21 | * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
| 22 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||
| 23 | * THE SOFTWARE. | ||
| 24 | * | ||
| 25 | */ | ||
| 26 | |||
| 27 | #import "CCBlockSupport.h" | ||
| 28 | |||
| 29 | #import "CCNode.h" | ||
| 30 | #import "CCProtocols.h" | ||
| 31 | |||
| 32 | @class CCSprite; | ||
| 33 | |||
| 34 | #define kCCItemSize 32 | ||
| 35 | |||
| 36 | #pragma mark - | ||
| 37 | #pragma mark CCMenuItem | ||
| 38 | /** CCMenuItem base class | ||
| 39 | * | ||
| 40 | * Subclass CCMenuItem (or any subclass) to create your custom CCMenuItem objects. | ||
| 41 | */ | ||
| 42 | @interface CCMenuItem : CCNode | ||
| 43 | { | ||
| 44 | NSInvocation *invocation_; | ||
| 45 | #if NS_BLOCKS_AVAILABLE | ||
| 46 | // used for menu items using a block | ||
| 47 | void (^block_)(id sender); | ||
| 48 | #endif | ||
| 49 | |||
| 50 | BOOL isEnabled_; | ||
| 51 | BOOL isSelected_; | ||
| 52 | } | ||
| 53 | |||
| 54 | /** returns whether or not the item is selected | ||
| 55 | @since v0.8.2 | ||
| 56 | */ | ||
| 57 | @property (nonatomic,readonly) BOOL isSelected; | ||
| 58 | |||
| 59 | /** Creates a CCMenuItem with a target/selector */ | ||
| 60 | +(id) itemWithTarget:(id)target selector:(SEL)selector; | ||
| 61 | |||
| 62 | /** Initializes a CCMenuItem with a target/selector */ | ||
| 63 | -(id) initWithTarget:(id)target selector:(SEL)selector; | ||
| 64 | |||
| 65 | #if NS_BLOCKS_AVAILABLE | ||
| 66 | /** Creates a CCMenuItem with the specified block. | ||
| 67 | The block will be "copied". | ||
| 68 | */ | ||
| 69 | +(id) itemWithBlock:(void(^)(id sender))block; | ||
| 70 | |||
| 71 | /** Initializes a CCMenuItem with the specified block. | ||
| 72 | The block will be "copied". | ||
| 73 | */ | ||
| 74 | -(id) initWithBlock:(void(^)(id sender))block; | ||
| 75 | #endif | ||
| 76 | |||
| 77 | /** Returns the outside box in points */ | ||
| 78 | -(CGRect) rect; | ||
| 79 | |||
| 80 | /** Activate the item */ | ||
| 81 | -(void) activate; | ||
| 82 | |||
| 83 | /** The item was selected (not activated), similar to "mouse-over" */ | ||
| 84 | -(void) selected; | ||
| 85 | |||
| 86 | /** The item was unselected */ | ||
| 87 | -(void) unselected; | ||
| 88 | |||
| 89 | /** Enable or disabled the CCMenuItem */ | ||
| 90 | -(void) setIsEnabled:(BOOL)enabled; | ||
| 91 | /** Returns whether or not the CCMenuItem is enabled */ | ||
| 92 | -(BOOL) isEnabled; | ||
| 93 | @end | ||
| 94 | |||
| 95 | #pragma mark - | ||
| 96 | #pragma mark CCMenuItemLabel | ||
| 97 | |||
| 98 | /** An abstract class for "label" CCMenuItemLabel items | ||
| 99 | Any CCNode that supports the CCLabelProtocol protocol can be added. | ||
| 100 | Supported nodes: | ||
| 101 | - CCLabelBMFont | ||
| 102 | - CCLabelAtlas | ||
| 103 | - CCLabelTTF | ||
| 104 | */ | ||
| 105 | @interface CCMenuItemLabel : CCMenuItem <CCRGBAProtocol> | ||
| 106 | { | ||
| 107 | CCNode<CCLabelProtocol, CCRGBAProtocol> *label_; | ||
| 108 | ccColor3B colorBackup; | ||
| 109 | ccColor3B disabledColor_; | ||
| 110 | float originalScale_; | ||
| 111 | } | ||
| 112 | |||
| 113 | /** the color that will be used to disable the item */ | ||
| 114 | @property (nonatomic,readwrite) ccColor3B disabledColor; | ||
| 115 | |||
| 116 | /** Label that is rendered. It can be any CCNode that implements the CCLabelProtocol */ | ||
| 117 | @property (nonatomic,readwrite,assign) CCNode<CCLabelProtocol, CCRGBAProtocol>* label; | ||
| 118 | |||
| 119 | /** creates a CCMenuItemLabel with a Label. Target and selector will be nill */ | ||
| 120 | +(id) itemWithLabel:(CCNode<CCLabelProtocol,CCRGBAProtocol>*)label; | ||
| 121 | |||
| 122 | /** creates a CCMenuItemLabel with a Label, target and selector */ | ||
| 123 | +(id) itemWithLabel:(CCNode<CCLabelProtocol,CCRGBAProtocol>*)label target:(id)target selector:(SEL)selector; | ||
| 124 | |||
| 125 | /** initializes a CCMenuItemLabel with a Label, target and selector */ | ||
| 126 | -(id) initWithLabel:(CCNode<CCLabelProtocol,CCRGBAProtocol>*)label target:(id)target selector:(SEL)selector; | ||
| 127 | |||
| 128 | #if NS_BLOCKS_AVAILABLE | ||
| 129 | /** creates a CCMenuItemLabel with a Label and a block to execute. | ||
| 130 | The block will be "copied". | ||
| 131 | */ | ||
| 132 | +(id) itemWithLabel:(CCNode<CCLabelProtocol,CCRGBAProtocol>*)label block:(void(^)(id sender))block; | ||
| 133 | |||
| 134 | /** initializes a CCMenuItemLabel with a Label and a block to execute. | ||
| 135 | The block will be "copied". | ||
| 136 | */ | ||
| 137 | -(id) initWithLabel:(CCNode<CCLabelProtocol,CCRGBAProtocol>*)label block:(void(^)(id sender))block; | ||
| 138 | #endif | ||
| 139 | |||
| 140 | /** sets a new string to the inner label */ | ||
| 141 | -(void) setString:(NSString*)label; | ||
| 142 | |||
| 143 | /** Enable or disabled the CCMenuItemFont | ||
| 144 | @warning setIsEnabled changes the RGB color of the font | ||
| 145 | */ | ||
| 146 | -(void) setIsEnabled: (BOOL)enabled; | ||
| 147 | @end | ||
| 148 | |||
| 149 | #pragma mark - | ||
| 150 | #pragma mark CCMenuItemAtlasFont | ||
| 151 | |||
| 152 | /** A CCMenuItemAtlasFont | ||
| 153 | Helper class that creates a MenuItemLabel class with a LabelAtlas | ||
| 154 | */ | ||
| 155 | @interface CCMenuItemAtlasFont : CCMenuItemLabel | ||
| 156 | { | ||
| 157 | } | ||
| 158 | |||
| 159 | /** creates a menu item from a string and atlas with a target/selector */ | ||
| 160 | +(id) itemFromString: (NSString*) value charMapFile:(NSString*) charMapFile itemWidth:(int)itemWidth itemHeight:(int)itemHeight startCharMap:(char)startCharMap; | ||
| 161 | |||
| 162 | /** creates a menu item from a string and atlas. Use it with MenuItemToggle */ | ||
| 163 | +(id) itemFromString: (NSString*) value charMapFile:(NSString*) charMapFile itemWidth:(int)itemWidth itemHeight:(int)itemHeight startCharMap:(char)startCharMap target:(id) rec selector:(SEL) cb; | ||
| 164 | |||
| 165 | /** initializes a menu item from a string and atlas with a target/selector */ | ||
| 166 | -(id) initFromString: (NSString*) value charMapFile:(NSString*) charMapFile itemWidth:(int)itemWidth itemHeight:(int)itemHeight startCharMap:(char)startCharMap target:(id) rec selector:(SEL) cb; | ||
| 167 | |||
| 168 | #if NS_BLOCKS_AVAILABLE | ||
| 169 | /** creates a menu item from a string and atlas. Use it with MenuItemToggle. | ||
| 170 | The block will be "copied". | ||
| 171 | */ | ||
| 172 | +(id) itemFromString: (NSString*) value charMapFile:(NSString*) charMapFile itemWidth:(int)itemWidth itemHeight:(int)itemHeight startCharMap:(char)startCharMap block:(void(^)(id sender))block; | ||
| 173 | |||
| 174 | /** initializes a menu item from a string and atlas with a block. | ||
| 175 | The block will be "copied". | ||
| 176 | */ | ||
| 177 | -(id) initFromString: (NSString*) value charMapFile:(NSString*) charMapFile itemWidth:(int)itemWidth itemHeight:(int)itemHeight startCharMap:(char)startCharMap block:(void(^)(id sender))block; | ||
| 178 | #endif | ||
| 179 | |||
| 180 | @end | ||
| 181 | |||
| 182 | #pragma mark - | ||
| 183 | #pragma mark CCMenuItemFont | ||
| 184 | |||
| 185 | /** A CCMenuItemFont | ||
| 186 | Helper class that creates a CCMenuItemLabel class with a Label | ||
| 187 | */ | ||
| 188 | @interface CCMenuItemFont : CCMenuItemLabel | ||
| 189 | { | ||
| 190 | NSUInteger fontSize_; | ||
| 191 | NSString *fontName_; | ||
| 192 | } | ||
| 193 | /** set default font size */ | ||
| 194 | +(void) setFontSize: (NSUInteger) s; | ||
| 195 | |||
| 196 | /** get default font size */ | ||
| 197 | +(NSUInteger) fontSize; | ||
| 198 | |||
| 199 | /** set default font name */ | ||
| 200 | +(void) setFontName: (NSString*) n; | ||
| 201 | |||
| 202 | /** get default font name */ | ||
| 203 | +(NSString*) fontName; | ||
| 204 | |||
| 205 | /** creates a menu item from a string without target/selector. To be used with CCMenuItemToggle */ | ||
| 206 | +(id) itemFromString: (NSString*) value; | ||
| 207 | |||
| 208 | /** creates a menu item from a string with a target/selector */ | ||
| 209 | +(id) itemFromString: (NSString*) value target:(id) r selector:(SEL) s; | ||
| 210 | |||
| 211 | /** initializes a menu item from a string with a target/selector */ | ||
| 212 | -(id) initFromString: (NSString*) value target:(id) r selector:(SEL) s; | ||
| 213 | |||
| 214 | /** set font size */ | ||
| 215 | -(void) setFontSize: (NSUInteger) s; | ||
| 216 | |||
| 217 | /** get font size */ | ||
| 218 | -(NSUInteger) fontSize; | ||
| 219 | |||
| 220 | /** set the font name */ | ||
| 221 | -(void) setFontName: (NSString*) n; | ||
| 222 | |||
| 223 | /** get the font name */ | ||
| 224 | -(NSString*) fontName; | ||
| 225 | |||
| 226 | #if NS_BLOCKS_AVAILABLE | ||
| 227 | /** creates a menu item from a string with the specified block. | ||
| 228 | The block will be "copied". | ||
| 229 | */ | ||
| 230 | +(id) itemFromString: (NSString*) value block:(void(^)(id sender))block; | ||
| 231 | |||
| 232 | /** initializes a menu item from a string with the specified block. | ||
| 233 | The block will be "copied". | ||
| 234 | */ | ||
| 235 | -(id) initFromString: (NSString*) value block:(void(^)(id sender))block; | ||
| 236 | #endif | ||
| 237 | @end | ||
| 238 | |||
| 239 | #pragma mark - | ||
| 240 | #pragma mark CCMenuItemSprite | ||
| 241 | |||
| 242 | /** CCMenuItemSprite accepts CCNode<CCRGBAProtocol> objects as items. | ||
| 243 | The images has 3 different states: | ||
| 244 | - unselected image | ||
| 245 | - selected image | ||
| 246 | - disabled image | ||
| 247 | |||
| 248 | @since v0.8.0 | ||
| 249 | */ | ||
| 250 | @interface CCMenuItemSprite : CCMenuItem <CCRGBAProtocol> | ||
| 251 | { | ||
| 252 | CCNode<CCRGBAProtocol> *normalImage_, *selectedImage_, *disabledImage_; | ||
| 253 | } | ||
| 254 | |||
| 255 | // weak references | ||
| 256 | |||
| 257 | /** the image used when the item is not selected */ | ||
| 258 | @property (nonatomic,readwrite,assign) CCNode<CCRGBAProtocol> *normalImage; | ||
| 259 | /** the image used when the item is selected */ | ||
| 260 | @property (nonatomic,readwrite,assign) CCNode<CCRGBAProtocol> *selectedImage; | ||
| 261 | /** the image used when the item is disabled */ | ||
| 262 | @property (nonatomic,readwrite,assign) CCNode<CCRGBAProtocol> *disabledImage; | ||
| 263 | |||
| 264 | /** creates a menu item with a normal and selected image*/ | ||
| 265 | +(id) itemFromNormalSprite:(CCNode<CCRGBAProtocol>*)normalSprite selectedSprite:(CCNode<CCRGBAProtocol>*)selectedSprite; | ||
| 266 | /** creates a menu item with a normal and selected image with target/selector */ | ||
| 267 | +(id) itemFromNormalSprite:(CCNode<CCRGBAProtocol>*)normalSprite selectedSprite:(CCNode<CCRGBAProtocol>*)selectedSprite target:(id)target selector:(SEL)selector; | ||
| 268 | /** creates a menu item with a normal,selected and disabled image with target/selector */ | ||
| 269 | +(id) itemFromNormalSprite:(CCNode<CCRGBAProtocol>*)normalSprite selectedSprite:(CCNode<CCRGBAProtocol>*)selectedSprite disabledSprite:(CCNode<CCRGBAProtocol>*)disabledSprite target:(id)target selector:(SEL)selector; | ||
| 270 | /** initializes a menu item with a normal, selected and disabled image with target/selector */ | ||
| 271 | -(id) initFromNormalSprite:(CCNode<CCRGBAProtocol>*)normalSprite selectedSprite:(CCNode<CCRGBAProtocol>*)selectedSprite disabledSprite:(CCNode<CCRGBAProtocol>*)disabledSprite target:(id)target selector:(SEL)selector; | ||
| 272 | |||
| 273 | #if NS_BLOCKS_AVAILABLE | ||
| 274 | /** creates a menu item with a normal and selected image with a block. | ||
| 275 | The block will be "copied". | ||
| 276 | */ | ||
| 277 | +(id) itemFromNormalSprite:(CCNode<CCRGBAProtocol>*)normalSprite selectedSprite:(CCNode<CCRGBAProtocol>*)selectedSprite block:(void(^)(id sender))block; | ||
| 278 | /** creates a menu item with a normal,selected and disabled image with a block. | ||
| 279 | The block will be "copied". | ||
| 280 | */ | ||
| 281 | +(id) itemFromNormalSprite:(CCNode<CCRGBAProtocol>*)normalSprite selectedSprite:(CCNode<CCRGBAProtocol>*)selectedSprite disabledSprite:(CCNode<CCRGBAProtocol>*)disabledSprite block:(void(^)(id sender))block; | ||
| 282 | /** initializes a menu item with a normal, selected and disabled image with a block. | ||
| 283 | The block will be "copied". | ||
| 284 | */ | ||
| 285 | -(id) initFromNormalSprite:(CCNode<CCRGBAProtocol>*)normalSprite selectedSprite:(CCNode<CCRGBAProtocol>*)selectedSprite disabledSprite:(CCNode<CCRGBAProtocol>*)disabledSprite block:(void(^)(id sender))block; | ||
| 286 | #endif | ||
| 287 | |||
| 288 | @end | ||
| 289 | |||
| 290 | #pragma mark - | ||
| 291 | #pragma mark CCMenuItemImage | ||
| 292 | |||
| 293 | /** CCMenuItemImage accepts images as items. | ||
| 294 | The images has 3 different states: | ||
| 295 | - unselected image | ||
| 296 | - selected image | ||
| 297 | - disabled image | ||
| 298 | |||
| 299 | For best results try that all images are of the same size | ||
| 300 | */ | ||
| 301 | @interface CCMenuItemImage : CCMenuItemSprite | ||
| 302 | { | ||
| 303 | } | ||
| 304 | |||
| 305 | /** creates a menu item with a normal and selected image*/ | ||
| 306 | +(id) itemFromNormalImage: (NSString*)value selectedImage:(NSString*) value2; | ||
| 307 | /** creates a menu item with a normal and selected image with target/selector */ | ||
| 308 | +(id) itemFromNormalImage: (NSString*)value selectedImage:(NSString*) value2 target:(id) r selector:(SEL) s; | ||
| 309 | /** creates a menu item with a normal,selected and disabled image with target/selector */ | ||
| 310 | +(id) itemFromNormalImage: (NSString*)value selectedImage:(NSString*) value2 disabledImage:(NSString*) value3 target:(id) r selector:(SEL) s; | ||
| 311 | /** initializes a menu item with a normal, selected and disabled image with target/selector */ | ||
| 312 | -(id) initFromNormalImage: (NSString*) value selectedImage:(NSString*)value2 disabledImage:(NSString*) value3 target:(id) r selector:(SEL) s; | ||
| 313 | #if NS_BLOCKS_AVAILABLE | ||
| 314 | /** creates a menu item with a normal and selected image with a block. | ||
| 315 | The block will be "copied". | ||
| 316 | */ | ||
| 317 | +(id) itemFromNormalImage: (NSString*)value selectedImage:(NSString*) value2 block:(void(^)(id sender))block; | ||
| 318 | /** creates a menu item with a normal,selected and disabled image with a block. | ||
| 319 | The block will be "copied". | ||
| 320 | */ | ||
| 321 | +(id) itemFromNormalImage: (NSString*)value selectedImage:(NSString*) value2 disabledImage:(NSString*) value3 block:(void(^)(id sender))block; | ||
| 322 | /** initializes a menu item with a normal, selected and disabled image with a block. | ||
| 323 | The block will be "copied". | ||
| 324 | */ | ||
| 325 | -(id) initFromNormalImage: (NSString*) value selectedImage:(NSString*)value2 disabledImage:(NSString*) value3 block:(void(^)(id sender))block; | ||
| 326 | #endif | ||
| 327 | @end | ||
| 328 | |||
| 329 | #pragma mark - | ||
| 330 | #pragma mark CCMenuItemToggle | ||
| 331 | |||
| 332 | /** A CCMenuItemToggle | ||
| 333 | A simple container class that "toggles" it's inner items | ||
| 334 | The inner itmes can be any MenuItem | ||
| 335 | */ | ||
| 336 | @interface CCMenuItemToggle : CCMenuItem <CCRGBAProtocol> | ||
| 337 | { | ||
| 338 | NSUInteger selectedIndex_; | ||
| 339 | NSMutableArray* subItems_; | ||
| 340 | GLubyte opacity_; | ||
| 341 | ccColor3B color_; | ||
| 342 | } | ||
| 343 | |||
| 344 | /** conforms with CCRGBAProtocol protocol */ | ||
| 345 | @property (nonatomic,readonly) GLubyte opacity; | ||
| 346 | /** conforms with CCRGBAProtocol protocol */ | ||
| 347 | @property (nonatomic,readonly) ccColor3B color; | ||
| 348 | |||
| 349 | /** returns the selected item */ | ||
| 350 | @property (nonatomic,readwrite) NSUInteger selectedIndex; | ||
| 351 | /** NSMutableArray that contains the subitems. You can add/remove items in runtime, and you can replace the array with a new one. | ||
| 352 | @since v0.7.2 | ||
| 353 | */ | ||
| 354 | @property (nonatomic,readwrite,retain) NSMutableArray *subItems; | ||
| 355 | |||
| 356 | /** creates a menu item from a list of items with a target/selector */ | ||
| 357 | +(id) itemWithTarget:(id)t selector:(SEL)s items:(CCMenuItem*) item, ... NS_REQUIRES_NIL_TERMINATION; | ||
| 358 | |||
| 359 | /** initializes a menu item from a list of items with a target selector */ | ||
| 360 | -(id) initWithTarget:(id)t selector:(SEL)s items:(CCMenuItem*) item vaList:(va_list) args; | ||
| 361 | |||
| 362 | #if NS_BLOCKS_AVAILABLE | ||
| 363 | /** creates a menu item from a list of items and executes the given block when the item is selected. | ||
| 364 | The block will be "copied". | ||
| 365 | */ | ||
| 366 | +(id) itemWithBlock:(void(^)(id sender))block items:(CCMenuItem*)item, ... NS_REQUIRES_NIL_TERMINATION; | ||
| 367 | |||
| 368 | /** initializes a menu item from a list of items with a block. | ||
| 369 | The block will be "copied". | ||
| 370 | */ | ||
| 371 | -(id) initWithBlock:(void (^)(id))block items:(CCMenuItem*)item vaList:(va_list)args; | ||
| 372 | #endif | ||
| 373 | |||
| 374 | /** return the selected item */ | ||
| 375 | -(CCMenuItem*) selectedItem; | ||
| 376 | @end | ||
| 377 | |||
