forked from cocos2d/cocos2d-objc
-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathCCControlSubclass.h
165 lines (140 loc) · 6.45 KB
/
CCControlSubclass.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
/*
* Cocos2D-SpriteBuilder: http://cocos2d.spritebuilder.com
*
* Copyright (c) 2013 Apportable Inc.
*
* 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.
*/
#import "CCControl.h"
/** Methods Used by Sub-Classes */
@interface CCControl (Implemented_by_Subclasses)
/** @name Controls */
/**
* Can be implemented by sub-classes. This method is called to trigger an action callback. E.g. CCButton calls this method when the button is tapped.
*/
- (void) triggerAction;
/**
* Can be implemented by sub-classes. This method is called every time the control's state changes, it's default behavior is to call the needsLayout method.
*/
- (void) stateChanged;
/**
* Can be implemented by sub-classes. This method should be called whenever the control needs to update its layout.
It will force a call to the layout method at the beginning of the next draw cycle.
*/
- (void) needsLayout;
/**
* Can be implemented by sub classes. Override this method to do any layout needed by the component.
This can include setting positions or sizes of child labels or sprites as well as the compontents contentSize.
*/
- (void) layout;
/** @name KVC */
/**
Can be implemented by sub-classes. Override this method if you are using custom properties and need to set them by name using the setValue:forKey method.
This is needed for integration with editors such as SpriteBuilder. When overriding this method, make sure to call its super method if you cannot handle the key.
@param value The value to set.
@param key The key to set the value for.
@param state The state to set the value for.
@see CCControlState
@see valueForKey:state:
*/
- (void) setValue:(id)value forKey:(NSString *)key state:(CCControlState) state;
/**
* Can be implemented by sub-classes. Override this method to return values of custom properties that are set by state.
*
* @param key The key to retrieve the value for.
* @param state The state to retrieve the value for.
*
* @return The value for the specified key and value or `NULL` if no such value exist.
* @see setValue:forKey:state:
*/
- (id) valueForKey:(NSString *)key state:(CCControlState)state;
/** @name Input Event Handling */
#if __CC_PLATFORM_IOS
/**
Can be implemented by sub-classes. Called when a touch enters the component. By default this happes if the touch down is within the control,
if the claimsUserEvents property is set to false this will also happen if the touch starts outside of the control.
@param touch Touch that entered the component.
@param event Event associated with the touch.
@see CCTouch
@see CCTouchEvent
*/
- (void) touchEntered:(CCTouch*) touch withEvent:(CCTouchEvent*)event;
/**
* Can be implemented by sub-classes. Called when a touch exits the component.
*
* @param touch Touch that exited the component
* @param event Event associated with the touch.
* @see CCTouch
* @see CCTouchEvent
*/
- (void) touchExited:(CCTouch*) touch withEvent:(CCTouchEvent*) event;
/**
* Can be implemented by sub-classes. Called when a touch that started inside the component is ended inside the component.
* E.g. for CCButton, this triggers the buttons callback action.
*
* @param touch Touch that is released inside the component.
* @param event Event associated with the touch.
* @see CCTouch
* @see CCTouchEvent
*/
- (void) touchUpInside:(CCTouch*) touch withEvent:(CCTouchEvent*) event;
/**
* Can be implemented by sub-classes. Called when a touch that started inside the component is ended outside the component.
* E.g. for CCButton, this doesn't trigger any callback action.
*
* @param touch Touch that is release outside of the component.
* @param event Event associated with the touch.
* @see CCTouch
* @see CCTouchEvent
*/
- (void) touchUpOutside:(CCTouch*) touch withEvent:(CCTouchEvent*) event;
#elif __CC_PLATFORM_MAC
/**
* Can be implemented by sub-classes. Called when a mouse down enters the component. By default this happes if the mouse down
* is within the control, if the claimsUserEvents property is set to false this will also happen if the mouse down starts outside of the control.
*
* @param event Event associated with the mouse down.
* @see [NSEvent](https://developer.apple.com/library/mac/documentation/Cocoa/Reference/ApplicationKit/Classes/NSEvent_Class/)
*/
- (void) mouseDownEntered:(NSEvent*) event;
/**
* Can be implemented by sub-classes. Called when a mouse down exits the component.
*
* @param event Event associated with the mouse down.
* @see [NSEvent](https://developer.apple.com/library/mac/documentation/Cocoa/Reference/ApplicationKit/Classes/NSEvent_Class/)
*/
- (void) mouseDownExited:(NSEvent*) event;
/**
* Can be implemented by sub-classes. Called when a mouse down that started inside the component is ended inside the component.
* E.g. for CCButton, this triggers the buttons callback action.
*
* @param event Event associated with the mouse up.
* @see [NSEvent](https://developer.apple.com/library/mac/documentation/Cocoa/Reference/ApplicationKit/Classes/NSEvent_Class/)
*/
- (void) mouseUpInside:(NSEvent*) event;
/**
* Can be implemented by sub-classes. Called when a mouse down that started inside the component is ended outside the component.
* E.g. for CCButton, this doesn't trigger any callback action.
*
* @param event Event associated with the mouse up.
* @see [NSEvent](https://developer.apple.com/library/mac/documentation/Cocoa/Reference/ApplicationKit/Classes/NSEvent_Class/)
*/
- (void) mouseUpOutside:(NSEvent*) event;
#endif
@end