CCControl Class Reference
| Inherits from | CCLayer | 
| Conforms to | CCRGBAProtocol | 
| Declared in | CCControl.h | 
Overview
CCControl is inspired by the UIControl API class from the UIKit library of CocoaTouch. It provides a base class for Cocos2D control such as CCControlButton or CCControlSlider that convey user intent to the application.
The goal of CCControl is to define an interface and a base implementation for preparing action messages and initially dispatching them to their targets when certain events occur.
To use the CCControl class you have to subclass it and implement your own behavior.
Tasks
RGBA Protocol Properties
- 
	
		opacityConforms to CCRGBAProtocol protocol. property
- 
	
		displayedOpacityConforms to CCRGBAProtocol (v2.1) protocol. property
- 
	
		colorConforms to CCRGBAProtocol protocol. property
- 
	
		displayedColorConforms to CCRGBAProtocol (v2.1) protocol. property
- 
	
		opacityModifyRGBConforms to CCRGBAProtocol protocol. property
- 
	
		cascadeColorEnabledConforms to CCRGBAProtocol (v2.1) protocol. property
- 
	
		cascadeOpacityEnabledConforms to CCRGBAProtocol (v2.1) protocol. property
Object Attributes
- 
	
		defaultTouchPriorityChanges the priority of the button. The lower the number, the higher the priority. property
- 
	
		stateThe current control state constant. property
- 
	
		enabledTells whether the control is enabled. property
- 
	
		selectedA Boolean value that determines the control’s selected state. property
- 
	
		highlightedA Boolean value that determines whether the control is highlighted. property
- 
	
		hasVisibleParentsTrue if all of the controls parents are visible property
Preparing and Sending Action Messages
- 
	
		– sendActionsForControlEvents:Sends action messages for the given control events. 
- 
	
		– addTarget:action:forControlEvents:Adds a target and action for a particular event (or events) to an internal dispatch table. The action message may optionnaly include the sender and the event as parameters, in that order. When you call this method, target is not retained. 
- 
	
		– removeTarget:action:forControlEvents:Removes a target and action for a particular event (or events) from an internal dispatch table. 
Preparing Blocks
- 
	
		– setBlock:forControlEvents:Sets a block for a particular event (or events) to an internal dispatch table. 
Tracking Touches and Redrawing Controls
- 
	
		– isPointInside:Returns a boolean value that indicates whether a location is inside the bounds of the receiver. 
- 
	
		– touchLocation:Returns a point corresponding to the touh location converted into the control space coordinates. 
- 
	
		– isTouchInside:Returns a boolean value that indicates whether a touch is inside the bounds of the receiver. The given touch must be relative to the world. 
- 
	
		– eventLocation:Returns a point corresponding to the event location converted into the control space coordinates. 
- 
	
		– isMouseInside:Returns a boolean value that indicates whether a mouse is inside the bounds of the receiver. The given mouse event must be relative to the world. 
- 
	
		– needsLayoutUpdates the control layout using its current internal state. 
Properties
cascadeColorEnabled
Conforms to CCRGBAProtocol (v2.1) protocol.
@property (nonatomic, getter=isCascadeColorEnabled) BOOL cascadeColorEnabledDiscussion
Conforms to CCRGBAProtocol (v2.1) protocol.
Declared In
CCControl.hcascadeOpacityEnabled
Conforms to CCRGBAProtocol (v2.1) protocol.
@property (nonatomic, getter=isCascadeOpacityEnabled) BOOL cascadeOpacityEnabledDiscussion
Conforms to CCRGBAProtocol (v2.1) protocol.
Declared In
CCControl.hcolor
Conforms to CCRGBAProtocol protocol.
@property (nonatomic, readwrite) ccColor3B colorDiscussion
Conforms to CCRGBAProtocol protocol.
Declared In
CCControl.hdefaultTouchPriority
Changes the priority of the button. The lower the number, the higher the priority.
@property (nonatomic, assign) NSInteger defaultTouchPriorityDiscussion
Changes the priority of the button. The lower the number, the higher the priority.
Declared In
CCControl.hdisplayedColor
Conforms to CCRGBAProtocol (v2.1) protocol.
@property (nonatomic, readonly) ccColor3B displayedColorDiscussion
Conforms to CCRGBAProtocol (v2.1) protocol.
Declared In
CCControl.hdisplayedOpacity
Conforms to CCRGBAProtocol (v2.1) protocol.
@property (nonatomic, readonly) GLubyte displayedOpacityDiscussion
Conforms to CCRGBAProtocol (v2.1) protocol.
Declared In
CCControl.henabled
Tells whether the control is enabled.
@property (nonatomic, getter=isEnabled) BOOL enabledDiscussion
Tells whether the control is enabled.
Declared In
CCControl.hhasVisibleParents
True if all of the controls parents are visible
@property (nonatomic, readonly) BOOL hasVisibleParentsDiscussion
True if all of the controls parents are visible
Declared In
CCControl.hhighlighted
A Boolean value that determines whether the control is highlighted.
@property (nonatomic, getter=isHighlighted) BOOL highlightedDiscussion
A Boolean value that determines whether the control is highlighted.
Declared In
CCControl.hopacity
Conforms to CCRGBAProtocol protocol.
@property (nonatomic, readwrite) GLubyte opacityDiscussion
Conforms to CCRGBAProtocol protocol.
Declared In
CCControl.hopacityModifyRGB
Conforms to CCRGBAProtocol protocol.
@property (nonatomic, getter=doesOpacityModifyRGB) BOOL opacityModifyRGBDiscussion
Conforms to CCRGBAProtocol protocol.
Declared In
CCControl.hInstance Methods
addTarget:action:forControlEvents:
Adds a target and action for a particular event (or events) to an internal dispatch table. The action message may optionnaly include the sender and the event as parameters, in that order. When you call this method, target is not retained.
- (void)addTarget:(id)target action:(SEL)action forControlEvents:(CCControlEvent)controlEventsParameters
- target
- The target object—that is, the object to which the action message is sent. It cannot be nil. The target is not retained. 
- action
- A selector identifying an action message. It cannot be NULL. 
- controlEvents
- A bitmask specifying the control events for which the action message is sent. See “CCControlEvent” for bitmask constants. 
Discussion
Adds a target and action for a particular event (or events) to an internal dispatch table. The action message may optionnaly include the sender and the event as parameters, in that order. When you call this method, target is not retained.
Declared In
CCControl.heventLocation:
Returns a point corresponding to the event location converted into the control space coordinates.
- (CGPoint)eventLocation:(NSEvent *)eventParameters
- event
- An NSEvent object representing the event. 
Return Value
A point specifying the location of the event in the current control context.
Discussion
Returns a point corresponding to the event location converted into the control space coordinates.
Declared In
CCControl.hisMouseInside:
Returns a boolean value that indicates whether a mouse is inside the bounds of the receiver. The given mouse event must be relative to the world.
- (BOOL)isMouseInside:(NSEvent *)eventParameters
- event
- An NSEvent object representing the event. 
Return Value
YES whether a mouse event is inside the receiver’s rect.
Discussion
Returns a boolean value that indicates whether a mouse is inside the bounds of the receiver. The given mouse event must be relative to the world.
Declared In
CCControl.hisPointInside:
Returns a boolean value that indicates whether a location is inside the bounds of the receiver.
- (BOOL)isPointInside:(CGPoint)locationParameters
- location
- A CGPoint that represents a location. 
Return Value
YES whether a location is inside the receiver’s rect.
Discussion
Returns a boolean value that indicates whether a location is inside the bounds of the receiver.
Declared In
CCControl.hisTouchInside:
Returns a boolean value that indicates whether a touch is inside the bounds of the receiver. The given touch must be relative to the world.
- (BOOL)isTouchInside:(UITouch *)touchParameters
- touch
- A UITouch object that represents a touch. 
Return Value
YES whether a touch is inside the receiver’s rect.
Discussion
Returns a boolean value that indicates whether a touch is inside the bounds of the receiver. The given touch must be relative to the world.
Declared In
CCControl.hneedsLayout
Updates the control layout using its current internal state.
- (void)needsLayoutDiscussion
Updates the control layout using its current internal state.
Declared In
CCControl.hremoveTarget:action:forControlEvents:
Removes a target and action for a particular event (or events) from an internal dispatch table.
- (void)removeTarget:(id)target action:(SEL)action forControlEvents:(CCControlEvent)controlEventsParameters
- target
- The target object—that is, the object to which the action message is sent. Pass nil to remove all targets paired with action and the specified control events. 
- action
- A selector identifying an action message. Pass NULL to remove all action messages paired with target. 
- controlEvents
- A bitmask specifying the control events associated with target and action. See “CCControlEvent” for bitmask constants. 
Discussion
Removes a target and action for a particular event (or events) from an internal dispatch table.
Declared In
CCControl.hsendActionsForControlEvents:
Sends action messages for the given control events.
- (void)sendActionsForControlEvents:(CCControlEvent)controlEventsParameters
- controlEvents
- A bitmask whose set flags specify the control events for which action messages are sent. See “CCControlEvent” for bitmask constants. 
Discussion
Sends action messages for the given control events.
Declared In
CCControl.hsetBlock:forControlEvents:
Sets a block for a particular event (or events) to an internal dispatch table.
- (void)setBlock:(CCControlBlock)block forControlEvents:(CCControlEvent)controlEventsParameters
- block
- The block to which the action message is sent. If the block is nil, it removes the previous one. 
- controlEvents
- A bitmask specifying the control events for which the action message is sent. See “CCControlEvent” for bitmask constants. 
Discussion
Sets a block for a particular event (or events) to an internal dispatch table.
Declared In
CCControl.htouchLocation:
Returns a point corresponding to the touh location converted into the control space coordinates.
- (CGPoint)touchLocation:(UITouch *)touchParameters
- touch
- A UITouch object that represents a touch. 
Return Value
A point specifying the location of the touch in the current control context.
Discussion
Returns a point corresponding to the touh location converted into the control space coordinates.
Declared In
CCControl.h