因为Cocos2d-X中的动作较多,我将全部的动作制作成了一个滚动视图。每一个滚动视图上都有动作名,单击滚动视图就能够展示对应的动作

程序效果图:

使用滚动视图实现动作切换

动作展示

程序代码:

首先创建一个ActionShow类

在ActionShow.h中的代码

#ifndef _ActionShow_H_
#define _ActionShow_H_ #include "cocos2d.h"
#include "cocos-ext.h"
USING_NS_CC;
USING_NS_CC_EXT; class ActionShow : public CCLayer
{
public:
static CCScene* scene(); bool init(); CREATE_FUNC(ActionShow); bool ccTouchBegan(CCTouch*, CCEvent*);
void ccTouchEnded(CCTouch*, CCEvent*); CCNode* _c;
void testAction(int idx, CCLayerColor*); void func();
void funcN(CCNode*);
void funcND(CCNode*, void*);
}; #endif

ActionShow.cpp中的代码

#include "ActionShow.h"

static const char* _actionName[] =
{
"CCMoveBy",
"CCMoveTo",
"CCRotateBy",
"CCRotateTo",
"CCScaleBy",
"CCScaleTo",
"CCSkewBy",
"CCSkewTo",
"CCJumpBy",
"CCJumpTo",
"CCBezierBy",
"CCBezierTo",
"CCFadeIn",
"CCFadeOut",
"CCTintTo",
"CCTintBy",
"CCBlink",
"CCDelayTime",
"CCOrbitCamera",
"CCCardinalSplineTo",
"CCCardinalSplineBy",
"CCCatmullRomTo",
"CCCatmullRomBy",
"CCFollow",
"CCCallFunc",
"CCCallFuncN",
"CCCallFuncND"
}; CCScene* ActionShow::scene()
{
CCScene* scene = CCScene::create(); ActionShow* layer = ActionShow::create(); scene->addChild(layer); return scene;
} bool ActionShow::init()
{
CCLayer::init(); CCSize winSize = CCDirector::sharedDirector()->getWinSize(); //创建Node结点用于ScrollView
CCNode* c = CCNode::create();
_c = c; //ScrollView中展示的动作的个数
int actionCount = sizeof(_actionName) / sizeof(*_actionName); //使用for循环创建视图用于展示动作
for (int i = 0; i < actionCount; i++)
{
CCLayerColor* layer; //
if (i % 2 == 0)
{
//创建带有颜色的背景层(背景层的颜色为深灰色)
layer = CCLayerColor::create(ccc4(192, 192, 192, 255), winSize.width, winSize.height);
}
else
{
//创建带有颜色的背景层(背景层的颜色为浅灰色)
layer = CCLayerColor::create(ccc4(128, 128, 128, 255), winSize.width, winSize.height);
} c->addChild(layer);
layer->setPosition(ccp(i*winSize.width, 0)); //保存动作的名字
const char* title = _actionName[i]; //创建标签用于显示动作的名字
CCLabelTTF* label = CCLabelTTF::create(title, "Arial", 36);
layer->addChild(label); //设置标签的位置
label->setPosition(ccp(winSize.width / 2, winSize.height - 80));
} //创建滚动视图
CCScrollView* view = CCScrollView::create(winSize, c); //设置滚动视图的滚动方向为水平滚动
view->setDirection(kCCScrollViewDirectionHorizontal); //设置滚动视图的大小
view->setContentSize(CCSize(winSize.width*actionCount, winSize.height));
addChild(view); //能触摸
setTouchEnabled(true);
setTouchMode(kCCTouchesOneByOne); return true;
} bool ActionShow::ccTouchBegan(CCTouch*, CCEvent*)
{
return true;
} void ActionShow::testAction(int idx, CCLayerColor* layer)
{
CCSize winSize = CCDirector::sharedDirector()->getWinSize(); //得到用户创建的精灵
CCSprite* sprite = (CCSprite*)layer->getUserObject(); //当没有精灵的时候
if (sprite == NULL)
{
//创建一个新的精灵
sprite = CCSprite::create("CloseNormal.png");
layer->addChild(sprite); //设置精灵的关联对象
layer->setUserObject(sprite);
} //保存用户选择的动作
const char* an = _actionName[idx]; //动作类
CCAction* action; //设置精灵的位置
sprite->setPosition(ccp(winSize.width / 2, winSize.height / 2)); if (an == "CCMoveTo")//运动
{
action = CCMoveTo::create(2, ccp(100, 100));
}
if (an == "CCMoveBy")//运动
{
action = CCMoveBy::create(2, ccp(100, 100));
}
if (an == "CCRotateBy")//旋转
{
action = CCRotateBy::create(2, 250);
}
if (an == "CCRotateTo")//旋转
{
action = CCRotateTo::create(2, 250);
}
if (an == "CCScaleBy")//放大或缩小
{
//2表示放大两倍
//-2表示缩小两倍
action = CCScaleBy::create(2, 2);
}
if (an == "CCScaleTo")//放大或缩小
{
action = CCScaleTo::create(2, -2);
}
if (an == "CCSkewBy")//扭曲
{
//第一个參数:完毕扭曲所花的时间
//第二个參数:x轴方向扭曲的值
//第三个參数:y轴方向扭曲的值
action = CCSkewBy::create(2, 35, 87);
}
if (an == "CCSkewTo")//扭曲
{
action = CCSkewTo::create(2, 35, 87);
}
if (an == "CCJumpBy")//跳跃
{
//第一个參数:完毕跳跃所花的时间
//第一个參数:跳跃到的位置
//第一个參数:跳跃的高度
//第一个參数:跳跃的次数
action = CCJumpBy::create(3, ccp(100, 100), 50, 6);
}
if (an == "CCJumpTo")//跳跃
{
action = CCJumpTo::create(3, ccp(100, 100), 50, 6);
}
if (an == "CCBezierBy")//贝塞尔曲线(相对)
{
//设置控制点
ccBezierConfig c; //控制点1
c.controlPoint_1 = ccp(400, 400); //控制点2
c.controlPoint_2 = ccp(250, 360); //终点
c.endPosition = ccp(100, 100); //第一个參数:时间
//第二个參数:控制点
action = CCBezierBy::create(3, c);
}
if (an == "CCBezierTo")//贝塞尔曲线(绝对)
{
ccBezierConfig c;
c.controlPoint_1 = ccp(400, 400);
c.controlPoint_2 = ccp(250, 360);
c.endPosition = ccp(100, 100);
action = CCBezierTo::create(3, c);
}
if (an == "CCFadeIn")//淡入(通过改动透明度实现)
{
action = CCFadeIn::create(3);
}
if (an == "CCFadeOut")//淡出(通过改动透明度实现)
{
action = CCFadeOut::create(3);
}
if (an == "CCTintTo")//在精灵上混合一个颜色
{
action = CCTintTo::create(3, 255, 0, 0);
}
if (an == "CCTintBy")//在精灵上混合一个颜色
{
action = CCTintBy::create(3, 23, 47, 37);
}
if (an == "CCBlink")//精灵闪烁
{
action = CCBlink::create(3, 10);
}
if (an == "CCDelayTime")//精灵停顿一会儿
{
//2秒钟内精灵移动到(100,100)
CCMoveBy* move = CCMoveBy::create(2, ccp(100, 100)); //停顿1秒钟
CCDelayTime* delay = CCDelayTime::create(1); //精灵返回
CCFiniteTimeAction* back = move->reverse(); //动作的顺序封装(先运行move后运行delay)
action = CCSequence::create(move, delay, back, NULL);
}
if (an == "CCOrbitCamera")//依据球面坐标轨迹旋转
{
//參数1:旋转的时间
//參数2:起始半径
//參数3:半径差
//參数4:起始z角
//參数5:旋转z角
//參数6:起始x角
//參数7:旋转x角
action = CCOrbitCamera::create(5, 80, 13, 55, 13, 80, 24);
}
if (an == "CCCardinalSplineTo")//样条曲线动作
{
//创建样条曲线动作
CCPointArray* arr = CCPointArray::create(20); //创建围城曲线框的四个点
arr->addControlPoint(ccp(200, 200));
arr->addControlPoint(ccp(200, 100));
arr->addControlPoint(ccp(100, 100));
arr->addControlPoint(ccp(100, 200));
action = CCCardinalSplineTo::create(5, arr, 5.0f);
}
if (an == "CCCardinalSplineBy")//样条曲线动作
{
CCPointArray* arr = CCPointArray::create(20);
arr->addControlPoint(ccp(200-50, 200-50));
arr->addControlPoint(ccp(200-50, 100-50));
arr->addControlPoint(ccp(100-50, 100-50));
arr->addControlPoint(ccp(100-50, 200-50));
action = CCCardinalSplineBy::create(5, arr, 5.0f);
}
if (an == "CCCatmullRomTo")//云性曲线
{
CCPointArray* arr = CCPointArray::create(20);
arr->addControlPoint(ccp(200, 200));
arr->addControlPoint(ccp(200, 100));
arr->addControlPoint(ccp(100, 100));
arr->addControlPoint(ccp(100, 200));
action = CCCatmullRomTo::create(5, arr);
}
if (an == "CCCatmullRomBy")//云性曲线
{
CCPointArray* arr = CCPointArray::create(20);
arr->addControlPoint(ccp(200, 200));
arr->addControlPoint(ccp(200, 100));
arr->addControlPoint(ccp(100, 100));
arr->addControlPoint(ccp(100, 200));
action = CCCatmullRomBy::create(5, arr);
}
if (an == "CCFollow")//镜头跟着目标走,超过范围就结束。
{
CCSprite* sprite2 = CCSprite::create("green_edit.png");
layer->addChild(sprite2);
sprite2->setPosition(ccp(winSize.width / 2, winSize.height / 2));
sprite2->runAction(CCJumpBy::create(100, ccp(800, 800), 800, 60));
action = CCFollow::create(sprite2);
}
if (an == "CCCallFunc")//创建一个回调动作(不带參数)
{
action = CCCallFunc::create(this, callfunc_selector(ActionShow::func));
}
if (an == "CCCallFuncN")//创建一个回调动作(传调用者为參数)
{
action = CCCallFuncN::create(this, callfuncN_selector(ActionShow::funcN));
}
if (an == "CallFuncND")//创建一个回调动作(带2个參数)
{
void* p = NULL;
action = CCCallFuncND::create(this, callfuncND_selector(ActionShow::funcND), p);
} sprite->runAction(action); } void ActionShow::func()
{
} void ActionShow::funcN(CCNode*)
{
} void ActionShow::funcND(CCNode*, void*)
{
} void ActionShow::ccTouchEnded(CCTouch* t, CCEvent*)
{
//得到按下鼠标时的位置
CCPoint ptStart = t->getStartLocation(); //得到松开鼠标时的位置
CCPoint ptEnd = t->getLocation(); //假设两个位置的距离的平方小于或者等于25
if(ptStart.getDistanceSq(ptEnd) <= 25)
{
// click
// 点中了哪个子窗体 // 转换ptStart为ScrollView中的Container的坐标
// 再推断被点击的LayerColor
//将鼠标点下的时候的位置的坐标转换成结点坐标
CCPoint ptInContainer = _c->convertToNodeSpace(ptStart); //创建一个数组用于保存LayerColor
CCArray* arr = _c->getChildren();// 全部的layercolor //用于寻找点中的LayerColor
for (int i = 0; i < sizeof(_actionName) / sizeof(*_actionName); i++)
{
//
CCLayerColor* layer = (CCLayerColor*)arr->objectAtIndex(i);
if (layer->boundingBox().containsPoint(ptInContainer))
{
testAction(i, layer);
break;
}
}
} }



Cocos2d-X 动作展示《一》的更多相关文章

  1. 【Cocos2d入门教程四】Cocos2d-x菜单篇

    游戏世界多姿多彩,无论多靓丽的游戏,多耐玩的游戏,在与游戏用户交互上的往往是菜单. 上一章我们已经大概了解了导演.节点.层.精灵.这一章以菜单为主题. 菜单(Menu)包含以下内容: 1.精灵菜单项( ...

  2. Cocos2D中Action的进阶使用技巧(一)

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 大家对Cocos2d中动作的使用大概都很清楚了,其实本身act ...

  3. 自然语言交流系统 phxnet团队 创新实训 项目博客 (二)

    基本要求 打开软件,即可进入2D文本交流界面, 软件此时已经连接到服务器,点击文本输入框输入你想说的话,点击发送按钮即可进行交流,点击CHAT和STUDY分别切换到聊天模式或是学习模式,聊天模式是机器 ...

  4. 【Cocos2dX(2.x)_Lua开发之三】

    [Cocos2dX(2.x)_Lua开发之三]在Lua中使用自定义精灵(Lua脚本与自创建类之间的访问)及Lua基础讲解 本站文章均为李华明Himi原创,转载务必在明显处注明:(作者新浪微博:@李华明 ...

  5. Web可用性设计的247条指导方针

    首页可用性设计 首页元素要清晰的关注用户的关键任务(避免“增加功能倾向(featuritis)”) 如果网站比较大,那么首页应包含搜索输入框 首页要十分清楚的提供产品(内容)分类 在首页或首页内一次点 ...

  6. odoo12从零开始:三、1)创建你的第一个应用模型(module)

    前言 以前,我一直都不知道为什么好多框架的入门都是“hello world”开始,当我思前想后我要如何介绍odoo的model.record.template等继承等高级特性时,发现在那之前便需要清楚 ...

  7. N1试卷常考词汇总结

    免れる まぬがれる 免去,幸免 軽率 けいそつ 轻率,草率 捩れる ねじれる 拧劲儿,扭歪,弯曲 裂ける さける 裂开,破裂 避ける さける 躲避,避开 つまむ 挟,捏,掐 追及 ついきゅう 追上.追 ...

  8. django 创建管理员用户

    7.2 create 创建管理员用户: python manage.py run server python manage.py createsuperuser password :123456789 ...

  9. 【Mock平台】测试开发实战01-开篇PRD和需求详细

    微信搜索[大奇测试开],关注这个坚持分享测试开发干货的家伙. 平台背景 从业务特性上,不少测试的服务很多是依赖第三方的接口的,比如其中的支付场景,就需要很多状态的返回进行验证,但大部分服务提供商没有很 ...

随机推荐

  1. C语言实践——学生信息管理

    这是本人做的第一个实践项目,用的知识都是书上有的,没有很多很复杂的知识 同时因为没有学习 C语言 图形方面的知识,所以界面做得很丑,暂时先这样吧 源文件: #include <stdio.h&g ...

  2. J2SE知识点摘记(二十五)

    Set 1.5.1        概述 Java 中的Set和正好和数学上直观的集(set)的概念是相同的.Set最大的特性就是不允许在其中存放的元素是重复的.根据这个特点,我们就可以使用Set 这个 ...

  3. android 读写sd卡的权限设置

    原文:android 读写sd卡的权限设置 在Android中,要模拟SD卡,要首先使用adb的mksdcard命令来建立SD卡的镜像,如何建立,大家上网查一下吧,应该很容易找到,这里不说这个问题. ...

  4. 【转】Ubuntu Linux 下文件名乱码(无效的编码)的快速解决办法

    原博文地址:http://www.cnblogs.com/york-hust/archive/2012/07/07/2580388.html 文件是在WIndows 下创建的,Windows 的文件名 ...

  5. POJ 3111 K Best(最大化平均值)

    题目链接:click here~~ [题目大意]有n个物品的重量和价值各自是Wi和Vi.从中选出K个物品使得单位重量的价值最大,输出物品的编号 [解题思路]:最大化平均值的经典.參见click her ...

  6. [poj 3678]Katu Pazzle[2-SAT常用建图法]

    题意: 不说了..典型的2-SAT 常用模型: 重点: 突出"绑定性". 连线表示限制而非可行. 因为最后要求对立点不在同一强连通分量是说同一强连通中的点必须同时选. 坑: 首先是 ...

  7. IOS系列——NStimer

    Timer经常使用的一些东西 1. 初始化 timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@select ...

  8. bit-map牛刀小试:数组test[X]的值所有在区间[1, 8000]中, 现要输出test中反复的数。要求:1. 不能改变原数组; 2.时间复杂度为O(X);3.除test外空间不超过1KB

    先来看看这个题目:数组test[X]的值所有在区间[1, 8000]中. 现要输出test中反复的数.要求:1. 不能改变原数组; 2.时间复杂度为O(X);3.除test外空间不超过1KB. 好, ...

  9. 转换成CSV文件、Word、Excel、PDF等的方法--读取CSV文件的方法

    1. 转换成CSV文件: http://www.dotnetgallery.com/lab/resource93-Export-to-CSV-file-from-Data-Table-in-Aspne ...

  10. 简单C#文字转语音

    跟着微软走妥妥的,C#文字转语音有很多参数我就不说了,毕竟我也是初学者.跟大家分享最简单的方法,要好的效果得自己琢磨喽: 先添加引用System.Speech程序集: using System; us ...