在官方网站上,对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-iPhone的延时动作是构建复杂游戏动画的关键组成部分,它可以与其它动作结合,实现丰富的动态效果。通过理解并熟练运用动作系统,开发者能够创建出引人入胜的iOS游戏体验。在实际项目中,开发者应根据...
该资源主要用于cocos2d-x中Value与json字符串的相互转换,提供从json文件读取为cocos2d::Value,cocos2d::Value写入到文件,cocos2d::Value转换为json字符串,json字符串转换为cocos2d::Value。json字符串转换成cocos...
在本篇【Cocos2D游戏之旅(四):卡牌翻转效果的实现(下)】中,我们将深入探讨如何在Cocos2D游戏引擎中实现引人入胜的卡牌翻转特效。Cocos2D是一款强大的2D游戏开发框架,广泛应用于iOS、Android以及Windows等平台...
资源名称:Cocos2d-x实战:JS卷——Cocos2d-JS开发内容简介:本书是介绍Cocos2d-x游戏编程和开发技术书籍,介绍了使用Cocos2d-JS中核心类、瓦片地图、物理引擎、音乐音效、数据持久化、网络通信、性能优化、多平台...
cocos2d::Scene* HelloWorld::createScene() { auto scene = Scene::create(); auto layer = HelloWorld::create(); scene->addChild(layer); return scene; } ``` 在层中添加精灵: ```cpp Sprite* Hello...
本主题主要关注Cocos2d-iPhone中的“动作”(Actions)机制,这是一个强大的工具,用于创建各种动画效果和游戏逻辑。在Cocos2d-iPhone中,动作是类的实例,它们可以控制节点(Nodes)的行为,如改变位置、旋转、缩放...
3. **动作(Actions)与效果**:Cocos2d-x的动作系统允许开发者对游戏对象施加各种效果,如移动、旋转、缩放、淡入淡出等,实现丰富的视觉表现。 4. **物理引擎集成**:可能包含Box2D或Chipmunk等物理引擎的集成,...
首先,我们需要了解Cocos2d::ActionManager类,它是Cocos2D-X中的核心组件之一,负责存储和执行所有已创建的动作。每个动作实例都是一个Cocos2d::Action对象,当调用其runWithTarget()方法时,该动作会被添加到...
总结,通过cocos2d-lua和OpenGL的结合,我们可以轻松创建出引人入胜的3D扑克翻牌特效。从建模到动画,再到交互设计,每一个步骤都需要细心打磨,才能打造出既美观又流畅的游戏体验。在实际开发中,开发者应不断学习...
《Cocos2d-JS开发之旅:从HTML5到原生手机游戏》是一本深入探讨Cocos2d-JS框架的书籍,旨在帮助开发者从Web前端的HTML5技术过渡到跨平台的原生手机游戏开发。Cocos2d-JS是Cocos2d-x引擎的一个分支,它结合了...
此外,cocos2d-x的事件系统也是其核心特性之一。它允许开发者方便地处理触摸、键盘、鼠标等各种输入事件,构建出响应性强的交互界面。同时,它的动作(Actions)和动画(Animations)系统,让开发者能够轻松实现复杂...
总结来说,COCOS2D实现弹球效果涉及的主要知识点有:物理引擎(Box2D)、碰撞检测、动画制作、用户交互以及资源管理。理解并熟练掌握这些知识点,将有助于开发者构建出具有高质量弹球效果的游戏。在实际项目中,还...
在Cocos2D-X中,动作(Actions)是游戏对象行为的核心组成部分,它们可以改变节点的位置、旋转、缩放、透明度等多种属性,甚至实现复杂的动画效果。本文主要围绕Cocos2D-X中的基础动作类的使用进行深入探讨。 一、...
总结,cocos2d_lua提供的3D功能使得实现搓牌效果成为可能。通过结合3D模型、纹理、动画和Lua脚本,我们可以创造出逼真的搓牌体验。在实际开发中,还需要考虑到性能优化和项目集成,以确保游戏的整体质量和用户体验。...
《Cocos2d-x实战 JS卷》是一本深入探讨Cocos2d-x游戏开发的专著,主要聚焦于使用JavaScript语言进行游戏编程。Cocos2d-x是一个开源的游戏开发框架,广泛应用于移动设备和桌面平台,支持iOS、Android、Windows等多...
此外,Cocos2d-iPhone还提供了许多其他高级动作,如Ease动作(用于缓动效果),Sequence动作(按顺序执行多个动作),以及Spawn动作(同时执行多个动作)。这些工具使得游戏开发者能够创造出丰富的视觉效果和动态...
在Cocos2d-x 3.10这个流行的2D游戏开发框架中,实现翻页和翻牌效果是一项常见的需求,特别是在制作卡片游戏或者互动UI时。这些效果为游戏增添了生动性和趣味性,使得用户体验更加丰富。下面我们将深入探讨如何在...
Cocos2d是一个开源的游戏开发框架,被广泛用于创建2D游戏、演示程序和其他图形交互应用。在Android平台上,cocos2d-x是其主要实现,而“cocos2d-android-1”可能是该框架的一个特定版本。这个压缩包中的“cocos2d-...
感觉4个人开发游戏真的很累,游戏为了脱颖出更加真实的效果还使用了物理引擎,在老大的同意的情况下,我共享cocos2d自己写的一些大家比较常用的,因为cocos2d有些控件不怎么好用或者没有,反正我觉得是这样的。...
"Cocos2d-x 闪电特效"正是这样一个专题,它探讨如何在Cocos2d-x环境中创建出逼真的闪电效果。 闪电特效通常涉及到电流的效果模拟,这种效果在游戏场景中常见于雷雨天气、魔法攻击或科技主题的游戏元素。在Cocos2d-x...