在官方网站上,对cocos2d所提供的动作(action)转化(Transformations)以及效果(effect)做了如下分类
- Basic actions
- Composition actions
- Ease actions
- Effect actions
- Special actions
- Animation
下面将对我使用过的类及方法做一个说明,随着本人实际使用的情况会不断补充内容。
这一篇先介绍Basic Action,包含了基本的移动,旋转,淡入淡出等动作。
用来移动精灵,使用方法如下(以CCMoveBy为例):
- CCSprite* sprite = [CCSprite spriteWithFile:@"sprit.png"];
- CCMoveBy* moveby = [CCMoveBy actionWithDuration:1.0f position:ccp(100, 50)];
- [sprite runAction:moveby];
参数actionWithDuration是指执行动作所花的时间,单位是秒,当然你自己写的时候也可以采用计算获得,本例力求简单,所以直接写了 "1.0f" 意思是一秒钟。
第二个参数 position,意思就是移动的位置。
CCMoveBy 和 CCMoveTo的区别是,By 是相对坐标,如上例,位置参数是ccp(100,50),意思就是说,向右移动100个单位,向上移动50个单位;如果换成To的类,那么就是移动到坐标 (100,50)位置。
其实你会看到很多类似的 用 To 和 By 来区分的类,都是 “绝对” 和 “相对” 的区别。
用来产生跳跃效果,个人感觉如果要产生逼真的跳跃效果,下面是示例。
- CCSprite* sprite = [CCSprite spriteWithFile:@"sprit.png"];
- CCJumpBy* jump = [CCJumpBy actionWithDuration:1.0f position:cpp(80,0) height:20 jumps:1];
- [sprite runAction:jump];
这里要说一下的参数是height和jump。
height,其实就是跳跃的高度,当时让我比较困惑的是 xcode提示这个参数的类型是ccTime,不知道是不是失误,总之不要去在意他的类型,我的感觉它和position的单位是一致的。
jump,是整形,意思是跳跃几次。
这个跟移动很像,只是这个是按设定的曲线移动的。Bezier 中文翻译叫贝赛尔曲线或是贝兹曲线,关于这种曲线可以参考维基百科的内容。
简单的来说,就是你设定三个点,然后它会计算出一条曲线通过这三个点,然后精灵就会按照这个曲线运动。示例如下:
- CCSprite* sprite = [CCSprite spriteWithFile:@"sprit.png"];
- ccBezierConfig bezier;
- bezier.controlPoint_1 = ccp(100,200 );
- bezier.controlPoint_2 = ccp(200, -100);
- bezier.endPosition = ccp(400,100);
- CCBezierBy* bez = [CCBezierBy actionWithDuration:5.0f bezier:bezier];
- [sprite runAction:bez];
CCRotateBy, CCRotateTo
用于旋转精灵,以度为单位,示例:
- CCSprite* sprite = [CCSprite spriteWithFile:@"sprit.png"];
- CCRotateBy* rotate = [CCRotateBy actionWithDuration:1.0f angle:360];
- [sprite runAction:rotate];
CCBlink
实现闪烁效果,示例如下:
- CCSprite* sprite = [CCSprite spriteWithFile:@"sprit.png"];
- CCBlink* blink = [CCBlink actionWithDuration:1 blinks:5];
- [sprite runAction:blink];
- actionWithDuration:像往常一样,是以秒为单位,意思是闪烁几秒钟。
- blinks: 是闪烁的次数。
上面这个例子的意思就是,在一秒钟内闪烁5次。
CCFadeIn,CCFadeOut, CCFadeTo
这三个是用来调整 透明度的,可以实现淡入,淡出效果,CCFadeTo用来调整到指定的透明度。
- CCSprite* sprite = [CCSprite spriteWithFile:@"sprit.png"];
- CCFadeOut* fade =[CCFadeOut actionWithDuration:1.0f];
- [sprite runAction:fade];
上面是淡出效果,淡入类似。
- CCSprite* sprite = [CCSprite spriteWithFile:@"sprit.png"];
- CCFadeTo* fadeto =[CCFadeTo actionWithDuration:1.0f opacity:100];
- [sprite runAction:fadeto];
CCFadeTo 相比前两个多了一个指定透明度的参数 opacity,这个参数的类型是GLubyte,值的范围是 0~255, 0 是完全透明, 255是完全不透明。
Reverse Action
几乎所有的动作都实现了 reverse 方法,这个方法用来反转动作,示例如下:
- id move = [CCMoveBy actionWithDuration:2 position: ccp(80,80)];
- id move_reverse = [move reverse];
上面这个例子就是,首先创建了一个 动作 “move”, 在两秒钟之内向右移动80, 同时向上方移动80。而 move_reverse 将动作反转,即,向左及向下移动80。
我个人经常在 CCSequence中使用,比如用来实现摆动,再reverse一下摆动回来。这样就不需要再定义一个新的动作了。
分享到:
相关推荐
首先,我们需要了解Cocos2d::ActionManager类,它是Cocos2D-X中的核心组件之一,负责存储和执行所有已创建的动作。每个动作实例都是一个Cocos2d::Action对象,当调用其runWithTarget()方法时,该动作会被添加到...
在cocos2d-x游戏开发框架中,动作(Actions)是一个关键的概念,它允许开发者创建丰富的动画效果,使游戏中的对象具有动态性。本学习笔记将深入探讨cocos2d-x中的动作系统,帮助你更好地理解和应用这些功能。 1. **...
在iOS游戏开发中,Cocos2d-x是一个广泛使用的2D游戏引擎,它为开发者提供了丰富的功能和便利的API。本篇文章将深入探讨Cocos2d-iPhone中的“动作(Actions)”和“组合动作(Composite Actions)”,帮助你更好地...
少儿编程scratch项目源代码文件案例素材-直升机飞行.zip
wanjunshe_Python-Tensorflow_12888_1745868924470
健康监测_Android开发_BLE蓝牙通信_心率数据采集与存储_基于小米手环2的实时心率监测应用_支持后台长时间运行的心率记录工具_可导出SQLite数据库的心率数据分析系统_适
少儿编程scratch项目源代码文件案例素材-种花模拟器.zip
嵌入式系统开发_FreeRTOS实时操作系统_STM32F103C8T6微控制器_OLED显示屏_DHT11温湿度传感器_多任务调度_多级菜单设计_万年历算法_电子闹钟功能_参数配
基于python实现的粒子群的VRP(车辆配送路径规划)问题建模求解+源码+项目文档+算法解析,适合毕业设计、课程设计、项目开发。项目源码已经过严格测试,可以放心参考并在此基础上延申使用,详情见md文档 算法设计的关键在于如何向表现较好的个体学习,标准粒子群算法引入惯性因子w、自我认知因子c1、社会认知因子c2分别作为自身、当代最优解和历史最优解的权重,指导粒子速度和位置的更新,这在求解函数极值问题时比较容易实现,而在VRP问题上,速度位置的更新则难以直接采用加权的方式进行,一个常见的方法是采用基于遗传算法交叉算子的混合型粒子群算法进行求解,这里采用顺序交叉算子,对惯性因子w、自我认知因子c1、社会认知因子c2则以w/(w+c1+c2),c1/(w+c1+c2),c2/(w+c1+c2)的概率接受粒子本身、当前最优解、全局最优解交叉的父代之一(即按概率选择其中一个作为父代,不加权)。 算法设计的关键在于如何向表现较好的个体学习,标准粒子群算法引入惯性因子w、自我认知因子c1、社会认知因子c2分别作为自身、当代最优解和历史最优解的权重,指导粒子速度和位置的更新,这在求解函数极值问题时比较容易实现,而在VRP问题上,速度位置的更新则难以直接采用加权的方式进行,一个常见的方法是采用基于遗传算法交叉算子的混合型粒子群算法进行求解,这里采用顺序交叉算子,对惯性因子w、自我认知因子c1、社会认知因子c2则以w/(w+c1+c2),c1/(w+c1+c2),c2/(w+c1+c2)的概率接受粒子本身、当前最优解、全局最优解交叉的父代之一(即按概率选择其中一个作为父代,不加权)。
scratch少儿编程逻辑思维游戏源码-猫猫粉碎.zip
scratch少儿编程逻辑思维游戏源码-蓝胡子.zip
scratch少儿编程逻辑思维游戏源码-美食大亨.zip
scratch少儿编程逻辑思维游戏源码-洛克人.zip
scratch少儿编程逻辑思维游戏源码-龙冲刺.zip
思幻个人引导页V2.2版本11月29日更新.zip
scratch少儿编程逻辑思维游戏源码-骑士风斩法.zip
移动应用开发_H5CSS3ionicng-cordovaMVVM模式_基于HTML5和CSS3技术实现多页面布局ionic指令数据绑定ui-route单页跳转调用手机
少儿编程scratch项目源代码文件案例素材-植物大战僵尸创造版 Ver. 1.0.3.zip
scratch少儿编程逻辑思维游戏源码-日落(2).zip
动态星空背景个人主页(带后台).zip