2012-04-19 14:35:52 +08:00
/*
2012-09-25 17:26:09 +08:00
* Copyright ( c ) 2012 cocos2d - x . org
* http : //www.cocos2d-x.org
2012-04-19 14:35:52 +08:00
*
* Copyright 2011 Yannick Loriot .
* http : //yannickloriot.com
*
* Permission is hereby granted , free of charge , to any person obtaining a copy
* of this software and associated documentation files ( the " Software " ) , to deal
* in the Software without restriction , including without limitation the rights
* to use , copy , modify , merge , publish , distribute , sublicense , and / or sell
* copies of the Software , and to permit persons to whom the Software is
* furnished to do so , subject to the following conditions :
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
* IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT . IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM , DAMAGES OR OTHER
* LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR OTHERWISE , ARISING FROM ,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE .
*
* Converted to c + + / cocos2d - x by Angus C
*/
# ifndef __CCCONTROL_H__
# define __CCCONTROL_H__
# include "CCInvocation.h"
# include "CCControlUtils.h"
2012-09-25 16:57:51 +08:00
# include "cocos2d.h"
2012-04-19 14:35:52 +08:00
2012-04-27 18:47:49 +08:00
NS_CC_EXT_BEGIN
2012-04-19 14:35:52 +08:00
2013-06-20 14:15:53 +08:00
class Invocation ;
2012-04-19 14:35:52 +08:00
2012-06-20 18:09:11 +08:00
/**
* @ addtogroup GUI
* @ {
* @ addtogroup control_extension
* @ {
*/
2012-04-19 14:35:52 +08:00
/** Number of kinds of control event. */
2012-09-25 16:57:51 +08:00
# define kControlEventTotalNumber 9
2012-04-19 14:35:52 +08:00
/** Kinds of possible events for the control objects. */
enum
{
2013-06-20 14:15:53 +08:00
ControlEventTouchDown = 1 < < 0 , // A touch-down event in the control.
ControlEventTouchDragInside = 1 < < 1 , // An event where a finger is dragged inside the bounds of the control.
ControlEventTouchDragOutside = 1 < < 2 , // An event where a finger is dragged just outside the bounds of the control.
ControlEventTouchDragEnter = 1 < < 3 , // An event where a finger is dragged into the bounds of the control.
ControlEventTouchDragExit = 1 < < 4 , // An event where a finger is dragged from within a control to outside its bounds.
ControlEventTouchUpInside = 1 < < 5 , // A touch-up event in the control where the finger is inside the bounds of the control.
ControlEventTouchUpOutside = 1 < < 6 , // A touch-up event in the control where the finger is outside the bounds of the control.
ControlEventTouchCancel = 1 < < 7 , // A system event canceling the current touches for the control.
ControlEventValueChanged = 1 < < 8 // A touch dragging or otherwise manipulating a control, causing it to emit a series of different values.
2012-04-19 14:35:52 +08:00
} ;
2013-06-20 14:15:53 +08:00
typedef unsigned int ControlEvent ;
2012-04-19 14:35:52 +08:00
/** The possible state for a control. */
enum
{
2013-06-20 14:15:53 +08:00
ControlStateNormal = 1 < < 0 , // The normal, or default state of a control<6F> <6C> that is, enabled but neither selected nor highlighted.
ControlStateHighlighted = 1 < < 1 , // Highlighted state of a control. A control enters this state when a touch down, drag inside or drag enter is performed. You can retrieve and set this value through the highlighted property.
ControlStateDisabled = 1 < < 2 , // Disabled state of a control. This state indicates that the control is currently disabled. You can retrieve and set this value through the enabled property.
ControlStateSelected = 1 < < 3 // Selected state of a control. This state indicates that the control is currently selected. You can retrieve and set this value through the selected property.
2012-04-19 14:35:52 +08:00
} ;
2013-06-20 14:15:53 +08:00
typedef unsigned int ControlState ;
2012-04-19 14:35:52 +08:00
2012-09-25 17:26:09 +08:00
/*
* @ class
2013-06-20 14:15:53 +08:00
* Control is inspired by the UIControl API class from the UIKit library of
* CocoaTouch . It provides a base class for control Sprites such as Button
* or Slider that convey user intent to the application .
2012-09-25 17:26:09 +08:00
*
2013-06-20 14:15:53 +08:00
* The goal of Control is to define an interface and base implementation for
2012-09-25 17:26:09 +08:00
* preparing action messages and initially dispatching them to their targets when
* certain events occur .
*
2013-06-20 14:15:53 +08:00
* To use the Control you have to subclass it .
2012-04-19 14:35:52 +08:00
*/
2013-06-20 14:15:53 +08:00
class Control : public LayerRGBA
2012-04-19 14:35:52 +08:00
{
//CCRGBAProtocol
2013-06-15 14:03:30 +08:00
bool _isOpacityModifyRGB ;
2013-02-28 11:55:36 +08:00
2012-04-19 14:35:52 +08:00
/** The current control state constant. */
2013-06-20 14:15:53 +08:00
CC_SYNTHESIZE_READONLY ( ControlState , _state , State ) ;
2012-09-25 16:57:51 +08:00
2012-09-25 17:26:09 +08:00
/** True if all of the controls parents are visible */
protected :
2013-06-15 14:03:30 +08:00
bool _hasVisibleParents ;
2012-06-15 16:47:30 +08:00
public :
2012-04-19 14:35:52 +08:00
/** Tells whether the control is enabled. */
2012-06-15 16:47:30 +08:00
virtual void setEnabled ( bool bEnabled ) ;
virtual bool isEnabled ( ) ;
/** A Boolean value that determines the control selected state. */
virtual void setSelected ( bool bSelected ) ;
virtual bool isSelected ( ) ;
2012-04-19 14:35:52 +08:00
/** A Boolean value that determines whether the control is highlighted. */
2012-06-15 16:47:30 +08:00
virtual void setHighlighted ( bool bHighlighted ) ;
virtual bool isHighlighted ( ) ;
2012-09-25 16:57:51 +08:00
bool hasVisibleParents ( ) ;
2012-09-25 17:26:09 +08:00
/**
* Updates the control layout using its current internal state .
*/
2012-09-25 16:57:51 +08:00
virtual void needsLayout ( ) ;
2013-02-28 11:55:36 +08:00
2013-07-05 15:06:38 +08:00
virtual bool isOpacityModifyRGB ( ) const ;
2013-02-28 11:55:36 +08:00
virtual void setOpacityModifyRGB ( bool bOpacityModifyRGB ) ;
2012-06-15 16:47:30 +08:00
protected :
2013-06-15 14:03:30 +08:00
bool _enabled ;
bool _selected ;
bool _highlighted ;
2012-06-15 16:47:30 +08:00
2012-09-25 17:26:09 +08:00
/**
2013-06-20 14:15:53 +08:00
* Table of connection between the ControlEvents and their associated
* target - actions pairs . For each ButtonEvents a list of NSInvocation
2012-09-25 17:26:09 +08:00
* ( which contains the target - action pair ) is linked .
2012-09-25 16:57:51 +08:00
*/
2013-06-20 14:15:53 +08:00
Dictionary * _dispatchTable ;
2012-04-19 14:35:52 +08:00
public :
2013-06-20 14:15:53 +08:00
Control ( ) ;
2012-04-19 14:35:52 +08:00
virtual bool init ( void ) ;
2013-06-20 14:15:53 +08:00
virtual ~ Control ( ) ;
2012-04-19 14:35:52 +08:00
virtual void onEnter ( ) ;
virtual void onExit ( ) ;
virtual void registerWithTouchDispatcher ( ) ;
/**
* Sends action messages for the given control events .
*
* @ param controlEvents A bitmask whose set flags specify the control events for
* which action messages are sent . See " CCControlEvent " for bitmask constants .
*/
2013-06-20 14:15:53 +08:00
virtual void sendActionsForControlEvents ( ControlEvent controlEvents ) ;
2012-04-19 14:35:52 +08:00
/**
* 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 .
*
2012-09-25 16:57:51 +08:00
* @ param target The target object that is , the object to which the action
2012-04-19 14:35:52 +08:00
* message is sent . It cannot be nil . The target is not retained .
* @ param action A selector identifying an action message . It cannot be NULL .
* @ param controlEvents A bitmask specifying the control events for which the
* action message is sent . See " CCControlEvent " for bitmask constants .
*/
2013-06-20 14:15:53 +08:00
virtual void addTargetWithActionForControlEvents ( Object * target , SEL_CCControlHandler action , ControlEvent controlEvents ) ;
2012-04-19 14:35:52 +08:00
/**
* Removes a target and action for a particular event ( or events ) from an
* internal dispatch table .
*
* @ param target The target object <EFBFBD> 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 .
* @ param action A selector identifying an action message . Pass NULL to remove
* all action messages paired with target .
* @ param controlEvents A bitmask specifying the control events associated with
* target and action . See " CCControlEvent " for bitmask constants .
*/
2013-06-20 14:15:53 +08:00
virtual void removeTargetWithActionForControlEvents ( Object * target , SEL_CCControlHandler action , ControlEvent controlEvents ) ;
2012-04-19 14:35:52 +08:00
/**
* Returns a point corresponding to the touh location converted into the
* control space coordinates .
2013-06-20 14:15:53 +08:00
* @ param touch A Touch object that represents a touch .
2012-04-19 14:35:52 +08:00
*/
2013-06-20 14:15:53 +08:00
virtual Point getTouchLocation ( Touch * touch ) ;
2012-04-19 14:35:52 +08:00
2012-09-25 17:26:09 +08:00
2012-04-19 14:35:52 +08:00
/**
* 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 .
*
2013-06-20 14:15:53 +08:00
* @ param touch A Touch object that represents a touch .
2012-04-19 14:35:52 +08:00
*
2012-09-25 16:57:51 +08:00
* @ return YES whether a touch is inside the receiver <EFBFBD> <EFBFBD> s rect .
2012-04-19 14:35:52 +08:00
*/
2013-06-20 14:15:53 +08:00
virtual bool isTouchInside ( Touch * touch ) ;
2012-04-19 14:35:52 +08:00
protected :
/**
2013-06-20 14:15:53 +08:00
* Returns an Invocation object able to construct messages using a given
2012-09-25 16:57:51 +08:00
* target - action pair . ( The invocation may optionnaly include the sender and
* the event as parameters , in that order )
*
* @ param target The target object .
* @ param action A selector identifying an action message .
* @ param controlEvent A control events for which the action message is sent .
* See " CCControlEvent " for constants .
*
2013-06-20 14:15:53 +08:00
* @ return an Invocation object able to construct messages using a given
2012-09-25 16:57:51 +08:00
* target - action pair .
*/
2013-06-20 14:15:53 +08:00
Invocation * invocationWithTargetAndActionForControlEvent ( Object * target , SEL_CCControlHandler action , ControlEvent controlEvent ) ;
2012-04-19 14:35:52 +08:00
/**
2013-06-20 14:15:53 +08:00
* Returns the Invocation list for the given control event . If the list does
2012-04-19 14:35:52 +08:00
* not exist , it ' ll create an empty array before returning it .
*
* @ param controlEvent A control events for which the action message is sent .
* See " CCControlEvent " for constants .
*
2013-06-20 14:15:53 +08:00
* @ return the Invocation list for the given control event .
2012-04-19 14:35:52 +08:00
*/
2013-06-20 14:15:53 +08:00
//<Invocation*>
Array * dispatchListforControlEvent ( ControlEvent controlEvent ) ;
2012-09-25 17:26:09 +08:00
/**
* Adds a target and action for a particular event 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 .
*
* @ param target The target object <EFBFBD> <EFBFBD> that is , the object to which the action
* message is sent . It cannot be nil . The target is not retained .
* @ param action A selector identifying an action message . It cannot be NULL .
* @ param controlEvent A control event for which the action message is sent .
* See " CCControlEvent " for constants .
2012-09-25 16:57:51 +08:00
*/
2013-06-20 14:15:53 +08:00
void addTargetWithActionForControlEvent ( Object * target , SEL_CCControlHandler action , ControlEvent controlEvent ) ;
2012-09-25 16:57:51 +08:00
2012-09-25 17:26:09 +08:00
/**
* Removes a target and action for a particular event from an internal dispatch
* table .
*
* @ param target The target object <EFBFBD> <EFBFBD> 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 .
* @ param action A selector identifying an action message . Pass NULL to remove
* all action messages paired with target .
* @ param controlEvent A control event for which the action message is sent .
* See " CCControlEvent " for constants .
2012-09-25 16:57:51 +08:00
*/
2013-06-20 14:15:53 +08:00
void removeTargetWithActionForControlEvent ( Object * target , SEL_CCControlHandler action , ControlEvent controlEvent ) ;
2012-04-19 14:35:52 +08:00
2013-06-20 14:15:53 +08:00
static Control * create ( ) ;
2013-05-24 11:42:27 +08:00
public :
2013-06-20 14:15:53 +08:00
void addHandleOfControlEvent ( int nFunID , ControlEvent controlEvent ) ;
void removeHandleOfControlEvent ( ControlEvent controlEvent ) ;
2013-05-24 11:42:27 +08:00
private :
2013-06-20 14:15:53 +08:00
int getHandleOfControlEvent ( ControlEvent controlEvent ) ;
2013-05-24 11:42:27 +08:00
private :
2013-06-15 14:03:30 +08:00
std : : map < int , int > _mapHandleOfControlEvent ;
2012-04-19 14:35:52 +08:00
} ;
2012-06-20 18:09:11 +08:00
// end of GUI group
/// @}
/// @}
2012-04-27 18:47:49 +08:00
NS_CC_EXT_END
2012-04-19 14:35:52 +08:00
2012-04-16 18:58:43 +08:00
# endif