cocos2dx 几个精灵依照顺序播放动画解决方法
我先描写叙述一下这个问题:
拿之前做的卡牌游戏来说。假设一方场上有3张牌,那么肯定要以一种顺序来播放攻击动画。我是以从左到右的方式。
我的解决方案是向每张牌都传递一个延时參数,然后在runAction的时候使用DelyTime,可是这样的方法太麻烦。
如今说说更好的方法吧:
基本思路是vector与callfunc相结合。
一:
先在类里定义数据和函数
std::vector<std::vector<int>> v_action;//储存精灵TAG和动画TAG的容器 void push_action(int sprite_tag,int action_tag);//加入动作序列
void run_action(int sprite_tag,int action_tag);//播放动作
void next_action();//下一个动作 Sequence* run(int action_tag);//依据TAG返回动作 bool isRunAction;//是否正在播放动作
二:
在init初始化參数
//还没有播放动作
isRunAction=false; Size visibleSize = Director::getInstance()->getVisibleSize();
Vec2 origin = Director::getInstance()->getVisibleOrigin();
//演员一
auto actor1 = Sprite::create("CloseNormal.png");
actor1->setTag(11);
actor1->setPosition(250,visibleSize.height/2);
this->addChild(actor1,2);
//演员二
auto actor2 = Sprite::create("CloseNormal.png");
actor2->setTag(22);
actor2->setPosition(300,visibleSize.height/2);
this->addChild(actor2,2);
//演员一跳跃
auto play1 = MenuItemImage::create(
"CloseNormal.png",
"CloseSelected.png",
CC_CALLBACK_1(HelloWorld::menuCallback, this));
play1->setTag(1);
play1->setPosition(250,visibleSize.height/5);
//演员二跳跃
auto play2 = MenuItemImage::create(
"CloseNormal.png",
"CloseSelected.png",
CC_CALLBACK_1(HelloWorld::menuCallback, this));
play2->setTag(2);
play2->setPosition(300,visibleSize.height/5); auto closeItem = MenuItemImage::create(
"CloseNormal.png",
"CloseSelected.png",
CC_CALLBACK_1(HelloWorld::menuCloseCallback, this)); closeItem->setPosition(Vec2(origin.x + visibleSize.width - closeItem->getContentSize().width/2 ,
origin.y + closeItem->getContentSize().height/2)); // create menu, it's an autorelease object
auto menu = Menu::create(play1,play2,closeItem, NULL);
menu->setPosition(Vec2::ZERO);
this->addChild(menu, 1);
以上创建了两个精灵和两个button(还有一个忽略),点击play1那么演员1跳一下,点击play2演员2跳一下。为了实现两个演员不同一时候起跳和记录我们操作的顺序,我们须要在menuCallback里这样写:
void HelloWorld::menuCallback(Ref* pSender)
{
auto menuItem = (MenuItemImage*)pSender;
Sprite* actor;
switch (menuItem->getTag())
{
case 1:
push_action(11,1);
break;
case 2:
push_action(22,1);
break;
default:
break;
}
}
这里使用了push_action函数,作用是播放动作或者将操作存入容器:
void HelloWorld::push_action(int sprite_tag,int action_tag)
{
if(isRunAction==false)//假设没有在播放动作,那么直接播放此动作
{
isRunAction=true;
run_action(sprite_tag,action_tag);
}
else//假设正在播放,那么将此动作存入容器
{
std::vector<int> v_sprite;
v_sprite.push_back(sprite_tag);
v_sprite.push_back(action_tag); v_action.push_back(v_sprite); }
}
凝视已经比較具体了~
我们先看看run_action函数里面有什么吧:
void HelloWorld::run_action(int sprite_tag,int action_tag)
{
auto actor = (Sprite*)getChildByTag(sprite_tag);
auto squence = Sequence::create(run(action_tag),
CallFunc::create(this,callfunc_selector(HelloWorld::next_action)),
NULL);
actor->runAction(squence);
}
函数的作用是依据传入的两个tag播放动作,然后调用next_action:
void HelloWorld::next_action()
{
if(v_action.empty())
{
isRunAction=false;
}
else
{
std::vector<int > a;
a=v_action.at(0);
int sprite_tag=a.at(0);
int action_tag=a.at(1);
std::vector<std::vector<int>>::iterator it = v_action.begin();
v_action.erase(it);
run_action(sprite_tag,action_tag);
}
}
假设容器里没有数据则说明接下来没有动作能够播放了,则把isRunAction赋为false,下次就能够直接播放动作。
假设容器里有数据。我们先把这项数据取出然后删除它。然后再调用run_action。
最后我们看看run里面有什么吧:
Sequence* HelloWorld::run(int action_tag)
{
switch (action_tag)
{
case 1:
return Sequence::create(MoveBy::create(0.2,Vec2(0,100)),
MoveBy::create(0.2,Vec2(0,-100)),
NULL);
default:
break;
}
}
非常easy,就是一个动作。当然我们能够依据须要添加。(注意返回參数是Sequence,所以想播放其它动画就改函数吧)
如今看看效果:
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcXEzNjk4NDY2NDI=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">
完毕!
cocos2dx 几个精灵依照顺序播放动画解决方法的更多相关文章
- 格式工厂转化成mp4 avc格式 暴风影音不能播放的解决方法
格式工厂转化成mp4 avc格式 暴风影音不能播放的解决方法 先转成其他mp4 确保能播放 然后再转成avc
- zepto的返回顶部scrollTop的动画解决方法
写移动端的时候,引入的zepto.js里的animate不包括scrollTop,所以返回顶部的时候,没有动画的效果.这里我使用的是setInterval的方法.代码详情如下 <!DOCTYPE ...
- 微软BI 之SSIS 系列 - 变量查询语句引起列输出顺序不一致的解决方法
开篇介绍 这个问题来自于 天善BI社区,看了一下比较有意思,因为我自己认为在 SSIS中处理各种类型文件的经验还比较丰富(有一年的时间几乎所有ETL都跟文件相关),但是这个问题确实之前没有特别考虑过. ...
- 关于微信H5页面开发中音乐不自动播放的解决方法
我想应该有很多人在做H5场景应用.H5微刊.H5微杂志的时候加入背景音乐吧(客户需求),相信很多人一定碰过不能自动播放的时候,即使是相同的iPhone 5s也有不播放的时候,很蛋疼吧!? 之前我的解决 ...
- HTML5添加 video 视频标签后仍然无法播放的解决方法 IIS添加MIEI类型
现象:插入如下代码后仍然无法看视频(注:视频已确认为浏览器支持格式) <video controls="controls" width="500px" h ...
- A Script Pro nginx URL重写规则无法播放MP4解决方法
I am using nginx and I have already add the line location /file/ { rewrite ^/-]+)/([-]+)/([^/]*)/([- ...
- Vue中swiper手动滑动后不能自动播放的解决方法
用户操作swiper之后,是否禁止autoplay.默认为true:停止.如果设置为false,用户操作swiper之后自动切换不会停止,每次都会重新启动autoplay.操作包括触碰,拖动,点击pa ...
- 【转】使用ffmpeg转码的MP4文件需要加载完了才能播放的解决办法
1.前一段时间做了一个ffmpeg转码MP4的项目,但是转出来的MP4部署在网站上需要把整个视频加载完成才能播放,到处找资料,最后找到解决方案记录于此备忘. FFMpeg转码由此得到的mp4文件中, ...
- cocos2d-x发生undefined reference to `XX'异常 一劳永逸解决的方法
转自:http://www.myexception.cn/operating-system/1620542.html cocos2d-x发生undefined reference to `XX'错误 ...
随机推荐
- Crontab入门基础
Crontab入门基础 crontab前言 crontab是Unix和Linux用于设置周期性被执行的指令,是互联网很常用的技术,很多任务都会设置在crontab循环执行,如果不使用crontab,那 ...
- Vue轮播图插件---Vue-Awesome-Swiper
轮播图插件 Vue-Awesome-Swiper 地址:https://github.com/surmon-china/vue-awesome-swiper 安装:npm install vue-aw ...
- IntegerToBinaryString
IntegerToBinaryString 方法写的非常的巧妙:佩服佩服! package com.stono.jdk; public class IntegerToBinaryString { pu ...
- CentOS 安装SVNclient
1.检查是已经安装了svn: # rpm -qa subversion subversion-1.7.14-6.el7.x86_64 卸载旧版本号的svn: # yum remove subversi ...
- Spoj 1557 Can you answer these queries II 线段树 随意区间最大子段和 不反复数字
题目链接:点击打开链接 每一个点都是最大值,把一整个序列和都压缩在一个点里. 1.普通的区间求和就是维护2个值,区间和Sum和延迟标志Lazy 2.Old 是该区间里出现过最大的Sum, Oldlaz ...
- JAVA设计模式之【状态模式】
状态模式 水.固态.气态.液态 账户.正常状态.透支状态.受限状态 状态模式中,用一个状态类来分散冗长的条件语句,让系统有灵活性和可扩展性 状态模式用于解决系统中复杂对象的状态转换以及不同状态下行为的 ...
- 发送HTTP请求 -- HttpUtil
1. package com.step.utils; import java.io.IOException; import java.net.URLDecoder; import java.util. ...
- awesome python 中文版 相见恨晚!(pythonNB的第三方资源库)
Awesome Python中文版来啦! 原文链接:Python 资源大全 内容包括:Web框架.网络爬虫.网络内容提取.模板引擎.数据库.数据可视化.图片处理.文本处理.自然语言处理.机器学习.日志 ...
- vue组件样式添加scoped属性之后,无法被父组件修改。或者无法在本组件修改element UI样式
在vue开发中,需要使用scoped属性避免样式的全局干扰,但是这样在父组件中是无法被修改的,不仅如此如果项目中用了UI框架比如element Ui,这个时候在本组件也无法修改样式,因为权重问题.但是 ...
- Java事件处理机制1
实现一个小程序,怎样通过点击不同的按钮,让面板的背景色发生相应的变化,如图: public class Demo2 extends JFrame implements ActionListener{ ...