cocod2d-x 之 CCDirector、CCScene、CCSprite

  CCDirector是控制遊戲流程的主要組件。javascript

  

  1 typedef enum {
  2     /// sets a 2D projection (orthogonal projection)2D投機模式
  3     kCCDirectorProjection2D,
  4     
  5     /// sets a 3D projection with a fovy=60, znear=0.5f and zfar=1500.3D投影
  6     kCCDirectorProjection3D,
  7     
  8     /// it calls "updateProjection" on the projection delegate.
  9     kCCDirectorProjectionCustom,
 10     
 11     /// Default projection is 3D projection
 12     kCCDirectorProjectionDefault = kCCDirectorProjection3D,
 13 } ccDirectorProjection;
 14 
 15 class CC_DLL CCDirector : public CCObject, public TypeInfo
 16 {
 17 public:
 18     
 19     CCDirector(void);
 20     virtual ~CCDirector(void);
 21     virtual bool init(void);
 22     virtual long getClassTypeInfo() {
 23         static const long id = cocos2d::getHashCodeByString(typeid(cocos2d::CCDirector).name());
 24         return id;
 25     }
 26 
 27     //獲取當前運行的Scene
 28     inline CCScene* getRunningScene(void) { return m_pRunningScene; }
 29 
 30     /** Get the FPS value *///獲取動畫繪製間隔
 31     inline double getAnimationInterval(void) { return m_dAnimationInterval; }
 32     /** Set the FPS value. *///設置動畫間隔
 33     virtual void setAnimationInterval(double dValue) = 0;
 34 
 35     /** Whether or not to display the FPS on the bottom-left corner *///是否顯示狀態fps、繪製間隔等
 36     inline bool isDisplayStats(void) { return m_bDisplayStats; }
 37     /** Display the FPS on the bottom-left corner */
 38     inline void setDisplayStats(bool bDisplayStats) { m_bDisplayStats = bDisplayStats; }
 39     
 40     /** seconds per frame *///每秒鐘繪製多少幀
 41     inline float getSecondsPerFrame() { return m_fSecondsPerFrame; }
 42 
 43     /** Get the CCEGLView, where everything is rendered
 44      * @js NA
 45      */
 46     inline CCEGLView* getOpenGLView(void) { return m_pobOpenGLView; }
 47     void setOpenGLView(CCEGLView *pobOpenGLView);
 48 
 49     inline bool isNextDeltaTimeZero(void) { return m_bNextDeltaTimeZero; }
 50     void setNextDeltaTimeZero(bool bNextDeltaTimeZero);
 51 
 52     /** Whether or not the Director is paused *///是否暫停
 53     inline bool isPaused(void) { return m_bPaused; }
 54 
 55     /** How many frames were called since the director started *///共繪製了多少幀
 56     inline unsigned int getTotalFrames(void) { return m_uTotalFrames; }
 57     
 58     /** Sets an OpenGL projection
 59      @since v0.8.2
 60      @js NA
 61      */
 62     inline ccDirectorProjection getProjection(void) { return m_eProjection; }
 63     void setProjection(ccDirectorProjection kProjection);
 64      /** reshape projection matrix when canvas has been change"*/畫布改變後,重塑投影矩陣
 65     void reshapeProjection(const CCSize& newWindowSize);
 66     
 67     /** Sets the glViewport*/
 68     void setViewport();
 69 
 70     /** How many frames were called since the director started */
 71     inline bool isSendCleanupToScene(void) { return m_bSendCleanupToScene; }
 72 
 73     CCNode* getNotificationNode();
 74     void setNotificationNode(CCNode *node);
 75     
 76     /** CCDirector delegate. It shall implemente the CCDirectorDelegate protocol
 77      */
 78     CCDirectorDelegate* getDelegate() const;
 79     void setDelegate(CCDirectorDelegate* pDelegate);
 80 
 81     // window size,設計分辨率
 82     /** returns the size of the OpenGL view in points.
 83     */
 84     CCSize getWinSize(void);
 85 
 86     /** returns the size of the OpenGL view in pixels.
 87     */
 88     CCSize getWinSizeInPixels(void);
 89     
 90     /** returns visible size of the OpenGL view in points.
 91      *  the value is equal to getWinSize if don't invoke
 92      *  CCEGLView::setDesignResolutionSize()
 93      *///openGL的可視區大小,是在 WinSize 以內,保持 FrameSize 的寬高比所能佔用的最大區域​
 94     CCSize getVisibleSize();
 95     
 96     /** returns visible origin of the OpenGL view in points.
 97      */
 98     CCPoint getVisibleOrigin();
 99 
100     /** converts a UIKit coordinate to an OpenGL coordinate
101      Useful to convert (multi) touch coordinates to the current layout (portrait or landscape)
102      *///將一個點座標從UI座標(坐上角爲原點)轉換爲openGL座標(左下角爲座標),主要用於在點擊事件中將點擊座標轉換爲屏幕座標
103     CCPoint convertToGL(const CCPoint& obPoint);
104 
105     /** converts an OpenGL coordinate to a UIKit coordinate
106      Useful to convert node points to window points for calls such as glScissor
107      *///將一個點轉換爲UI座標的點
108     CCPoint convertToUI(const CCPoint& obPoint);
109 
110     /// XXX: missing description 
111     float getZEye(void);
112 
113     // Scene Management
114 
115     /** Enters the Director's main loop with the given Scene.
116      * Call it to run only your FIRST scene.
117      * Don't call it if there is already a running scene.
118      *
119      * It will call pushScene: and then it will call startAnimation
120      *///加載場景並運行,遊戲開始時調用
121     void runWithScene(CCScene *pScene);
122 
123     /** Suspends the execution of the running scene, pushing it on the stack of suspended scenes.
124      * The new scene will be executed.
125      * Try to avoid big stacks of pushed scenes to reduce memory allocation. 
126      * ONLY call it if there is a running scene.
127      */
128     void pushScene(CCScene *pScene);
129 
130     /** Pops out a scene from the queue.
131      * This scene will replace the running one.
132      * The running scene will be deleted. If there are no more scenes in the stack the execution is terminated.
133      * ONLY call it if there is a running scene.
134      */
135     void popScene(void);
136 
137     /** Pops out all scenes from the queue until the root scene in the queue.
138      * This scene will replace the running one.
139      * Internally it will call `popToSceneStackLevel(1)`
140      */
141     void popToRootScene(void);
142 
143     /** Pops out all scenes from the queue until it reaches `level`.
144      If level is 0, it will end the director.
145      If level is 1, it will pop all scenes until it reaches to root scene.
146      If level is <= than the current stack level, it won't do anything.
147      */
148      void popToSceneStackLevel(int level);
149 
150     /** Replaces the running scene with a new one. The running scene is terminated.
151      * ONLY call it if there is a running scene.
152      */
153     void replaceScene(CCScene *pScene);
154 
155     /** Ends the execution, releases the running scene.
156      It doesn't remove the OpenGL view from its parent. You have to do it manually.
157      *///遊戲結束,釋放場景,但未移除openGL view
158     void end(void);
159 
160     /** Pauses the running scene.
161      The running scene will be _drawed_ but all scheduled timers will be paused
162      While paused, the draw rate will be 4 FPS to reduce CPU consumption
163      *///遊戲暫停
164     void pause(void);
165 
166     /** Resumes the paused scene
167      The scheduled timers will be activated again.
168      The "delta time" will be 0 (as if the game wasn't paused)
169      *///遊戲恢復
170     void resume(void);
171 
172     /** Stops the animation. Nothing will be drawn. The main loop won't be triggered anymore.
173      If you don't want to pause your animation call [pause] instead.
174      *///中止動畫
175     virtual void stopAnimation(void) = 0;
176 
177     /** The main loop is triggered again.
178      Call this function only if [stopAnimation] was called earlier
179      @warning Don't call this function to start the main loop. To run the main loop call runWithScene
180      *///開始動畫
181     virtual void startAnimation(void) = 0;
182 
183     /** Draw the scene.
184     This method is called every frame. Don't call it manually.
185     */
186     void drawScene(void);
187 
188     // Memory Helper
189 
190     /** Removes cached all cocos2d cached data.
191      It will purge the CCTextureCache, CCSpriteFrameCache, CCLabelBMFont cache
192      @since v0.99.3
193      *///清楚緩存數據,包括紋理、精靈、Label等
194     void purgeCachedData(void);
195 
196     /** sets the default values based on the CCConfiguration info */
197     void setDefaultValues(void);
198 
199     // OpenGL Helper
200 
201     /** sets the OpenGL default values */
202     void setGLDefaultValues(void);
203 
204     /** enables/disables OpenGL alpha blending */
205     void setAlphaBlending(bool bOn);
206 
207     /** enables/disables OpenGL depth test */
208     void setDepthTest(bool bOn);
209 
210     virtual void mainLoop(void) = 0;
211 
212     /** The size in pixels of the surface. It could be different than the screen size.
213     High-res devices might have a higher surface size than the screen size.
214     Only available when compiled using SDK >= 4.0.
215     @since v0.99.4
216     *///設置縮放參數
217     void setContentScaleFactor(float scaleFactor);
218     float getContentScaleFactor(void);
219 
220 public:
221     /** CCScheduler associated with this director
222      @since v2.0
223      *///聲明成員屬性
224     CC_PROPERTY(CCScheduler*, m_pScheduler, Scheduler);
225 
226     /** CCActionManager associated with this director
227      @since v2.0
228      */
229     CC_PROPERTY(CCActionManager*, m_pActionManager, ActionManager);
230 
231     /** CCTouchDispatcher associated with this director
232      @since v2.0
233      */
234     CC_PROPERTY(CCTouchDispatcher*, m_pTouchDispatcher, TouchDispatcher);
235 
236     /** CCKeypadDispatcher associated with this director
237      @since v2.0
238      */
239     CC_PROPERTY(CCKeypadDispatcher*, m_pKeypadDispatcher, KeypadDispatcher);
240 
241     /** CCAccelerometer associated with this director
242      @since v2.0
243      @js NA
244      @lua NA
245      */
246     CC_PROPERTY(CCAccelerometer*, m_pAccelerometer, Accelerometer);
247 
248     /* delta time since last tick to main loop */
249     CC_PROPERTY_READONLY(float, m_fDeltaTime, DeltaTime);
250     
251 public:
252     /** returns a shared instance of the director 
253      *  @js getInstance
254      */
255     static CCDirector* sharedDirector(void);
256 
257 protected:
258 
259     void purgeDirector();//清空director
260     bool m_bPurgeDirecotorInNextLoop; // this flag will be set to true in end()
261     
262     void setNextScene(void);
263     
264     void showStats();
265     void createStatsLabel();
266     void calculateMPF();
267     void getFPSImageData(unsigned char** datapointer, unsigned int* length);
268     
269     /** calculates delta time since last time it was called */    
270     void calculateDeltaTime();
271 protected:
272     /* The CCEGLView, where everything is rendered */
273     CCEGLView    *m_pobOpenGLView;
274 
275     double m_dAnimationInterval;
276     double m_dOldAnimationInterval;
277 
278     /* landscape mode ? */
279     bool m_bLandscape;
280     
281     bool m_bDisplayStats;
282     float m_fAccumDt;
283     float m_fFrameRate;
284     
285     CCLabelAtlas *m_pFPSLabel;
286     CCLabelAtlas *m_pSPFLabel;
287     CCLabelAtlas *m_pDrawsLabel;
288     
289     /** Whether or not the Director is paused */
290     bool m_bPaused;//是否暫停
291 
292     /* How many frames were called since the director started */
293     /* 開始運行後共渲染了多少幀 */
294     unsigned int m_uTotalFrames;
295     unsigned int m_uFrames;
296     float m_fSecondsPerFrame;//每秒的幀率
297      
298     /* The running scene */
299     CCScene *m_pRunningScene;//當前場景
300     
301     /* will be the next 'runningScene' in the next frame
302      nextScene is a weak reference. */
303     CCScene *m_pNextScene;//下一個場景
304     
305     /* If YES, then "old" scene will receive the cleanup message */
306     bool    m_bSendCleanupToScene;//是否清空前一個場景
307 
308     /* scheduled scenes */
309     CCArray* m_pobScenesStack;//scene場景列表
310     
311     /* last time the main loop was updated */
312     struct cc_timeval *m_pLastUpdate;//遊戲主循環上一次刷新的時間
313 
314     /* whether or not the next delta time will be zero */
315     bool m_bNextDeltaTimeZero;
316     
317     /* projection used */
318     ccDirectorProjection m_eProjection;
319 
320     /* window size in points */
321     CCSize    m_obWinSizeInPoints;//窗口大小
322     
323     /* content scale factor */
324     float    m_fContentScaleFactor;//縮放
325 
326     /* store the fps string */
327     char *m_pszFPS;
328 
329     /* This object will be visited after the scene. Useful to hook a notification node */
330     CCNode *m_pNotificationNode;
331 
332     /* Projection protocol delegate */
333     CCDirectorDelegate *m_pProjectionDelegate;//代理
334     
335     // CCEGLViewProtocol will recreate stats labels to fit visible rect//根據模式重繪畫面,用於適配各類屏幕分辨率
336     friend class CCEGLViewProtocol;
337 };
338 
339 CCDirector.h

 

  CCDirector經常使用方法java

  CCDirector *pDirector = CCDirector::sharedDirector() //獲取CCDirectornode

  runWithScene(CCScene* scene) //啓動遊戲並運行scenec++

  replaceScene(CCScene* scene) //使用傳入的scene替換當前場景來切換畫面,當前場景將被釋放canvas

  pushScene(CCScene* scene) //將當前運行中的場景暫停並壓入到代執行場景棧中,再將傳入的scene設置爲當前運行場景windows

  popScene() //釋放當前場景,再從代執行場景棧中彈出棧頂的場景,並將其設置爲當前運行場景。若是棧爲空,則直接結束應用緩存

  pause() //暫停當前運行場景中的全部計時器和動做,場景仍然會顯示在屏幕上app

  resume() //恢復當前運行場景中被暫停的計時器和動做。它與pause配合使用
  end() //結束場景,同時退出應用less

  以上三種切換場景的方法(replaceScene、pushScene、popScene)均是先將待切換的場景徹底加載完畢後,纔將當前運行的場景釋放掉。因此,在新場景剛好徹底加載完畢的瞬間,系統中同時存在着兩個場景,這將是對內存的一個考驗,若不注意的話,切換場景可能會形成內存不足ide

  

  CCScene定義了一個場景。場景只是層的容器,包含了全部須要顯示的遊戲元素

  CCLayer定義了一個層。與CCScene相似,層也扮演着容器的角色。然而與場景不一樣的是,層一般包含的是直接呈如今屏幕上的具體內容.

  

 1 //cocos2d-x-2.2/cocos2dx/layers_scenes_transitions_nodes/CCLayer.h
 2 
 3  class CC_DLL CCLayer : public CCNode, public CCTouchDelegate, public CCAccelerometerDelegate, public CCKeypadDelegate
 4 {
 5 public:
 6     CCLayer();
 7     virtual ~CCLayer();
 8     virtual bool init();
 9     static CCLayer *create(void);
10     virtual void onEnter();
11     virtual void onExit();
12     virtual void onEnterTransitionDidFinish();
13     
14     // 觸摸事件處理函數
15     virtual bool ccTouchBegan(CCTouch *pTouch, CCEvent *pEvent);
16     virtual void ccTouchMoved(CCTouch *pTouch, CCEvent *pEvent);
17     virtual void ccTouchEnded(CCTouch *pTouch, CCEvent *pEvent);
18     virtual void ccTouchCancelled(CCTouch *pTouch, CCEvent *pEvent);
19 
20     // 多點觸摸
21     virtual void ccTouchesBegan(CCSet *pTouches, CCEvent *pEvent);
22     virtual void ccTouchesMoved(CCSet *pTouches, CCEvent *pEvent);
23     virtual void ccTouchesEnded(CCSet *pTouches, CCEvent *pEvent);
24     virtual void ccTouchesCancelled(CCSet *pTouches, CCEvent *pEvent);
25  
26     virtual void didAccelerate(CCAcceleration* pAccelerationValue);
27     void registerScriptAccelerateHandler(int nHandler);
28     void unregisterScriptAccelerateHandler(void);
29 
30     virtual void registerWithTouchDispatcher(void);
31     
32     /** Register script touch events handler */
33     //註冊觸摸事件
34     virtual void registerScriptTouchHandler(int nHandler, bool bIsMultiTouches = false, int nPriority = INT_MIN, bool bSwallowsTouches = false);
35     /** Unregister script touch events handler */
36     virtual void unregisterScriptTouchHandler(void);
37 
38     /** 是否處理觸摸事件
39     */
40     virtual bool isTouchEnabled();
41     virtual void setTouchEnabled(bool value);
42     
43     virtual void setTouchMode(ccTouchesMode mode);
44     virtual int getTouchMode();
45     
46     /** priority of the touch events. Default is 0 */
47     virtual void setTouchPriority(int priority);
48     virtual int getTouchPriority();
49 
50     /** whether or not it will receive Accelerometer events
51     You can enable / disable accelerometer events with this property.
52     @since v0.8.1
53     */
54     virtual bool isAccelerometerEnabled();
55     virtual void setAccelerometerEnabled(bool value);
56     virtual void setAccelerometerInterval(double interval);
57 
58     /** whether or not it will receive keypad events
59     You can enable / disable accelerometer events with this property.
60     it's new in cocos2d-x
61     */
62     virtual bool isKeypadEnabled();
63     virtual void setKeypadEnabled(bool value);
64 
65     /** Register keypad events handler */
66     void registerScriptKeypadHandler(int nHandler);
67     /** Unregister keypad events handler */
68     void unregisterScriptKeypadHandler(void);
69 
70     virtual void keyBackClicked(void);
71     virtual void keyMenuClicked(void);
72     
73     inline CCTouchScriptHandlerEntry* getScriptTouchHandlerEntry() { return m_pScriptTouchHandlerEntry; };
74     inline CCScriptHandlerEntry* getScriptKeypadHandlerEntry() { return m_pScriptKeypadHandlerEntry; };
75     inline CCScriptHandlerEntry* getScriptAccelerateHandlerEntry() { return m_pScriptAccelerateHandlerEntry; };
76 protected:   
77     bool m_bTouchEnabled;
78     bool m_bAccelerometerEnabled;
79     bool m_bKeypadEnabled;
80     
81 private:
82     // Script touch events handler
83     CCTouchScriptHandlerEntry* m_pScriptTouchHandlerEntry;
84     CCScriptHandlerEntry* m_pScriptKeypadHandlerEntry;
85     CCScriptHandlerEntry* m_pScriptAccelerateHandlerEntry;
86     
87     int m_nTouchPriority;
88     ccTouchesMode m_eTouchMode;
89     
90     int  excuteScriptTouchHandler(int nEventType, CCTouch *pTouch);
91     int  excuteScriptTouchHandler(int nEventType, CCSet *pTouches);
92 };

 

  向場景中添加層,咱們可使用addChild方法。

  void addChild(CCNode* child);

  void addChild(CCNode* child, int zOrder);
  void addChild(CCNode* child, int zOrder, int tag);
  其中child參數爲將要添加的節點。對於場景而言,一般咱們添加的節點就是層。先添加的層會被置於後添加的層之下。若是想要爲它們指定前後次序,可使用不一樣的zOrder值,zOrder表明了該節點下元素的前後次序,值越大則顯示順序越靠上。zOrder的默認值爲0。tag是元素的標識號碼,若是爲子節點設置了tag值,就能夠在它的父節點中利用tag值找到它了。這裏咱們能夠選擇本身須要的方法來向場景中添加層。

  

  CCSprite是CCNode的一個最重要也最靈活的子類。說它重要是由於CCSprite表明了遊戲中一個最小的可見單位,說它靈活則是因爲其裝載了一個平面紋理,具備豐富的表現力,並且能夠經過多種方式加載。若是說CCScene和CCLayer表明了宏觀的遊戲元素管理,那麼CCSprite則爲微觀世界提供了豐富靈活的細節表現。

  建立精靈

  CCSprite* fish = CCSprite::create("fish.png");

  這個工廠方法包含一個字符串參數,表示精靈所用紋理的文件名。CCSprite會自動把圖片做爲紋理載入到遊戲中,而後使用紋理初始化精靈。

  CCSprite* smallFish = CCSprite::create("fishes.png", CCRectMake(0, 0, 100, 100));

  僅顯示紋理的一部分。

  向層中添加精靈

  this->addChild(fish);

  

  初始化方法

  static CCSprite* create(const char *pszFileName);

  static CCSprite* create(const char *pszFileName, const CCRect& rect);

  bool initWithFile(const char *pszFilename);

   bool initWithFile(const char *pszFilename, const CCRect& rect);

  使用CCTexture2D紋理建立精靈

   static CCSprite* create(CCTexture2D *pTexture);

  static CCSprite* create(CCTexture2D *pTexture, const CCRect& rect);
  bool initWithTexture(CCTexture2D *pTexture);
  bool initWithTexture(CCTexture2D *pTexture, const CCRect& rect);

  使用CCSpriteFrame精靈框幀建立精靈

  static CCSprite* create(CCSpriteFrame *pSpriteFrame);

  bool initWithSpriteFrame(CCSpriteFrame *pSpriteFrame);

  1 //cocos2d-x-2.2/cocos2dx/sprite_nodes/CCSprite.h
  2 class CC_DLL CCSprite : public CCNodeRGBA, public CCTextureProtocol
  3 #ifdef EMSCRIPTEN
  4 , public CCGLBufferedNode
  5 #endif // EMSCRIPTEN
  6 {
  7 public:
  8     /// @{
  9     /// @name Creators
 10     
 11     /**
 12      * Creates an empty sprite without texture. You can call setTexture method subsequently.
 13      *
 14      * @return An empty sprite object that is marked as autoreleased.
 15      */
 16     static CCSprite* create();
 17     
 18     /**
 19      * Creates a sprite with an image filename.
 20      *
 21      * After creation, the rect of sprite will be the size of the image,
 22      * and the offset will be (0,0).
 23      *
 24      * @param   pszFileName The string which indicates a path to image file, e.g., "scene1/monster.png".
 25      * @return  A valid sprite object that is marked as autoreleased.
 26      */
 27     static CCSprite* create(const char *pszFileName);
 28     
 29     /**
 30      * Creates a sprite with an image filename and a rect.
 31      *
 32      * @param   pszFileName The string wich indicates a path to image file, e.g., "scene1/monster.png"
 33      * @param   rect        Only the contents inside rect of pszFileName's texture will be applied for this sprite.
 34      * @return  A valid sprite object that is marked as autoreleased.
 35      */
 36     static CCSprite* create(const char *pszFileName, const CCRect& rect);
 37     
 38     /**
 39      * Creates a sprite with an exsiting texture contained in a CCTexture2D object
 40      * After creation, the rect will be the size of the texture, and the offset will be (0,0).
 41      *
 42      * @param   pTexture    A pointer to a CCTexture2D object.
 43      * @return  A valid sprite object that is marked as autoreleased.
 44      */
 45     static CCSprite* createWithTexture(CCTexture2D *pTexture);
 46     
 47     /**
 48      * Creates a sprite with a texture and a rect.
 49      *
 50      * After creation, the offset will be (0,0).
 51      *
 52      * @param   pTexture    A pointer to an existing CCTexture2D object.
 53      *                      You can use a CCTexture2D object for many sprites.
 54      * @param   rect        Only the contents inside the rect of this texture will be applied for this sprite.
 55      * @return  A valid sprite object that is marked as autoreleased.
 56      */
 57     static CCSprite* createWithTexture(CCTexture2D *pTexture, const CCRect& rect);
 58     
 59     /**
 60      * Creates a sprite with an sprite frame.
 61      *
 62      * @param   pSpriteFrame    A sprite frame which involves a texture and a rect
 63      * @return  A valid sprite object that is marked as autoreleased.
 64      */
 65     static CCSprite* createWithSpriteFrame(CCSpriteFrame *pSpriteFrame);
 66     
 67     /**
 68      * Creates a sprite with an sprite frame name.
 69      *
 70      * A CCSpriteFrame will be fetched from the CCSpriteFrameCache by pszSpriteFrameName param.
 71      * If the CCSpriteFrame doesn't exist it will raise an exception.
 72      *
 73      * @param   pszSpriteFrameName A null terminated string which indicates the sprite frame name.
 74      * @return  A valid sprite object that is marked as autoreleased.
 75      */
 76     static CCSprite* createWithSpriteFrameName(const char *pszSpriteFrameName);
 77     
 78     /// @}  end of creators group
 79     
 80     
 81     
 82     /// @{
 83     /// @name Initializers
 84     
 85     /**
 86      * Default constructor
 87      * @js ctor
 88      */
 89     CCSprite(void);
 90     
 91     /**
 92      * Default destructor
 93      * @js NA
 94      * @lua NA
 95      */
 96     virtual ~CCSprite(void);
 97     
 98     /**
 99      * Initializes an empty sprite with nothing init.
100      */
101     virtual bool init(void);
102     
103     /**
104      * Initializes a sprite with a texture.
105      *
106      * After initialization, the rect used will be the size of the texture, and the offset will be (0,0).
107      *
108      * @param   pTexture    A pointer to an existing CCTexture2D object.
109      *                      You can use a CCTexture2D object for many sprites.
110      * @return  true if the sprite is initialized properly, false otherwise.
111      */
112     virtual bool initWithTexture(CCTexture2D *pTexture);
113     
114     /**
115      * Initializes a sprite with a texture and a rect.
116      *
117      * After initialization, the offset will be (0,0).
118      *
119      * @param   pTexture    A pointer to an exisiting CCTexture2D object.
120      *                      You can use a CCTexture2D object for many sprites.
121      * @param   rect        Only the contents inside rect of this texture will be applied for this sprite.
122      * @return  true if the sprite is initialized properly, false otherwise.
123      */
124     virtual bool initWithTexture(CCTexture2D *pTexture, const CCRect& rect);
125     
126     /**
127      * Initializes a sprite with a texture and a rect in points, optionally rotated.
128      *
129      * After initialization, the offset will be (0,0).
130      * @note    This is the designated initializer.
131      *
132      * @param   pTexture    A CCTexture2D object whose texture will be applied to this sprite.
133      * @param   rect        A rectangle assigned the contents of texture.
134      * @param   rotated     Whether or not the texture rectangle is rotated.
135      * @return  true if the sprite is initialized properly, false otherwise.
136      */
137     virtual bool initWithTexture(CCTexture2D *pTexture, const CCRect& rect, bool rotated);
138     
139     /**
140      * Initializes a sprite with an SpriteFrame. The texture and rect in SpriteFrame will be applied on this sprite
141      *
142      * @param   pSpriteFrame  A CCSpriteFrame object. It should includes a valid texture and a rect
143      * @return  true if the sprite is initialized properly, false otherwise.
144      */
145     virtual bool initWithSpriteFrame(CCSpriteFrame *pSpriteFrame);
146     
147     /**
148      * Initializes a sprite with an sprite frame name.
149      *
150      * A CCSpriteFrame will be fetched from the CCSpriteFrameCache by name.
151      * If the CCSpriteFrame doesn't exist it will raise an exception.
152      *
153      * @param   pszSpriteFrameName  A key string that can fected a volid CCSpriteFrame from CCSpriteFrameCache
154      * @return  true if the sprite is initialized properly, false otherwise.
155      */
156     virtual bool initWithSpriteFrameName(const char *pszSpriteFrameName);
157     
158     /**
159      * Initializes a sprite with an image filename.
160      *
161      * This method will find pszFilename from local file system, load its content to CCTexture2D,
162      * then use CCTexture2D to create a sprite.
163      * After initialization, the rect used will be the size of the image. The offset will be (0,0).
164      *
165      * @param   pszFilename The path to an image file in local file system
166      * @return  true if the sprite is initialized properly, false otherwise.
167      * @js init
168      */
169     virtual bool initWithFile(const char *pszFilename);
170     
171     /**
172      * Initializes a sprite with an image filename, and a rect.
173      *
174      * This method will find pszFilename from local file system, load its content to CCTexture2D,
175      * then use CCTexture2D to create a sprite.
176      * After initialization, the offset will be (0,0).
177      *
178      * @param   pszFilename The path to an image file in local file system.
179      * @param   rect        The rectangle assigned the content area from texture.
180      * @return  true if the sprite is initialized properly, false otherwise.
181      * @js init
182      */
183     virtual bool initWithFile(const char *pszFilename, const CCRect& rect);
184     
185     /// @} end of initializers
186     
187     /// @{
188     /// @name Functions inherited from CCTextureProtocol
189     virtual void setTexture(CCTexture2D *texture);
190     virtual CCTexture2D* getTexture(void);
191     inline void setBlendFunc(ccBlendFunc blendFunc) { m_sBlendFunc = blendFunc; }
192     /**
193      * @js NA
194      */
195     inline ccBlendFunc getBlendFunc(void) { return m_sBlendFunc; }
196     /// @}
197 
198     /// @{
199     /// @name Functions inherited from CCNode
200     virtual void setScaleX(float fScaleX);
201     virtual void setScaleY(float fScaleY);
202     /**
203      * @lua NA
204      */
205     virtual void setPosition(const CCPoint& pos);
206     virtual void setRotation(float fRotation);
207     virtual void setRotationX(float fRotationX);
208     virtual void setRotationY(float fRotationY);
209     virtual void setSkewX(float sx);
210     virtual void setSkewY(float sy);
211     virtual void removeChild(CCNode* pChild, bool bCleanup);
212     virtual void removeAllChildrenWithCleanup(bool bCleanup);
213     virtual void reorderChild(CCNode *pChild, int zOrder);
214     virtual void addChild(CCNode *pChild);
215     virtual void addChild(CCNode *pChild, int zOrder);
216     virtual void addChild(CCNode *pChild, int zOrder, int tag);
217     virtual void sortAllChildren();
218     virtual void setScale(float fScale);
219     virtual void setVertexZ(float fVertexZ);
220     virtual void setAnchorPoint(const CCPoint& anchor);
221     virtual void ignoreAnchorPointForPosition(bool value);
222     virtual void setVisible(bool bVisible);
223     virtual void draw(void);
224     /// @}
225     
226     /// @{
227     /// @name Functions inherited from CCNodeRGBA
228     virtual void setColor(const ccColor3B& color3);
229     virtual void updateDisplayedColor(const ccColor3B& parentColor);
230     virtual void setOpacity(GLubyte opacity);
231     virtual void setOpacityModifyRGB(bool modify);
232     virtual bool isOpacityModifyRGB(void);
233     virtual void updateDisplayedOpacity(GLubyte parentOpacity);
234     /// @}
235 
236     
237     /// @{
238     /// @name BatchNode methods
239     
240     /**
241      * Updates the quad according the rotation, position, scale values. 
242      */
243     virtual void updateTransform(void);
244     
245     /**
246      * Returns the batch node object if this sprite is rendered by CCSpriteBatchNode
247      *
248      * @return The CCSpriteBatchNode object if this sprite is rendered by CCSpriteBatchNode,
249      *         NULL if the sprite isn't used batch node.
250      */
251     virtual CCSpriteBatchNode* getBatchNode(void);
252     /**
253      * Sets the batch node to sprite
254      * @warning This method is not recommended for game developers. Sample code for using batch node
255      * @code
256      * CCSpriteBatchNode *batch = CCSpriteBatchNode::create("Images/grossini_dance_atlas.png", 15);
257      * CCSprite *sprite = CCSprite::createWithTexture(batch->getTexture(), CCRectMake(0, 0, 57, 57));
258      * batch->addChild(sprite);
259      * layer->addChild(batch);
260      * @endcode
261      */
262     virtual void setBatchNode(CCSpriteBatchNode *pobSpriteBatchNode);
263      
264     /// @} end of BatchNode methods
265     
266     
267     
268     /// @{
269     /// @name Texture methods
270     
271     /**
272      * Updates the texture rect of the CCSprite in points.
273      * It will call setTextureRect:rotated:untrimmedSize with rotated = NO, and utrimmedSize = rect.size.
274      */
275     virtual void setTextureRect(const CCRect& rect);
276     
277     /**
278      * Sets the texture rect, rectRotated and untrimmed size of the CCSprite in points.
279      * It will update the texture coordinates and the vertex rectangle.
280      */
281     virtual void setTextureRect(const CCRect& rect, bool rotated, const CCSize& untrimmedSize);
282     
283     /**
284      * Sets the vertex rect.
285      * It will be called internally by setTextureRect.
286      * Useful if you want to create 2x images from SD images in Retina Display.
287      * Do not call it manually. Use setTextureRect instead.
288      */
289     virtual void setVertexRect(const CCRect& rect);
290     
291     /// @} end of texture methods
292     
293 
294     
295     /// @{
296     /// @name Frames methods
297     
298     /**
299      * Sets a new display frame to the CCSprite.
300      */
301     virtual void setDisplayFrame(CCSpriteFrame *pNewFrame);
302     
303     /**
304      * Returns whether or not a CCSpriteFrame is being displayed
305      */
306     virtual bool isFrameDisplayed(CCSpriteFrame *pFrame);
307     
308     /**
309      * Returns the current displayed frame.
310      * @js NA
311      */
312     virtual CCSpriteFrame* displayFrame(void);
313     
314     /// @} End of frames methods
315     
316 
317     /// @{
318     /// @name Animation methods
319     /**
320      * Changes the display frame with animation name and index.
321      * The animation name will be get from the CCAnimationCache
322      */
323     virtual void setDisplayFrameWithAnimationName(const char *animationName, int frameIndex);
324     /// @}
325     
326     
327     /// @{
328     /// @name Sprite Properties' setter/getters
329     
330     /** 
331      * Whether or not the Sprite needs to be updated in the Atlas.
332      *
333      * @return true if the sprite needs to be updated in the Atlas, false otherwise.
334      */
335     inline virtual bool isDirty(void) { return m_bDirty; }
336     
337     /** 
338      * Makes the Sprite to be updated in the Atlas.
339      */
340     inline virtual void setDirty(bool bDirty) { m_bDirty = bDirty; }
341     
342     /**
343      * Returns the quad (tex coords, vertex coords and color) information.
344      * @js NA
345      */
346     inline ccV3F_C4B_T2F_Quad getQuad(void) { return m_sQuad; }
347 
348     /** 
349      * Returns whether or not the texture rectangle is rotated.
350      */
351     inline bool isTextureRectRotated(void) { return m_bRectRotated; }
352     
353     /** 
354      * Returns the index used on the TextureAtlas. 
355      */
356     inline unsigned int getAtlasIndex(void) { return m_uAtlasIndex; }
357     
358     /** 
359      * Sets the index used on the TextureAtlas.
360      * @warning Don't modify this value unless you know what you are doing
361      */
362     inline void setAtlasIndex(unsigned int uAtlasIndex) { m_uAtlasIndex = uAtlasIndex; }
363 
364     /** 
365      * Returns the rect of the CCSprite in points 
366      */
367     inline const CCRect& getTextureRect(void) { return m_obRect; }
368 
369     /**
370      * Gets the weak reference of the CCTextureAtlas when the sprite is rendered using via CCSpriteBatchNode
371      */
372     inline CCTextureAtlas* getTextureAtlas(void) { return m_pobTextureAtlas; }
373     
374     /**
375      * Sets the weak reference of the CCTextureAtlas when the sprite is rendered using via CCSpriteBatchNode
376      */
377     inline void setTextureAtlas(CCTextureAtlas *pobTextureAtlas) { m_pobTextureAtlas = pobTextureAtlas; }
378 
379     /** 
380      * Gets the offset position of the sprite. Calculated automatically by editors like Zwoptex.
381      */
382     inline const CCPoint& getOffsetPosition(void) { return m_obOffsetPosition; }
383 
384 
385     /** 
386      * Returns the flag which indicates whether the sprite is flipped horizontally or not.
387      *
388      * It only flips the texture of the sprite, and not the texture of the sprite's children.
389      * Also, flipping the texture doesn't alter the anchorPoint.
390      * If you want to flip the anchorPoint too, and/or to flip the children too use:
391      * sprite->setScaleX(sprite->getScaleX() * -1);
392      *
393      * @return true if the sprite is flipped horizaontally, false otherwise.
394      * @js isFlippedX
395      */
396     bool isFlipX(void);
397     /**
398      * Sets whether the sprite should be flipped horizontally or not.
399      *
400      * @param bFlipX true if the sprite should be flipped horizaontally, false otherwise.
401      */
402     void setFlipX(bool bFlipX);
403     
404     /** 
405      * Return the flag which indicates whether the sprite is flipped vertically or not.
406      * 
407      * It only flips the texture of the sprite, and not the texture of the sprite's children.
408      * Also, flipping the texture doesn't alter the anchorPoint.
409      * If you want to flip the anchorPoint too, and/or to flip the children too use:
410      * sprite->setScaleY(sprite->getScaleY() * -1);
411      * 
412      * @return true if the sprite is flipped vertically, flase otherwise.
413      * @js isFlippedY
414      */
415     bool isFlipY(void);
416     /**
417      * Sets whether the sprite should be flipped vertically or not.
418      *
419      * @param bFlipY true if the sprite should be flipped vertically, flase otherwise.
420      */
421     void setFlipY(bool bFlipY);
422     
423     /// @} End of Sprite properties getter/setters
424     
425 protected:
426     void updateColor(void);
427     virtual void setTextureCoords(CCRect rect);
428     virtual void updateBlendFunc(void);
429     virtual void setReorderChildDirtyRecursively(void);
430     virtual void setDirtyRecursively(bool bValue);
431 
432     //
433     // Data used when the sprite is rendered using a CCSpriteSheet
434     //
435     CCTextureAtlas*     m_pobTextureAtlas;      /// CCSpriteBatchNode texture atlas (weak reference)
436     unsigned int        m_uAtlasIndex;          /// Absolute (real) Index on the SpriteSheet
437     CCSpriteBatchNode*  m_pobBatchNode;         /// Used batch node (weak reference)
438     
439     bool                m_bDirty;               /// Whether the sprite needs to be updated
440     bool                m_bRecursiveDirty;      /// Whether all of the sprite's children needs to be updated
441     bool                m_bHasChildren;         /// Whether the sprite contains children
442     bool                m_bShouldBeHidden;      /// should not be drawn because one of the ancestors is not visible
443     CCAffineTransform   m_transformToBatch;
444     
445     //
446     // Data used when the sprite is self-rendered
447     //
448     ccBlendFunc        m_sBlendFunc;            /// It's required for CCTextureProtocol inheritance
449     CCTexture2D*       m_pobTexture;            /// CCTexture2D object that is used to render the sprite
450 
451     //
452     // Shared data
453     //
454 
455     // texture
456     CCRect m_obRect;                            /// Retangle of CCTexture2D
457     bool   m_bRectRotated;                      /// Whether the texture is rotated
458 
459     // Offset Position (used by Zwoptex)
460     CCPoint m_obOffsetPosition;
461     CCPoint m_obUnflippedOffsetPositionFromCenter;
462 
463     // vertex coords, texture coords and color info
464     ccV3F_C4B_T2F_Quad m_sQuad;
465 
466     // opacity and RGB protocol
467     bool m_bOpacityModifyRGB;
468 
469     // image is flipped
470     bool m_bFlipX;                              /// Whether the sprite is flipped horizaontally or not.
471     bool m_bFlipY;                              /// Whether the sprite is flipped vertically or not.
472 };
473 
474 CCSprite.h

 

  CCNode與座標系

  Cocos2d-x採用了場景、層、精靈的層次結構來組織遊戲元素,與此同時,這個層次結構還對應了遊戲的渲染層次,所以遊戲元素能夠組織成樹形結構,稱做渲染樹。Cocos2d-x把渲染樹上的每個遊戲元素抽象爲一個節點,即CCNode。一切遊戲元素都繼承自CCNode,所以它們都具備CCNode所提供的特性。

 

   1 //cocos2d-x-2.2/cocos2dx/base_nodes/CCNode.h
   2 
   3 enum {
   4     kCCNodeTagInvalid = -1,
   5 };
   6 
   7 enum {
   8     kCCNodeOnEnter,
   9     kCCNodeOnExit,
  10     kCCNodeOnEnterTransitionDidFinish,
  11     kCCNodeOnExitTransitionDidStart,
  12     kCCNodeOnCleanup
  13 };
  14 
  15 
  16 class CC_DLL CCNode : public CCObject
  17 {
  18 public:
  19     /// @{
  20     /// @name Constructor, Distructor and Initializers
  21     
  22     /**
  23      * Default constructor
  24      * @js ctor
  25      */
  26     CCNode(void);
  27     
  28     /**
  29      * Default destructor
  30      * @js NA
  31      * @lua NA
  32      */
  33     virtual ~CCNode(void);
  34     
  35     /**
  36      *  Initializes the instance of CCNode
  37      *  @return Whether the initialization was successful.
  38      */
  39     virtual bool init();
  40     /**
  41      * Allocates and initializes a node.
  42      * @return A initialized node which is marked as "autorelease".
  43      */
  44     static CCNode * create(void);
  45     
  46     /**
  47      * Gets the description string. It makes debugging easier.
  48      * @return A string terminated with '\0'
  49      * @js NA
  50      */
  51     const char* description(void);
  52     
  53     /// @} end of initializers
  54     
  55     
  56     
  57     /// @{
  58     /// @name Setters & Getters for Graphic Peroperties
  59     
  60     /**
  61      * Sets the Z order which stands for the drawing order, and reorder this node in its parent's children array.
  62      *
  63      * The Z order of node is relative to its "brothers": children of the same parent.
  64      * It's nothing to do with OpenGL's z vertex. This one only affects the draw order of nodes in cocos2d.
  65      * The larger number it is, the later this node will be drawn in each message loop.
  66      * Please refer to setVertexZ(float) for the difference.
  67      *
  68      * @param nZOrder   Z order of this node.
  69      */
  70     virtual void setZOrder(int zOrder);
  71     /**
  72      * Sets the z order which stands for the drawing order
  73      *
  74      * This is an internal method. Don't call it outside the framework.
  75      * The difference between setZOrder(int) and _setOrder(int) is:
  76      * - _setZOrder(int) is a pure setter for m_nZOrder memeber variable
  77      * - setZOrder(int) firstly changes m_nZOrder, then recorder this node in its parent's chilren array.
  78      */
  79     virtual void _setZOrder(int z);
  80     /**
  81      * Gets the Z order of this node.
  82      *
  83      * @see setZOrder(int)
  84      *
  85      * @return The Z order.
  86      */
  87     virtual int getZOrder();
  88 
  89 
  90     /**
  91      * Sets the real OpenGL Z vertex.
  92      *
  93      * Differences between openGL Z vertex and cocos2d Z order:
  94      * - OpenGL Z modifies the Z vertex, and not the Z order in the relation between parent-children
  95      * - OpenGL Z might require to set 2D projection
  96      * - cocos2d Z order works OK if all the nodes uses the same openGL Z vertex. eg: vertexZ = 0
  97      *
  98      * @warning Use it at your own risk since it might break the cocos2d parent-children z order
  99      *
 100      * @param fVertexZ  OpenGL Z vertex of this node.
 101      */
 102     virtual void setVertexZ(float vertexZ);
 103     /**
 104      * Gets OpenGL Z vertex of this node.
 105      *
 106      * @see setVertexZ(float)
 107      *
 108      * @return OpenGL Z vertex of this node
 109      */
 110     virtual float getVertexZ();
 111 
 112 
 113     /**
 114      * Changes the scale factor on X axis of this node
 115      *
 116      * The deafult value is 1.0 if you haven't changed it before
 117      *
 118      * @param fScaleX   The scale factor on X axis.
 119      */
 120     virtual void setScaleX(float fScaleX);
 121     /**
 122      * Returns the scale factor on X axis of this node
 123      *
 124      * @see setScaleX(float)
 125      *
 126      * @return The scale factor on X axis.
 127      */
 128     virtual float getScaleX();
 129 
 130     
 131     /**
 132      * Changes the scale factor on Y axis of this node
 133      *
 134      * The Default value is 1.0 if you haven't changed it before.
 135      *
 136      * @param fScaleY   The scale factor on Y axis.
 137      */
 138     virtual void setScaleY(float fScaleY);
 139     /**
 140      * Returns the scale factor on Y axis of this node
 141      *
 142      * @see setScaleY(float)
 143      *
 144      * @return The scale factor on Y axis. 
 145      */
 146     virtual float getScaleY();
 147 
 148     
 149     /**
 150      * Changes both X and Y scale factor of the node.
 151      *
 152      * 1.0 is the default scale factor. It modifies the X and Y scale at the same time.
 153      *
 154      * @param scale     The scale factor for both X and Y axis.
 155      */
 156     virtual void setScale(float scale);
 157     /**
 158      * Gets the scale factor of the node,  when X and Y have the same scale factor.
 159      *
 160      * @warning Assert when m_fScaleX != m_fScaleY.
 161      * @see setScale(float)
 162      *
 163      * @return The scale factor of the node.
 164      */
 165     virtual float getScale();
 166     
 167 
 168     /**
 169      * Changes both X and Y scale factor of the node.
 170      *
 171      * 1.0 is the default scale factor. It modifies the X and Y scale at the same time.
 172      *
 173      * @param fScaleX     The scale factor on X axis.
 174      * @param fScaleY     The scale factor on Y axis.
 175      */
 176     virtual void setScale(float fScaleX,float fScaleY);
 177 
 178     
 179     /**
 180      * Changes the position (x,y) of the node in OpenGL coordinates
 181      *
 182      * Usually we use ccp(x,y) to compose CCPoint object.
 183      * The original point (0,0) is at the left-bottom corner of screen.
 184      * For example, this codesnip sets the node in the center of screen.
 185      * @code
 186      * CCSize size = CCDirector::sharedDirector()->getWinSize();
 187      * node->setPosition( ccp(size.width/2, size.height/2) )
 188      * @endcode
 189      *
 190      * @param position  The position (x,y) of the node in OpenGL coordinates
 191      * @js NA
 192      */
 193     virtual void setPosition(const CCPoint &position);
 194     /**
 195      * Gets the position (x,y) of the node in OpenGL coordinates
 196      * 
 197      * @see setPosition(const CCPoint&)
 198      *
 199      * @return The position (x,y) of the node in OpenGL coordinates
 200      */
 201     virtual const CCPoint& getPosition();
 202     /**
 203      * Sets position in a more efficient way.
 204      *
 205      * Passing two numbers (x,y) is much efficient than passing CCPoint object.
 206      * This method is binded to lua and javascript. 
 207      * Passing a number is 10 times faster than passing a object from lua to c++
 208      *
 209      * @code
 210      * // sample code in lua
 211      * local pos  = node::getPosition()  -- returns CCPoint object from C++
 212      * node:setPosition(x, y)            -- pass x, y coordinate to C++
 213      * @endcode
 214      *
 215      * @param x     X coordinate for position
 216      * @param y     Y coordinate for position
 217      * @js NA
 218      */
 219     virtual void setPosition(float x, float y);
 220     /**
 221      * Gets position in a more efficient way, returns two number instead of a CCPoint object
 222      *
 223      * @see setPosition(float, float)
 224      */
 225     virtual void getPosition(float* x, float* y);
 226     /**
 227      * Gets/Sets x or y coordinate individually for position.
 228      * These methods are used in Lua and Javascript Bindings
 229      */
 230     virtual void  setPositionX(float x);
 231     virtual float getPositionX(void);
 232     virtual void  setPositionY(float y);
 233     virtual float getPositionY(void);
 234     
 235     
 236     /**
 237      * Changes the X skew angle of the node in degrees.
 238      *
 239      * This angle describes the shear distortion in the X direction.
 240      * Thus, it is the angle between the Y axis and the left edge of the shape
 241      * The default skewX angle is 0. Positive values distort the node in a CW direction.
 242      *
 243      * @param fSkewX The X skew angle of the node in degrees.
 244      */
 245     virtual void setSkewX(float fSkewX);
 246     /**
 247      * Returns the X skew angle of the node in degrees.
 248      *
 249      * @see setSkewX(float)
 250      *
 251      * @return The X skew angle of the node in degrees.
 252      */
 253     virtual float getSkewX();
 254 
 255     
 256     /**
 257      * Changes the Y skew angle of the node in degrees.
 258      *
 259      * This angle describes the shear distortion in the Y direction.
 260      * Thus, it is the angle between the X axis and the bottom edge of the shape
 261      * The default skewY angle is 0. Positive values distort the node in a CCW direction.
 262      *
 263      * @param fSkewY    The Y skew angle of the node in degrees.
 264      */
 265     virtual void setSkewY(float fSkewY);
 266     /**
 267      * Returns the Y skew angle of the node in degrees.
 268      *
 269      * @see setSkewY(float)
 270      *
 271      * @return The Y skew angle of the node in degrees.
 272      */
 273     virtual float getSkewY();
 274 
 275     
 276     /**
 277      * Sets the anchor point in percent.
 278      *
 279      * anchorPoint is the point around which all transformations and positioning manipulations take place.
 280      * It's like a pin in the node where it is "attached" to its parent.
 281      * The anchorPoint is normalized, like a percentage. (0,0) means the bottom-left corner and (1,1) means the top-right corner.
 282      * But you can use values higher than (1,1) and lower than (0,0) too.
 283      * The default anchorPoint is (0.5,0.5), so it starts in the center of the node.
 284      *
 285      * @param anchorPoint   The anchor point of node.
 286      */
 287     virtual void setAnchorPoint(const CCPoint& anchorPoint);
 288     /** 
 289      * Returns the anchor point in percent.
 290      *
 291      * @see setAnchorPoint(const CCPoint&)
 292      *
 293      * @return The anchor point of node.
 294      */
 295     virtual const CCPoint& getAnchorPoint();
 296     /**
 297      * Returns the anchorPoint in absolute pixels.
 298      * 
 299      * @warning You can only read it. If you wish to modify it, use anchorPoint instead.
 300      * @see getAnchorPoint()
 301      *
 302      * @return The anchor point in absolute pixels.
 303      */
 304     virtual const CCPoint& getAnchorPointInPoints();
 305     
 306     
 307     /**
 308      * Sets the untransformed size of the node.
 309      *
 310      * The contentSize remains the same no matter the node is scaled or rotated.
 311      * All nodes has a size. Layer and Scene has the same size of the screen.
 312      *
 313      * @param contentSize   The untransformed size of the node.
 314      */
 315     virtual void setContentSize(const CCSize& contentSize);
 316     /**
 317      * Returns the untransformed size of the node.
 318      *
 319      * @see setContentSize(const CCSize&)
 320      *
 321      * @return The untransformed size of the node.
 322      */
 323     virtual const CCSize& getContentSize() const;
 324 
 325     
 326     /**
 327      * Sets whether the node is visible
 328      *
 329      * The default value is true, a node is default to visible
 330      *
 331      * @param visible   true if the node is visible, false if the node is hidden.
 332      */
 333     virtual void setVisible(bool visible);
 334     /**
 335      * Determines if the node is visible
 336      *
 337      * @see setVisible(bool)
 338      *
 339      * @return true if the node is visible, false if the node is hidden.
 340      */
 341     virtual bool isVisible();
 342 
 343     
 344     /** 
 345      * Sets the rotation (angle) of the node in degrees. 
 346      * 
 347      * 0 is the default rotation angle. 
 348      * Positive values rotate node clockwise, and negative values for anti-clockwise.
 349      * 
 350      * @param fRotation     The roration of the node in degrees.
 351      */
 352     virtual void setRotation(float fRotation);
 353     /**
 354      * Returns the rotation of the node in degrees.
 355      *
 356      * @see setRotation(float)
 357      *
 358      * @return The rotation of the node in degrees.
 359      */
 360     virtual float getRotation();
 361 
 362     
 363     /** 
 364      * Sets the X rotation (angle) of the node in degrees which performs a horizontal rotational skew.
 365      * 
 366      * 0 is the default rotation angle. 
 367      * Positive values rotate node clockwise, and negative values for anti-clockwise.
 368      * 
 369      * @param fRotationX    The X rotation in degrees which performs a horizontal rotational skew.
 370      */
 371     virtual void setRotationX(float fRotaionX);
 372     /**
 373      * Gets the X rotation (angle) of the node in degrees which performs a horizontal rotation skew.
 374      *
 375      * @see setRotationX(float)
 376      *
 377      * @return The X rotation in degrees.
 378      */
 379     virtual float getRotationX();
 380 
 381     
 382     /** 
 383      * Sets the Y rotation (angle) of the node in degrees which performs a vertical rotational skew.
 384      * 
 385      * 0 is the default rotation angle. 
 386      * Positive values rotate node clockwise, and negative values for anti-clockwise.
 387      *
 388      * @param fRotationY    The Y rotation in degrees.
 389      */
 390     virtual void setRotationY(float fRotationY);
 391     /**
 392      * Gets the Y rotation (angle) of the node in degrees which performs a vertical rotational skew.
 393      *
 394      * @see setRotationY(float)
 395      *
 396      * @return The Y rotation in degrees.
 397      */
 398     virtual float getRotationY();
 399 
 400     
 401     /**
 402      * Sets the arrival order when this node has a same ZOrder with other children.
 403      *
 404      * A node which called addChild subsequently will take a larger arrival order,
 405      * If two children have the same Z order, the child with larger arrival order will be drawn later.
 406      *
 407      * @warning This method is used internally for zOrder sorting, don't change this manually
 408      *
 409      * @param uOrderOfArrival   The arrival order.
 410      */
 411     virtual void setOrderOfArrival(unsigned int uOrderOfArrival);
 412     /**
 413      * Returns the arrival order, indecates which children is added previously.
 414      *
 415      * @see setOrderOfArrival(unsigned int)
 416      *
 417      * @return The arrival order.
 418      */
 419     virtual unsigned int getOrderOfArrival();
 420     
 421     
 422     /**
 423      * Sets the state of OpenGL server side.
 424      *
 425      * @param glServerState     The state of OpenGL server side.
 426      * @js NA
 427      */
 428     virtual void setGLServerState(ccGLServerState glServerState);
 429     /**
 430      * Returns the state of OpenGL server side.
 431      *
 432      * @return The state of OpenGL server side.
 433      * @js NA
 434      */
 435     virtual ccGLServerState getGLServerState();
 436     
 437     
 438     /**
 439      * Sets whether the anchor point will be (0,0) when you position this node.
 440      *
 441      * This is an internal method, only used by CCLayer and CCScene. Don't call it outside framework.
 442      * The default value is false, while in CCLayer and CCScene are true
 443      *
 444      * @param ignore    true if anchor point will be (0,0) when you position this node
 445      * @todo This method shoud be renamed as setIgnoreAnchorPointForPosition(bool) or something with "set"
 446      */
 447     virtual void ignoreAnchorPointForPosition(bool ignore);
 448     /**
 449      * Gets whether the anchor point will be (0,0) when you position this node.
 450      *
 451      * @see ignoreAnchorPointForPosition(bool)
 452      *
 453      * @return true if the anchor point will be (0,0) when you position this node.
 454      */
 455     virtual bool isIgnoreAnchorPointForPosition();
 456     
 457     /// @}  end of Setters & Getters for Graphic Peroperties
 458     
 459     
 460     /// @{
 461     /// @name Children and Parent
 462     
 463     /** 
 464      * Adds a child to the container with z-order as 0.
 465      *
 466      * If the child is added to a 'running' node, then 'onEnter' and 'onEnterTransitionDidFinish' will be called immediately.
 467      *
 468      * @param child A child node
 469      */
 470     virtual void addChild(CCNode * child);
 471     /** 
 472      * Adds a child to the container with a z-order
 473      *
 474      * If the child is added to a 'running' node, then 'onEnter' and 'onEnterTransitionDidFinish' will be called immediately.
 475      *
 476      * @param child     A child node
 477      * @param zOrder    Z order for drawing priority. Please refer to setZOrder(int)
 478      */
 479     virtual void addChild(CCNode * child, int zOrder);
 480     /** 
 481      * Adds a child to the container with z order and tag
 482      *
 483      * If the child is added to a 'running' node, then 'onEnter' and 'onEnterTransitionDidFinish' will be called immediately.
 484      *
 485      * @param child     A child node
 486      * @param zOrder    Z order for drawing priority. Please refer to setZOrder(int)
 487      * @param tag       A interger to identify the node easily. Please refer to setTag(int)
 488      */
 489     virtual void addChild(CCNode* child, int zOrder, int tag);
 490     /**
 491      * Gets a child from the container with its tag
 492      *
 493      * @param tag   An identifier to find the child node.
 494      *
 495      * @return a CCNode object whose tag equals to the input parameter
 496      */
 497     CCNode * getChildByTag(int tag);
 498     /**
 499      * Return an array of children
 500      *
 501      * Composing a "tree" structure is a very important feature of CCNode
 502      * Here's a sample code of traversing children array:
 503      * @code
 504      * CCNode* node = NULL;
 505      * CCARRAY_FOREACH(parent->getChildren(), node)
 506      * {
 507      *     node->setPosition(0,0);
 508      * }
 509      * @endcode
 510      * This sample code traverses all children nodes, and set theie position to (0,0)
 511      *
 512      * @return An array of children
 513      */
 514     virtual CCArray* getChildren();
 515     
 516     /** 
 517      * Get the amount of children.
 518      *
 519      * @return The amount of children.
 520      */
 521     unsigned int getChildrenCount(void) const;
 522     
 523     /**
 524      * Sets the parent node
 525      *
 526      * @param parent    A pointer to the parnet node
 527      */
 528     virtual void setParent(CCNode* parent);
 529     /**
 530      * Returns a pointer to the parent node
 531      * 
 532      * @see setParent(CCNode*)
 533      *
 534      * @returns A pointer to the parnet node
 535      */
 536     virtual CCNode* getParent();
 537     
 538     
 539     ////// REMOVES //////
 540     
 541     /** 
 542      * Removes this node itself from its parent node with a cleanup.
 543      * If the node orphan, then nothing happens.
 544      * @see removeFromParentAndCleanup(bool)
 545      */
 546     virtual void removeFromParent();
 547     /** 
 548      * Removes this node itself from its parent node. 
 549      * If the node orphan, then nothing happens.
 550      * @param cleanup   true if all actions and callbacks on this node should be removed, false otherwise.
 551      * @js removeFromParent
 552      */
 553     virtual void removeFromParentAndCleanup(bool cleanup);
 554     /** 
 555      * Removes a child from the container with a cleanup
 556      *
 557      * @see removeChild(CCNode, bool)
 558      *
 559      * @param child     The child node which will be removed.
 560      */
 561     virtual void removeChild(CCNode* child);
 562     /** 
 563      * Removes a child from the container. It will also cleanup all running actions depending on the cleanup parameter.
 564      * 
 565      * @param child     The child node which will be removed.
 566      * @param cleanup   true if all running actions and callbacks on the child node will be cleanup, false otherwise.
 567      */
 568     virtual void removeChild(CCNode* child, bool cleanup);
 569     /** 
 570      * Removes a child from the container by tag value with a cleanup.
 571      *
 572      * @see removeChildByTag(int, bool)
 573      *
 574      * @param tag       An interger number that identifies a child node
 575      */
 576     virtual void removeChildByTag(int tag);
 577     /** 
 578      * Removes a child from the container by tag value. It will also cleanup all running actions depending on the cleanup parameter
 579      * 
 580      * @param tag       An interger number that identifies a child node
 581      * @param cleanup   true if all running actions and callbacks on the child node will be cleanup, false otherwise. 
 582      */
 583     virtual void removeChildByTag(int tag, bool cleanup);
 584     /** 
 585      * Removes all children from the container with a cleanup.
 586      *
 587      * @see removeAllChildrenWithCleanup(bool)
 588      */
 589     virtual void removeAllChildren();
 590     /** 
 591      * Removes all children from the container, and do a cleanup to all running actions depending on the cleanup parameter.
 592      *
 593      * @param cleanup   true if all running actions on all children nodes should be cleanup, false oterwise.
 594      * @js removeAllChildren
 595      */
 596     virtual void removeAllChildrenWithCleanup(bool cleanup);
 597     
 598     /** 
 599      * Reorders a child according to a new z value.
 600      *
 601      * @param child     An already added child node. It MUST be already added.
 602      * @param zOrder    Z order for drawing priority. Please refer to setZOrder(int)
 603      */
 604     virtual void reorderChild(CCNode * child, int zOrder);
 605     
 606     /** 
 607      * Sorts the children array once before drawing, instead of every time when a child is added or reordered.
 608      * This appraoch can improves the performance massively.
 609      * @note Don't call this manually unless a child added needs to be removed in the same frame 
 610      */
 611     virtual void sortAllChildren();
 612 
 613     /// @} end of Children and Parent
 614     
 615 
 616     
 617     /// @{
 618     /// @name Grid object for effects
 619     
 620     /**
 621      * Returns a grid object that is used when applying effects
 622      * 
 623      * @return A CCGrid object that is used when applying effects
 624      * @js NA
 625      */
 626     virtual CCGridBase* getGrid();
 627     /**
 628      * Changes a grid object that is used when applying effects
 629      *
 630      * @param A CCGrid object that is used when applying effects
 631      */
 632     virtual void setGrid(CCGridBase *pGrid);
 633     
 634     /// @} end of Grid
 635     
 636     
 637     /// @{
 638     /// @name Tag & User data
 639     
 640     /**
 641      * Returns a tag that is used to identify the node easily.
 642      *
 643      * You can set tags to node then identify them easily.
 644      * @code
 645      * #define TAG_PLAYER  1
 646      * #define TAG_MONSTER 2
 647      * #define TAG_BOSS    3
 648      * // set tags
 649      * node1->setTag(TAG_PLAYER);
 650      * node2->setTag(TAG_MONSTER);
 651      * node3->setTag(TAG_BOSS);
 652      * parent->addChild(node1);
 653      * parent->addChild(node2);
 654      * parent->addChild(node3);
 655      * // identify by tags
 656      * CCNode* node = NULL;
 657      * CCARRAY_FOREACH(parent->getChildren(), node)
 658      * {
 659      *     switch(node->getTag())
 660      *     {
 661      *         case TAG_PLAYER:
 662      *             break;
 663      *         case TAG_MONSTER:
 664      *             break;
 665      *         case TAG_BOSS:
 666      *             break;
 667      *     }
 668      * }
 669      * @endcode
 670      *
 671      * @return A interger that identifies the node.
 672      */
 673     virtual int getTag() const;
 674     /**
 675      * Changes the tag that is used to identify the node easily.
 676      *
 677      * Please refer to getTag for the sample code.
 678      *
 679      * @param A interger that indentifies the node.
 680      */
 681     virtual void setTag(int nTag);
 682     
 683     /**
 684      * Returns a custom user data pointer
 685      *
 686      * You can set everything in UserData pointer, a data block, a structure or an object.
 687      * 
 688      * @return A custom user data pointer
 689      * @js NA
 690      */
 691     virtual void* getUserData();
 692     /**
 693      * Sets a custom user data pointer
 694      *
 695      * You can set everything in UserData pointer, a data block, a structure or an object, etc.
 696      * @warning Don't forget to release the memroy manually, 
 697      *          especially before you change this data pointer, and before this node is autoreleased.
 698      *
 699      * @return A custom user data pointer
 700      * @js NA
 701      */
 702     virtual void setUserData(void *pUserData);
 703     
 704     /** 
 705      * Returns a user assigned CCObject
 706      * 
 707      * Similar to userData, but instead of holding a void* it holds an object
 708      *
 709      * @return A user assigned CCObject
 710      * @js NA
 711      */
 712     virtual CCObject* getUserObject();
 713     /**
 714      * Returns a user assigned CCObject
 715      *
 716      * Similar to UserData, but instead of holding a void* it holds an object.
 717      * The UserObject will be retained once in this method,
 718      * and the previous UserObject (if existed) will be relese.
 719      * The UserObject will be released in CCNode's destructure.
 720      *
 721      * @param A user assigned CCObject
 722      */
 723     virtual void setUserObject(CCObject *pUserObject);
 724     
 725     /// @} end of Tag & User Data
 726     
 727     
 728     /// @{
 729     /// @name Shader Program
 730     /**
 731      * Return the shader program currently used for this node
 732      * 
 733      * @return The shader program currelty used for this node
 734      */
 735     virtual CCGLProgram* getShaderProgram();
 736     /**
 737      * Sets the shader program for this node
 738      *
 739      * Since v2.0, each rendering node must set its shader program.
 740      * It should be set in initialize phase.
 741      * @code
 742      * node->setShaderProgram(CCShaderCache::sharedShaderCache()->programForKey(kCCShader_PositionTextureColor));
 743      * @endcode
 744      * 
 745      * @param The shader program which fetchs from CCShaderCache.
 746      */
 747     virtual void setShaderProgram(CCGLProgram *pShaderProgram);
 748     /// @} end of Shader Program
 749     
 750     
 751     /**
 752      * Returns a camera object that lets you move the node using a gluLookAt
 753      *
 754      * @code
 755      * CCCamera* camera = node->getCamera();
 756      * camera->setEyeXYZ(0, 0, 415/2);
 757      * camera->setCenterXYZ(0, 0, 0);
 758      * @endcode
 759      *
 760      * @return A CCCamera object that lets you move the node using a gluLookAt
 761      */
 762     virtual CCCamera* getCamera();
 763     
 764     /** 
 765      * Returns whether or not the node accepts event callbacks.
 766      * 
 767      * Running means the node accept event callbacks like onEnter(), onExit(), update()
 768      *
 769      * @return Whether or not the node is running.
 770      */
 771     virtual bool isRunning();
 772 
 773     
 774     /// @{
 775     /// @name Script Bindings for lua
 776 
 777     /**
 778      * Registers a script function that will be called in onEnter() & onExit() seires functions.
 779      * 
 780      * This handler will be removed automatically after onExit() called.
 781      * @code
 782      * -- lua sample
 783      * local function sceneEventHandler(eventType)
 784      *     if eventType == kCCNodeOnEnter then
 785      *         -- do something
 786      *     elseif evetType == kCCNodeOnExit then
 787      *         -- do something
 788      *     end
 789      * end
 790      * scene::registerScriptHandler(sceneEventHandler)
 791      * @endcode
 792      *
 793      * @warning This method is for internal usage, don't call it manually.
 794      * @todo Perhaps we should rename it to get/set/removeScriptHandler acoording to the function name style.
 795      *
 796      * @param handler   A number that indicates a lua function. 
 797      */
 798     virtual void registerScriptHandler(int handler);
 799     /**
 800      * Unregisters a script function that will be called in onEnter() & onExit() series functions.
 801      *
 802      * @see registerScriptHandler(int)
 803      */
 804     virtual void unregisterScriptHandler(void);
 805     /**
 806      * Gets script handler for onEnter/onExit event.
 807      * This is an internal method. g
 808      * @see registerScriptHandler(int)
 809      *
 810      * @return A number that indicates a lua function.
 811      */
 812     inline int getScriptHandler() { return m_nScriptHandler; };
 813     
 814     /** 
 815      * Schedules for lua script. 
 816      * @js NA
 817      */
 818     void scheduleUpdateWithPriorityLua(int nHandler, int priority);
 819     
 820     /// @}  end Script Bindings
 821 
 822 
 823     /// @{
 824     /// @name Event Callbacks
 825     
 826     /** 
 827      * Event callback that is invoked every time when CCNode enters the 'stage'.
 828      * If the CCNode enters the 'stage' with a transition, this event is called when the transition starts.
 829      * During onEnter you can't access a "sister/brother" node.
 830      * If you override onEnter, you shall call its parent's one, e.g., CCNode::onEnter().
 831      * @js NA
 832      * @lua NA
 833      */
 834     virtual void onEnter();
 835 
 836     /** Event callback that is invoked when the CCNode enters in the 'stage'.
 837      * If the CCNode enters the 'stage' with a transition, this event is called when the transition finishes.
 838      * If you override onEnterTransitionDidFinish, you shall call its parent's one, e.g. CCNode::onEnterTransitionDidFinish()
 839      * @js NA
 840      * @lua NA
 841      */
 842     virtual void onEnterTransitionDidFinish();
 843 
 844     /** 
 845      * Event callback that is invoked every time the CCNode leaves the 'stage'.
 846      * If the CCNode leaves the 'stage' with a transition, this event is called when the transition finishes.
 847      * During onExit you can't access a sibling node.
 848      * If you override onExit, you shall call its parent's one, e.g., CCNode::onExit().
 849      * @js NA
 850      * @lua NA
 851      */
 852     virtual void onExit();
 853 
 854     /** 
 855      * Event callback that is called every time the CCNode leaves the 'stage'.
 856      * If the CCNode leaves the 'stage' with a transition, this callback is called when the transition starts.
 857      * @js NA
 858      * @lua NA
 859      */
 860     virtual void onExitTransitionDidStart();
 861 
 862     /// @} end of event callbacks.
 863 
 864 
 865     /** 
 866      * Stops all running actions and schedulers
 867      */
 868     virtual void cleanup(void);
 869 
 870     /** 
 871      * Override this method to draw your own node.
 872      * The following GL states will be enabled by default:
 873      * - glEnableClientState(GL_VERTEX_ARRAY);
 874      * - glEnableClientState(GL_COLOR_ARRAY);
 875      * - glEnableClientState(GL_TEXTURE_COORD_ARRAY);
 876      * - glEnable(GL_TEXTURE_2D);
 877      * AND YOU SHOULD NOT DISABLE THEM AFTER DRAWING YOUR NODE
 878      * But if you enable any other GL state, you should disable it after drawing your node.
 879      */
 880     virtual void draw(void);
 881 
 882     /** 
 883      * Visits this node's children and draw them recursively.
 884      */
 885     virtual void visit(void);
 886 
 887     
 888     /** 
 889      * Returns a "local" axis aligned bounding box of the node.
 890      * The returned box is relative only to its parent.
 891      *
 892      * @note This method returns a temporaty variable, so it can't returns const CCRect&
 893      * @todo Rename to getBoundingBox() in the future versions.
 894      * 
 895      * @return A "local" axis aligned boudning box of the node.
 896      * @js getBoundingBox
 897      */
 898     CCRect boundingBox(void);
 899 
 900     /// @{
 901     /// @name Actions
 902 
 903     /**
 904      * Sets the CCActionManager object that is used by all actions.
 905      *
 906      * @warning If you set a new CCActionManager, then previously created actions will be removed.
 907      *
 908      * @param actionManager     A CCActionManager object that is used by all actions.
 909      */
 910     virtual void setActionManager(CCActionManager* actionManager);
 911     /**
 912      * Gets the CCActionManager object that is used by all actions.
 913      * @see setActionManager(CCActionManager*)
 914      * @return A CCActionManager object.
 915      */
 916     virtual CCActionManager* getActionManager();
 917     
 918     /** 
 919      * Executes an action, and returns the action that is executed.
 920      *
 921      * This node becomes the action's target. Refer to CCAction::getTarget()
 922      * @warning Actions don't retain their target.
 923      *
 924      * @return An Action pointer
 925      */
 926     CCAction* runAction(CCAction* action);
 927 
 928     /** 
 929      * Stops and removes all actions from the running action list .
 930      */
 931     void stopAllActions(void);
 932 
 933     /** 
 934      * Stops and removes an action from the running action list.
 935      *
 936      * @param An action object to be removed.
 937      */
 938     void stopAction(CCAction* action);
 939 
 940     /** 
 941      * Removes an action from the running action list by its tag.
 942      *
 943      * @param A tag that indicates the action to be removed.
 944      */
 945     void stopActionByTag(int tag);
 946 
 947     /** 
 948      * Gets an action from the running action list by its tag.
 949      *
 950      * @see setTag(int), getTag().
 951      *
 952      * @return The action object with the given tag.
 953      */
 954     CCAction* getActionByTag(int tag);
 955 
 956     /** 
 957      * Returns the numbers of actions that are running plus the ones that are schedule to run (actions in actionsToAdd and actions arrays).
 958      *
 959      * Composable actions are counted as 1 action. Example:
 960      *    If you are running 1 Sequence of 7 actions, it will return 1.
 961      *    If you are running 7 Sequences of 2 actions, it will return 7.
 962      * @todo Rename to getNumberOfRunningActions()
 963      *
 964      * @return The number of actions that are running plus the ones that are schedule to run
 965      */
 966     unsigned int numberOfRunningActions(void);
 967 
 968     /// @} end of Actions
 969     
 970     
 971     /// @{
 972     /// @name Scheduler and Timer
 973 
 974     /**
 975      * Sets a CCScheduler object that is used to schedule all "updates" and timers.
 976      *
 977      * @warning If you set a new CCScheduler, then previously created timers/update are going to be removed.
 978      * @param scheduler     A CCShdeduler object that is used to schedule all "update" and timers.
 979      * @js NA
 980      */
 981     virtual void setScheduler(CCScheduler* scheduler);
 982     /**
 983      * Gets a CCSheduler object.
 984      *
 985      * @see setScheduler(CCScheduler*)
 986      * @return A CCScheduler object.
 987      * @js NA
 988      */
 989     virtual CCScheduler* getScheduler();
 990     
 991     /** 
 992      * Checks whether a selector is scheduled.
 993      *
 994      * @param selector      A function selector
 995      * @return Whether the funcion selector is scheduled.
 996      * @js NA
 997      * @lua NA
 998      */
 999     bool isScheduled(SEL_SCHEDULE selector);
1000 
1001     /** 
1002      * Schedules the "update" method. 
1003      *
1004      * It will use the order number 0. This method will be called every frame.
1005      * Scheduled methods with a lower order value will be called before the ones that have a higher order value.
1006      * Only one "update" method could be scheduled per node.
1007      * @lua NA
1008      */
1009     void scheduleUpdate(void);
1010 
1011     /** 
1012      * Schedules the "update" method with a custom priority. 
1013      *
1014      * This selector will be called every frame.
1015      * Scheduled methods with a lower priority will be called before the ones that have a higher value.
1016      * Only one "update" selector could be scheduled per node (You can't have 2 'update' selectors).
1017      * @lua NA
1018      */
1019     void scheduleUpdateWithPriority(int priority);
1020 
1021     /* 
1022      * Unschedules the "update" method.
1023      * @see scheduleUpdate();
1024      */
1025     void unscheduleUpdate(void);
1026 
1027     /**
1028      * Schedules a custom selector.
1029      *
1030      * If the selector is already scheduled, then the interval parameter will be updated without scheduling it again.
1031      * @code
1032      * // firstly, implement a schedule function
1033      * void MyNode::TickMe(float dt);
1034      * // wrap this function into a selector via schedule_selector marco.
1035      * this->schedule(schedule_selector(MyNode::TickMe), 0, 0, 0);
1036      * @endcode
1037      *
1038      * @param interval  Tick interval in seconds. 0 means tick every frame. If interval = 0, it's recommended to use scheduleUpdate() instead.
1039      * @param repeat    The selector will be excuted (repeat + 1) times, you can use kCCRepeatForever for tick infinitely.
1040      * @param delay     The amount of time that the first tick will wait before execution.
1041      * @lua NA
1042      */
1043     void schedule(SEL_SCHEDULE selector, float interval, unsigned int repeat, float delay);
1044     
1045     /**
1046      * Schedules a custom selector with an interval time in seconds.
1047      * @see schedule(SEL_SCHEDULE, float, unsigned int, float)
1048      *
1049      * @param selector      A function wrapped as a selector
1050      * @param interval      Callback interval time in seconds. 0 means tick every frame,
1051      * @lua NA
1052      */
1053     void schedule(SEL_SCHEDULE selector, float interval);
1054     
1055     /**
1056      * Schedules a selector that runs only once, with a delay of 0 or larger
1057      * @see schedule(SEL_SCHEDULE, float, unsigned int, float)
1058      *
1059      * @param selector      A function wrapped as a selector
1060      * @param delay         The amount of time that the first tick will wait before execution.
1061      * @lua NA
1062      */
1063     void scheduleOnce(SEL_SCHEDULE selector, float delay);
1064     
1065     /**
1066      * Schedules a custom selector, the scheduled selector will be ticked every frame
1067      * @see schedule(SEL_SCHEDULE, float, unsigned int, float)
1068      *
1069      * @param selector      A function wrapped as a selector
1070      * @lua NA
1071      */
1072     void schedule(SEL_SCHEDULE selector);
1073     
1074     /** 
1075      * Unschedules a custom selector.
1076      * @see schedule(SEL_SCHEDULE, float, unsigned int, float)
1077      *
1078      * @param selector      A function wrapped as a selector
1079      * @lua NA
1080      */
1081     void unschedule(SEL_SCHEDULE selector);
1082 
1083     /** 
1084      * Unschedule all scheduled selectors: custom selectors, and the 'update' selector.
1085      * Actions are not affected by this method.
1086      */
1087     void unscheduleAllSelectors(void);
1088 
1089     /** 
1090      * Resumes all scheduled selectors and actions.
1091      * This method is called internally by onEnter
1092      * @js NA
1093      * @lua NA
1094      */
1095     void resumeSchedulerAndActions(void);
1096     /** 
1097      * Pauses all scheduled selectors and actions.
1098      * This method is called internally by onExit
1099      * @js NA
1100      * @lua NA
1101      */
1102     void pauseSchedulerAndActions(void);
1103     
1104     /* 
1105      * Update method will be called automatically every frame if "scheduleUpdate" is called, and the node is "live"
1106      */
1107     virtual void update(float delta);
1108 
1109     /// @} end of Scheduler and Timer
1110 
1111     /// @{
1112     /// @name Transformations
1113     
1114     /**
1115      * Performs OpenGL view-matrix transformation based on position, scale, rotation and other attributes.
1116      */
1117     void transform(void);
1118     /**
1119      * Performs OpenGL view-matrix transformation of it's ancestors.
1120      * Generally the ancestors are already transformed, but in certain cases (eg: attaching a FBO)
1121      * It's necessary to transform the ancestors again.
1122      */
1123     void transformAncestors(void);
1124     /**
1125      * Calls children's updateTransform() method recursively.
1126      *
1127      * This method is moved from CCSprite, so it's no longer specific to CCSprite.
1128      * As the result, you apply CCSpriteBatchNode's optimization on your customed CCNode.
1129      * e.g., batchNode->addChild(myCustomNode), while you can only addChild(sprite) before.
1130      */
1131     virtual void updateTransform(void);
1132     
1133     /** 
1134      * Returns the matrix that transform the node's (local) space coordinates into the parent's space coordinates.
1135      * The matrix is in Pixels.
1136      */
1137     virtual CCAffineTransform nodeToParentTransform(void);
1138 
1139     /** 
1140      * Returns the matrix that transform parent's space coordinates to the node's (local) space coordinates.
1141      * The matrix is in Pixels.
1142      */
1143     virtual CCAffineTransform parentToNodeTransform(void);
1144 
1145     /** 
1146      * Returns the world affine transform matrix. The matrix is in Pixels.
1147      */
1148     virtual CCAffineTransform nodeToWorldTransform(void);
1149 
1150     /** 
1151      * Returns the inverse world affine transform matrix. The matrix is in Pixels.
1152      */
1153     virtual CCAffineTransform worldToNodeTransform(void);
1154 
1155     /// @} end of Transformations
1156     
1157     
1158     /// @{
1159     /// @name Coordinate Converters
1160     
1161     /** 
1162      * Converts a Point to node (local) space coordinates. The result is in Points.
1163      */
1164     CCPoint convertToNodeSpace(const CCPoint& worldPoint);
1165     
1166     /** 
1167      * Converts a Point to world space coordinates. The result is in Points.
1168      */
1169     CCPoint convertToWorldSpace(const CCPoint& nodePoint);
1170     
1171     /** 
1172      * Converts a Point to node (local) space coordinates. The result is in Points.
1173      * treating the returned/received node point as anchor relative.
1174      */
1175     CCPoint convertToNodeSpaceAR(const CCPoint& worldPoint);
1176     
1177     /** 
1178      * Converts a local Point to world space coordinates.The result is in Points.
1179      * treating the returned/received node point as anchor relative.
1180      */
1181     CCPoint convertToWorldSpaceAR(const CCPoint& nodePoint);
1182 
1183     /** 
1184      * convenience methods which take a CCTouch instead of CCPoint
1185      */
1186     CCPoint convertTouchToNodeSpace(CCTouch * touch);
1187 
1188     /** 
1189      * converts a CCTouch (world coordinates) into a local coordinate. This method is AR (Anchor Relative).
1190      */
1191     CCPoint convertTouchToNodeSpaceAR(CCTouch * touch);
1192     
1193     /**
1194      *  Sets the additional transform.
1195      *
1196      *  @note The additional transform will be concatenated at the end of nodeToParentTransform.
1197      *        It could be used to simulate `parent-child` relationship between two nodes (e.g. one is in BatchNode, another isn't).
1198      *  @code
1199         // create a batchNode
1200         CCSpriteBatchNode* batch= CCSpriteBatchNode::create("Icon-114.png");
1201         this->addChild(batch);
1202      
1203         // create two sprites, spriteA will be added to batchNode, they are using different textures.
1204         CCSprite* spriteA = CCSprite::createWithTexture(batch->getTexture());
1205         CCSprite* spriteB = CCSprite::create("Icon-72.png");
1206 
1207         batch->addChild(spriteA); 
1208      
1209         // We can't make spriteB as spriteA's child since they use different textures. So just add it to layer.
1210         // But we want to simulate `parent-child` relationship for these two node.
1211         this->addChild(spriteB); 
1212 
1213         //position
1214         spriteA->setPosition(ccp(200, 200));
1215      
1216         // Gets the spriteA's transform.
1217         CCAffineTransform t = spriteA->nodeToParentTransform();
1218      
1219         // Sets the additional transform to spriteB, spriteB's postion will based on its pseudo parent i.e. spriteA.
1220         spriteB->setAdditionalTransform(t);
1221 
1222         //scale
1223         spriteA->setScale(2);
1224      
1225         // Gets the spriteA's transform.
1226         t = spriteA->nodeToParentTransform();
1227      
1228         // Sets the additional transform to spriteB, spriteB's scale will based on its pseudo parent i.e. spriteA.
1229         spriteB->setAdditionalTransform(t);
1230 
1231         //rotation
1232         spriteA->setRotation(20);
1233      
1234         // Gets the spriteA's transform.
1235         t = spriteA->nodeToParentTransform();
1236      
1237         // Sets the additional transform to spriteB, spriteB's rotation will based on its pseudo parent i.e. spriteA.
1238         spriteB->setAdditionalTransform(t);
1239      *  @endcode
1240      */
1241     void setAdditionalTransform(const CCAffineTransform& additionalTransform);
1242     
1243     /// @} end of Coordinate Converters
1244 
1245       /// @{
1246     /// @name component functions
1247     /** 
1248      *   gets a component by its name
1249      */
1250     CCComponent* getComponent(const char *pName) const;
1251     
1252     /** 
1253      *   adds a component
1254      */
1255     virtual bool addComponent(CCComponent *pComponent);
1256     
1257     /** 
1258      *   removes a component by its name      
1259      */
1260     virtual bool removeComponent(const char *pName);
1261     
1262     /**
1263      *   removes all components
1264      */
1265     virtual void removeAllComponents();
1266     /// @} end of component functions
1267 
1268 private:
1269     /// lazy allocs
1270     void childrenAlloc(void);
1271     
1272     /// helper that reorder a child
1273     void insertChild(CCNode* child, int z);
1274     
1275     /// Removes a child, call child->onExit(), do cleanup, remove it from children array.
1276     void detachChild(CCNode *child, bool doCleanup);
1277     
1278     /** Convert cocos2d coordinates to UI windows coordinate.
1279      * @js NA
1280      * @lua NA
1281      */
1282     CCPoint convertToWindowSpace(const CCPoint& nodePoint);
1283 
1284 protected:
1285     float m_fRotationX;                 ///< rotation angle on x-axis
1286     float m_fRotationY;                 ///< rotation angle on y-axis
1287     
1288     float m_fScaleX;                    ///< scaling factor on x-axis
1289     float m_fScaleY;                    ///< scaling factor on y-axis
1290     
1291     float m_fVertexZ;                   ///< OpenGL real Z vertex
1292     
1293     CCPoint m_obPosition;               ///< position of the node
1294     
1295     float m_fSkewX;                     ///< skew angle on x-axis
1296     float m_fSkewY;                     ///< skew angle on y-axis
1297     
1298     CCPoint m_obAnchorPointInPoints;    ///< anchor point in points
1299     CCPoint m_obAnchorPoint;            ///< anchor point normalized (NOT in points)
1300     
1301     CCSize m_obContentSize;             ///< untransformed size of the node
1302     
1303     
1304     CCAffineTransform m_sAdditionalTransform; ///< transform
1305     CCAffineTransform m_sTransform;     ///< transform
1306     CCAffineTransform m_sInverse;       ///< transform
1307     
1308     CCCamera *m_pCamera;                ///< a camera
1309     
1310     CCGridBase *m_pGrid;                ///< a grid
1311     
1312     int m_nZOrder;                      ///< z-order value that affects the draw order
1313     
1314     CCArray *m_pChildren;               ///< array of children nodes
1315     CCNode *m_pParent;                  ///< weak reference to parent node
1316     
1317     int m_nTag;                         ///< a tag. Can be any number you assigned just to identify this node
1318     
1319     void *m_pUserData;                  ///< A user assingned void pointer, Can be point to any cpp object
1320     CCObject *m_pUserObject;            ///< A user assigned CCObject
1321     
1322     CCGLProgram *m_pShaderProgram;      ///< OpenGL shader
1323     
1324     ccGLServerState m_eGLServerState;   ///< OpenGL servier side state
1325     
1326     unsigned int m_uOrderOfArrival;     ///< used to preserve sequence while sorting children with the same zOrder
1327     
1328     CCScheduler *m_pScheduler;          ///< scheduler used to schedule timers and updates
1329     
1330     CCActionManager *m_pActionManager;  ///< a pointer to ActionManager singleton, which is used to handle all the actions
1331     
1332     bool m_bRunning;                    ///< is running
1333     
1334     bool m_bTransformDirty;             ///< transform dirty flag
1335     bool m_bInverseDirty;               ///< transform dirty flag
1336     bool m_bAdditionalTransformDirty;   ///< The flag to check whether the additional transform is dirty
1337     bool m_bVisible;                    ///< is this node visible
1338     
1339     bool m_bIgnoreAnchorPointForPosition; ///< true if the Anchor Point will be (0,0) when you position the CCNode, false otherwise.
1340                                           ///< Used by CCLayer and CCScene.
1341     
1342     bool m_bReorderChildDirty;          ///< children order dirty flag
1343     
1344     int m_nScriptHandler;               ///< script handler for onEnter() & onExit(), used in Javascript binding and Lua binding.
1345     int m_nUpdateScriptHandler;         ///< script handler for update() callback per frame, which is invoked from lua & javascript.
1346     ccScriptType m_eScriptType;         ///< type of script binding, lua or javascript
1347     
1348     CCComponentContainer *m_pComponentContainer;        ///< Dictionary of components
1349 
1350 };
1351 
1352 CCNode.h

  在Cocos2d-x中,存在兩種座標系。

  繪圖座標系。它是最多見的座標系,與OpenGL採用的座標系相同,以左下角爲原點,向右爲x軸正方向,向上爲y軸正方向。在Cocos2d-x中,一切繪圖相關的操做都使用繪圖座標系,如遊戲元素中的Position和AnchorPoint等屬性。

  紋理座標系。紋理座標系以左上角爲原點,向右爲x軸正方向,向下爲y軸正方向,如圖3-2所示。在Cocos2d-x中,只有從紋理中截取部分矩形時才使用這個座標系,如CCSprite的TextureRect屬性。

  CCRect ContentSize:獲取或設置此節點的內容大小。任何一個節點都須要肯定它的內容大小,以便進行圖形變換。對於精靈來講,ContentSize是它的紋理顯示部分的大小;對於層或場景等全屏的大型節點來講,ContentSize則是屏幕大小。

  CCPoint AnchorPoint與CCPoint Position:AnchorPoint用於設置一個錨點,以便精確地控制節點的位置和變換。AnchorPoint的兩個參量x和y的取值一般都是0到1之間的實數,表示錨點相對於節點長寬的位置。例如,把節點左下角做爲錨點,值爲(0,0);把節點的中心做爲錨點,值爲(0.5,0.5);把節點右下角做爲錨點,值爲(1,0)。精靈的AnchorPoint默認值爲(0.5,0.5),其餘節點的默認值爲(0,0)。

  Position用於設置節點的位置。因爲Position指的是錨點在父節點中的座標值,節點顯示的位置一般與錨點有關。所以,若是層與場景保持默認的位置,只需把層中精靈位置設爲窗口長寬的一半便可讓它顯示在屏幕中央。

  對於場景或層等大型節點,它們的IgnoreAnchorPointForPosition屬性爲true,此時引擎會認爲AnchorPoint永遠爲(0,0);而其餘節點的該屬性爲flase,它們的錨點不會被忽略。

  int Tag:獲取或設置節點的標號。在Cocos2d-x中,Tag的做用相似於標識符,以便快速地從節點的全部子節點中找出所需節點。Tag能夠用於定位子節點,所以添加到同一節點的全部CCNode之中,不能有兩個節點的Tag相同,不然就給定位帶來了麻煩。與Tag相關的方法有getChildByTag、removeChildByTag等。

  

  定時器事件

  定時器是以必定時間間隔連續引起遊戲事件的工具。。Cocos2d-x爲咱們提供了兩種方式實現定時機制--使用update方法以及使用schedule方法。

  第一種定時機制是CCNode的刷新事件update方法,該方法在每幀繪製以前都會被觸發一次。因爲繪圖幀率有限,而每次更新最終會反映到畫面上,因此在每幀之間刷新一次已經足夠應付大部分遊戲邏輯處理的要求了。CCNode默認並無啓用update事件,爲了啓用定時器,咱們須要調用scheduleUpdate方法,並重載update以執行本身的代碼。對應地,咱們可使用unscheduleUpdate方法中止定時器。

  另外一種定時機制是CCNode提供的schedule方法,能夠實現以必定的時間間隔連續調用某個函數。因爲引擎的調度機制,這裏的時間間隔必須大於兩幀的間隔,不然兩幀期間的屢次調用會被合併成一次調用。

  因爲Cocos2d-x的調度是純粹的串行機制,所以全部函數都運行在同一個線程,不會存在並行程序的種種麻煩。

  CCNode中與定時器相關的方法

方法 描述
isScheduled(SEL_SCHEDULE selector)

返回一個值,表示selector對應的函數是否已被添加爲定時器

scheduleUpdate 啓用update定時器
scheduleUpdateWithPriority(int priority) 啓用update定時器,並設定定時器的優先級
unscheduleUpdate 取消update定時器

schedule(SEL_SCHEDULE selector,
float interval,unsigned int  repeat,

float delay)

添加一個schedule定時器,其中selector
參數爲定時器的事件函數,interval參
數爲定時器的時間間隔,repeat參數爲定
時事件觸發一次後還會再次觸發
的次數(默認值爲kCCRepeatForever,
表示觸發無窮屢次),delay爲第一次觸
發事件前的延時。此處時間都以秒爲單位

scheduleOnce(SEL_SCHEDULE selector,

float delay)

添加一個schedule定時器,但定時器只觸發一次
unschedule(SEL_SCHEDULE selector) 取消selector所對應函數的定時器
unscheduleAllSelectors 取消此節點所關聯的所有定時器
pauseSchedulerAndActions 暫停此節點所關聯的所有定時器與動做
resumeSchedulerAndActions 繼續執行此節點所關聯的定時器與動做
onEnter() 當此節點所在場景即將呈現時,會調用此方法
onEnterTransitionDidFinish()

當此節點所在場景的入場動做結束後,會調用此方法。若是所在場景沒有入場動做,則此方法會緊接着onEnter()後被調用

onExit() 當此節點所在場景即將退出時,會調用此方法
onExitTransitionDidStart()

當此節點所在場景的出場動做結束後,會調用此方法。若是所在場景沒有出場動做,則此方法會緊接着onExit()後被調用

  

  Cocos2d-x內置的經常使用層

  爲了方便遊戲開發者,Cocos2d-x內置了3種特殊的CCLayer。CCLayerColor:一個單純的實心色塊。CCLayerGradient:一個色塊,但能夠設置兩種顏色的漸變效果。CCMenu:十分經常使用的遊戲菜單。

  CCLayerColor擁有如下初始化方法:若是採用指定了寬與高的初始化方法,則建立一個指定大小的色塊;若是採用不指定大小的初始化方法,則建立一個屏幕大小的色塊。CCLayerColor的建立方法和初始化方法以下所示:

  static CCLayerColor * create(const ccColor4B& color);

  static CCLayerColor * create(const ccColor4B& color, GLfloat width, GLfloat height);
  bool initWithColor(const ccColor4B& color);
  bool initWithColor(const ccColor4B& color, GLfloat width, GLfloat height);
  CCLayerGradient與CCLayerColor相似,可是它在初始化時須要指定兩種顏色以及漸變的方向。在初始化方法中,start參數爲起始顏色,end參數爲結束顏色,而v是方向向量。CCLayerGradient的建立方法和初始化方法以下所示:
  static CCLayerGradient* create(const ccColor4B& start, const ccColor4B& end);
  static CCLayerGradient* create(const ccColor4B& start, const ccColor4B& end, const CCPoint& v);
  bool initWithColor(const ccColor4B& start, const ccColor4B& end);
  bool initWithColor(const ccColor4B& start, const ccColor4B& end, const CCPoint& v);
  在色塊建立後,也能夠經過下面列舉的方法來修改色塊大小:
  void changeWidth(GLfloat w);
  void changeHeight(GLfloat h);
  void changeWidthAndHeight(GLfloat w ,GLfloat h);

 

  

  CCMenu:遊戲菜單  菜單是遊戲不可或缺的一部分。在Cocos2d-x中,菜單由兩部分組成,分別是菜單項和菜單自己。CCMenuItem表示一個菜單項,每一個菜單項都是一個獨立的按鈕,定義了菜單的視覺表現和響應動做;CCMenu則是菜單,它負責將菜單項組織到一塊兒並添加到場景中,轉換屏幕的觸摸事件到各個菜單項。  CCMenuItemImage::create(    "CloseNormal.png", //普通狀態下的圖片    "CloseSelected.png", //按下狀態下的圖片    this, //響應對象    menu_selector(HelloWorld::menuCloseCallback)); //響應函數  其中響應函數必須知足SEL_MenuHandler形式:返回值爲空,帶一個CCNode*型的參數。

相關文章
相關標籤/搜索