cocos2dx进阶学习之CCNode
继承关系
CCNode -> CCObject
CCNode在cocos2dx中抽象舞台对象,需要渲染的对象都是从CCNode派生,包括CCScene,CCLayer,CCSprite等等
CCNode提供包容关系管理
成员函数
virtual bool init();
static CCNode * create(void);
创建和初始化接口,create函数会自动调用autorelease
virtual void setZOrder(int zOrder);
virtual void _setZOrder(int z);
virtual int getZOrder();
ZOrder相关设置,ZOrder是指在Z轴方向的顺序,指示对象的覆盖关系,其中_setZOrder只是改变本对象的成员函数,setZOrder除了改变本对象成员,还会调用父节点相关函数改变该对象在父对象中的位置
virtual void setVertexZ(float vertexZ);
virtual float getVertexZ();
设置OpenGZ的z向量,这个可能会破坏cocos2dx的ZOrder关系
virtual void setScaleX(float fScaleX);
virtual float getScaleX();
virtual void setScaleY(float fScaleY);
virtual float getScaleY();
virtual void setScale(float scale);
virtual float getScale();
virtual void setScale(float fScaleX,float fScaleY);
设置缩放因子
virtual void setPosition(const CCPoint &position);
virtual const CCPoint& getPosition();
virtual void setPosition(float x, float y);
virtual void getPosition(float* x, float* y);
virtual void setPositionX(float x);
virtual float getPositionX(void);
virtual void setPositionY(float y);
virtual float getPositionY(void);
设置位置,这个位置基于父对象坐标
virtual void setSkewX(float fSkewX);
virtual float getSkewX();
virtual void setSkewY(float fSkewY);
virtual float getSkewY();
设置翻转
virtual void setAnchorPoint(const CCPoint& anchorPoint);
virtual const CCPoint& getAnchorPoint();
设置锚点,锚点是指设置点相对于自己的坐标点,这里anchorPoint是一个比例值,默认一般(0.5,0.5)
virtual void setContentSize(const CCSize& contentSize);
virtual const CCSize& getContentSize() const;
设置未转换的节点尺寸,所有的node都有尺寸,Scene和Layer的尺寸与屏幕相同
virtual void setVisible(bool visible);
virtual bool isVisible();
设置是否显示
virtual void setRotation(float fRotation);
virtual float getRotation();
virtual void setRotationX(float fRotaionX);
virtual float getRotationX();
virtual void setRotationY(float fRotationY);
virtual float getRotationY();
设置旋转角度
virtual void setOrderOfArrival(unsigned int uOrderOfArrival);
virtual unsigned int getOrderOfArrival();
设置arrival order,当两个node有相同的zorder时,按照arrival order次序来绘画
virtual void addChild(CCNode * child);
virtual void addChild(CCNode * child, int zOrder);
virtual void addChild(CCNode* child, int zOrder, int tag);
增加子节点,可以在增加子节点时,设定zOrder和tag
CCNode * getChildByTag(int tag);
virtual CCArray* getChildren();
virtual void setParent(CCNode* parent);
unsigned int getChildrenCount(void) const;
virtual CCNode* getParent();
父子关系管理
virtual void removeFromParent();
virtual void removeFromParentAndCleanup(bool cleanup);
virtual void removeChild(CCNode* child);
virtual void removeChild(CCNode* child, bool cleanup);
virtual void removeChildByTag(int tag);
virtual void removeChildByTag(int tag, bool cleanup);
virtual void removeAllChildren();
virtual void removeAllChildrenWithCleanup(bool cleanup);
节点父子关系解除
virtual void reorderChild(CCNode * child, int zOrder);
virtual void sortAllChildren();
子节点排序
virtual CCGridBase* getGrid();
virtual void setGrid(CCGridBase *pGrid);
设置格子,用于格子动画,那是另外一个专题了
virtual int getTag() const;
virtual void setTag(int nTag);
设置标签,每个node可以有一个标签,用于标示这个节点
virtual void* getUserData();
virtual void setUserData(void *pUserData);
每个node可以设置void*的自定义数据,这个数据可以用来关联其他系统,比如物理系统对象
virtual CCObject* getUserObject();
virtual void setUserObject(CCObject *pUserObject);
设置关联的对象,和UserData类似,只是指针类型不同
virtual CCGLProgram* getShaderProgram();
virtual void setShaderProgram(CCGLProgram *pShaderProgram);
设置着色器
virtual CCCamera* getCamera();
获取照相机对象
virtual bool isRunning();
是否在运行,运行的意思是节点接受事件回调函数,如OnEnter, OnExit, update等
virtual void registerScriptHandler(int handler);
virtual void unregisterScriptHandler(void);
inline int getScriptHandler() { return m_nScriptHandler; };
注册lua函数处理OnEnter,OnExit
void scheduleUpdateWithPriorityLua(int nHandler, int priority);
定时回调lua脚本函数
virtual void onEnter();
virtual void onEnterTransitionDidFinish();
virtual void onExit();
virtual void onExitTransitionDidStart();
进入和退出Scene的回调函数,onEnterTransitionDidFinish是在场景切换有动画时,动画结束后的回调,onExitTransitionDidStart类似
virtual void cleanup(void);
停止所有的schedule和actions
virtual void draw(void);
绘制node
virtual void visit(void);
绘制所有儿子节点
CCRect boundingBox(void);
获取节点矩形,该矩形的坐标基于父节点
virtual void setActionManager(CCActionManager* actionManager);
virtual CCActionManager* getActionManager();
设置Action管理器,动画管理器管理这个node的所有动画
CCAction* runAction(CCAction* action);
让node执行动作,这个node也成了action的target,通过action->getTarget可以获取这个node
注意action并没有增加node的内存计数器
void stopAllActions(void);
void stopAction(CCAction* action);
void stopActionByTag(int tag);
停止action
CCAction* getActionByTag(int tag);
获取action
unsigned int numberOfRunningActions(void);
返回正在运行的action个数
virtual void setScheduler(CCScheduler* scheduler);
virtual CCScheduler* getScheduler();
设置调度器
bool isScheduled(SEL_SCHEDULE selector);
检查函数selector是否被调度
void scheduleUpdate(void);
调度update函数
void scheduleUpdateWithPriority(int priority);
有优先级的调度,priority越小,越先被调度
void unscheduleUpdate(void);
取消调度
void schedule(SEL_SCHEDULE selector, float interval, unsigned int repeat, float delay);
void schedule(SEL_SCHEDULE selector, float interval);
void scheduleOnce(SEL_SCHEDULE selector, float delay);
void schedule(SEL_SCHEDULE selector);
void unschedule(SEL_SCHEDULE selector);
void unscheduleAllSelectors(void);
定时调度,delay是多少时间后,interval是两次调度之间间隔多少时间,repeat是重复次数
void resumeSchedulerAndActions(void);
void pauseSchedulerAndActions(void);
调度的暂停和继续
virtual void update(float delta);
可重载的update函数
void transform(void);
void transformAncestors(void);
virtual void updateTransform(void);
virtual CCAffineTransform nodeToParentTransform(void);
virtual CCAffineTransform parentToNodeTransform(void);
virtual CCAffineTransform nodeToWorldTransform(void);
virtual CCAffineTransform worldToNodeTransform(void);
void setAdditionalTransform(const CCAffineTransform& additionalTransform);
OpenGL的矩阵坐标转换
CCPoint convertToNodeSpace(const CCPoint& worldPoint);
CCPoint convertToWorldSpace(const CCPoint& nodePoint);
CCPoint convertToNodeSpaceAR(const CCPoint& worldPoint);
CCPoint convertToWorldSpaceAR(const CCPoint& nodePoint);
坐标转换,从世界坐标转到本地坐标(节点坐标),AR结尾序列式转化时以锚点为原点
CCPoint convertTouchToNodeSpace(CCTouch * touch);
CCPoint convertTouchToNodeSpaceAR(CCTouch * touch);
将CCTouch转换成节点坐标
CCComponent* getComponent(const char *pName) const;
virtual bool addComponent(CCComponent *pComponent);
virtual bool removeComponent(const char *pName);
virtual void removeAllComponents();
组件管理,类似userData,但是组件可以增加很多
cocos2dx进阶学习之CCNode的更多相关文章
- cocos2dx进阶学习之CCScene
继承关系 CCScene -> CCNode -> CCObject CCScene抽象了一个场景的概念,类似舞台的一幕 函数 static CCScene *create(void); ...
- cocos2dx进阶学习之CCAction
CCAction在cocos2dx中,抽象了节点的动作.它由CCObject派生,因此它不是渲染节点. 它经常的用法是,创建一个action,然后让某个CCNode对象(一般是精灵),去执行它. 在马 ...
- cocos2dx进阶学习之CCTMXTiledMap
继承关系 CCTMXTiledMap -> CCNode 它由CCNode派生,我们已经知道CCNode是cocos2dx的舞台对象的公共父类,所以CCTMXTiledMap也是个舞台对象 成员 ...
- cocos2dx进阶学习之场景切换
背景 在学习马里奥时,我们学习到从菜单场景到游戏场景的切换,代码如下 void CMMenuScene::OnStartCallBack( CCObject *pSender ) { CCDirect ...
- cocos2dx进阶学习之CCSprite
继承关系 CCSprite -> CCNodeRGBA -> CCNode, CCRGBAProtocol CCTextureProtocol 从继承关系可以看出,CCSp ...
- cocos2dx进阶学习之CCLayer
继承关系 CCLayer -> CCNode,CCTouchDelegate,CCAccelerometerDelegate,CCKeypadDelegate CCLayer在cocos2dx中 ...
- cocos2dx进阶学习之坐标转换
在cocos2dx中,有四种坐标系 GL坐标系:左下为原点,x轴向右,y轴向上 UI坐标系:左上为原点,x轴向右,y轴向下 世界坐标系:与GL坐标系相同 本地坐标系:是节点(CCNode)的坐标系,原 ...
- cocos2dx进阶学习之CCDirector
继承关系 CCDirecotor -> CCObject, TypeInfo 处理主窗口消息,管理何时.何种方式执行场景. 经常被翻译成导演,负责管理整个游戏的进程推动和周边支持. 成员 inl ...
- cocos2dx进阶学习之屏幕适配
背景 在学习cocos2dx时,我们在main函数中发现一句代码, #include "main.h" #include "AppDelegate.h" #in ...
随机推荐
- java.lang.NoClassDefFoundError: javax/servlet/AsyncContext
报错:java.lang.NoClassDefFoundError: javax/servlet/AsyncContext 我认为你需要在Servlet API,而不是2.5.AsyncContext ...
- iOS设计模式——单例模式
单例模式用于当一个类只能有一个实例的时候, 通常情况下这个“单例”代表的是某一个物理设备比如打印机,或是某种不可以有多个实例同时存在的虚拟资源或是系统属性比如一个程序的某个引擎或是数据.用单例模式加以 ...
- C++内联函数、函数模板之于头文件
一.基本说明 C++标准中提到,一个编译单元是指一个.cpp文件以及它所include的所有.h文件,.h文件里的代码将会被扩展到包含它的.cpp文件里,然后编译器编译该.cpp文件为一个.obj文件 ...
- mysql 本机root密码忘记
1.找到对应的my.conf,在mysqld节点添加:skip-grant-tables 2.重启mysql 即可无密登录 3.update user表中的密码后,去除skip-grant-tabl ...
- 【转载】python 模块 - random生成随机数模块
随机数种子 要每次产生随机数相同就要设置种子,相同种子数的Random对象,相同次数生成的随机数字是完全相同的: random.seed(1) 这样random.randint(0,6, (4,5)) ...
- 利用python进行数据分析之数据规整化
数据分析和建模大部分时间都用在数据准备上,数据的准备过程包括:加载,清理,转换与重塑. 合并数据集 pandas对象中的数据可以通过一些内置方法来进行合并: pandas.merge可根据一个或多个键 ...
- Tomcat+redis+nginx配置
为客户开发的一个绩效系统,采用了java web的开发方式,使用了一些spring mvc, mybatis之类的框架.相比于oracle ebs的二次开发,这种开发更加灵活,虽然和ebs集成的时候遇 ...
- BZOJ 1089 严格n元树 (递推+高精度)
题解:用a[i]表<=i时有几种树满足度数要求,那么这样就可以递归了,a[i]=a[i-1]^n+1.n个节点每个有a[i-1]种情况,那么将其相乘,最后加上1,因为深度为0也算一种.那么答案就 ...
- hdu 4738 (双联通求桥)
2013 ACM/ICPC Asia Regional Hangzhou Online 题目大意:有n个岛,曹操在一些岛之间建了一些桥,每个桥上有一些士兵把守,周瑜只有一个炸弹只能炸掉一个桥,炸弹需要 ...
- hdu1281结题报告
哎哎...自己刚刚一看到这个题目居然.....什么都想不到...看了一下别人的解题报告说最大匹配...于是就自己开始构思啦... 对于这个棋盘,有K个可以放棋子的位置....那么 首先我们开始可以求出 ...