上一篇整理了 basice action 基本动作的部分,这一篇接着讲 composition actions -复合动作的部分。在实际编程中,这部分是跑不掉的,几乎每一个都是必用的。
CCSequence
sequence是用来按顺序执行一系列的动作,即动作按排列的顺序一个接一个的执行,示例如下:
- id action1 = [CCMoveTo actionWithDuration:2 position:ccp(100,100)];
- id action2 = [CCMoveBy actionWithDuration:2 position: ccp(80,80)];
- id action3 = [CCMoveBy actionWithDuration:2 position: ccp(0,80)];
- [sprite runAction: [CCSequence actions:action1, action2, action3, nil]];
上面这段代码的意思是,sprite(精灵对象)先移动到坐标(100,100)位置,然后在向右上方移动(80,80),然后,再向右移动80(80,0)。这一系列动作是不重叠,一个接一个的执行的。
注意的是,在这些动作中不能有 CCRepeatForever 这种无限的动作(就是不停的一直持续的动作),必须是那种可以在有限的时间内完成的。
CCSpawn
这个与上面的 CCSequence 不同的是,排列的动作是同时执行的,执行的时间以子动作中的最长的时间为准。代码示例:
- id action = [CCSpawn actions:
- [CCJumpBy actionWithDuration:2 position:ccp(300,0) height:50 jumps:4],
- [CCRotateBy actionWithDuration: 2 angle: 720],
- nil];
-
- [sprite runAction:action];
上面这段代码的意思是,sprite 在两秒钟内,向右跳四次,总共跳跃距离是300,跳跃高度是50,在跳跃过程中 同时旋转720度。
CCRepeat
这个是用来重复一个动作有限的次数。当然,你也可以用CCSequence来实现同样的功能,只是那样看起来有点傻。示例:
- id a1 = [CCMoveBy actionWithDuration:1 position:ccp(150,0)];
- id action1 = [CCRepeat actionWithAction:
- [CCSequence actions: [CCPlace actionWithPosition:ccp(60,60)], a1, nil]
- times:3];
- [sprite runAction:action1];
上面这段代码的意思是,先将sprite 放置在(60,60)位置,然后一秒内向右移动150的距离。这两个动作重复3次。
CCRepeatForever
上面的是重复有限次数,这个是无限次重复,比如,你想让一个轮子不停的旋转,就可以用这个实现。示例:
- CCRotateBy* rotate = [CCRotateBy actionWithDuration:1.0f angle:360];
- CCRepeatForever* action2 = [CCRepeatForever actionWithAction:rotate];
- [sprite runAction:action2];
就像上面讲的这段代码会让这个 sprite 一直不停的 以每秒360度的转速永远的旋转下去。
通过上面这四种类,可以方便的组合出许多复杂的运动,就看你的想象力了。
分享到:
相关推荐
该资源主要用于cocos2d-x中Value与json字符串的相互转换,提供从json文件读取为cocos2d::Value,cocos2d::Value写入到文件,cocos2d::Value转换为json字符串,json字符串转换为cocos2d::Value。json字符串转换成cocos...
总结,Cocos2d-iPhone的延时动作是构建复杂游戏动画的关键组成部分,它可以与其它动作结合,实现丰富的动态效果。通过理解并熟练运用动作系统,开发者能够创建出引人入胜的iOS游戏体验。在实际项目中,开发者应根据...
在本篇【Cocos2D游戏之旅(四):卡牌翻转效果的实现(下)】中,我们将深入探讨如何在Cocos2D游戏引擎中实现引人入胜的卡牌翻转特效。Cocos2D是一款强大的2D游戏开发框架,广泛应用于iOS、Android以及Windows等平台...
资源名称:Cocos2d-x实战:JS卷——Cocos2d-JS开发内容简介:本书是介绍Cocos2d-x游戏编程和开发技术书籍,介绍了使用Cocos2d-JS中核心类、瓦片地图、物理引擎、音乐音效、数据持久化、网络通信、性能优化、多平台...
3. **动作(Actions)与效果**:Cocos2d-x的动作系统允许开发者对游戏对象施加各种效果,如移动、旋转、缩放、淡入淡出等,实现丰富的视觉表现。 4. **物理引擎集成**:可能包含Box2D或Chipmunk等物理引擎的集成,...
本主题主要关注Cocos2d-iPhone中的“动作”(Actions)机制,这是一个强大的工具,用于创建各种动画效果和游戏逻辑。在Cocos2d-iPhone中,动作是类的实例,它们可以控制节点(Nodes)的行为,如改变位置、旋转、缩放...
总结,通过cocos2d-lua和OpenGL的结合,我们可以轻松创建出引人入胜的3D扑克翻牌特效。从建模到动画,再到交互设计,每一个步骤都需要细心打磨,才能打造出既美观又流畅的游戏体验。在实际开发中,开发者应不断学习...
cocos2d::Scene* HelloWorld::createScene() { auto scene = Scene::create(); auto layer = HelloWorld::create(); scene->addChild(layer); return scene; } ``` 在层中添加精灵: ```cpp Sprite* Hello...
Cocos Studio和Cocos Creator是两个常用的Cocos2d-JS集成开发环境,它们提供了图形化界面,让游戏设计和开发更加直观。 书中的内容可能涵盖了Cocos2d-JS的安装配置、基本语法、游戏对象的创建与管理、物理引擎的...
此外,cocos2d-x的事件系统也是其核心特性之一。它允许开发者方便地处理触摸、键盘、鼠标等各种输入事件,构建出响应性强的交互界面。同时,它的动作(Actions)和动画(Animations)系统,让开发者能够轻松实现复杂...
首先,我们需要了解Cocos2d::ActionManager类,它是Cocos2D-X中的核心组件之一,负责存储和执行所有已创建的动作。每个动作实例都是一个Cocos2d::Action对象,当调用其runWithTarget()方法时,该动作会被添加到...
总的来说,实现Cocos2d-x 3.10中的翻页和翻牌效果,需要对Cocos2d-x的动作系统、精灵和批处理节点有深入的理解,同时也需要对图形动画原理有一定的掌握。通过灵活运用这些基础知识,开发者可以创造出各种生动有趣的...
在Cocos2D-X中,动作(Actions)是游戏对象行为的核心组成部分,它们可以改变节点的位置、旋转、缩放、透明度等多种属性,甚至实现复杂的动画效果。本文主要围绕Cocos2D-X中的基础动作类的使用进行深入探讨。 一、...
总结来说,COCOS2D实现弹球效果涉及的主要知识点有:物理引擎(Box2D)、碰撞检测、动画制作、用户交互以及资源管理。理解并熟练掌握这些知识点,将有助于开发者构建出具有高质量弹球效果的游戏。在实际项目中,还...
总结,cocos2d_lua提供的3D功能使得实现搓牌效果成为可能。通过结合3D模型、纹理、动画和Lua脚本,我们可以创造出逼真的搓牌体验。在实际开发中,还需要考虑到性能优化和项目集成,以确保游戏的整体质量和用户体验。...
《Cocos2d-x实战 JS卷》是一本深入探讨Cocos2d-x游戏开发的专著,主要聚焦于使用JavaScript语言进行游戏编程。Cocos2d-x是一个开源的游戏开发框架,广泛应用于移动设备和桌面平台,支持iOS、Android、Windows等多...
此外,Cocos2d-iPhone还提供了许多其他高级动作,如Ease动作(用于缓动效果),Sequence动作(按顺序执行多个动作),以及Spawn动作(同时执行多个动作)。这些工具使得游戏开发者能够创造出丰富的视觉效果和动态...
二、Cocos2d-Android-1 API概览 Cocos2d-Android-1的API文档详细列出了可供开发者调用的类、方法和接口。这些API涵盖了以下几个核心领域: 1. **Scene和Layer**:Scene是游戏的顶级容器,可以包含多个Layer。Layer...
"Cocos2d-x 闪电特效"正是这样一个专题,它探讨如何在Cocos2d-x环境中创建出逼真的闪电效果。 闪电特效通常涉及到电流的效果模拟,这种效果在游戏场景中常见于雷雨天气、魔法攻击或科技主题的游戏元素。在Cocos2d-x...
感觉4个人开发游戏真的很累,游戏为了脱颖出更加真实的效果还使用了物理引擎,在老大的同意的情况下,我共享cocos2d自己写的一些大家比较常用的,因为cocos2d有些控件不怎么好用或者没有,反正我觉得是这样的。...