cocos2d-x 卡牌翻牌效果的实现
转自:http://blog.csdn.net/yanghuiliu/article/details/9115833
这个能实现翻牌的action就是CCOrbitCamera。
static CCOrbitCamera* create(float t, float radius, float deltaRadius, float angleZ, float deltaAngleZ, float angleX, float deltaAngleX);
参数分别为旋转的时间,起始半径,半径差,起始z角,旋转z角差,起始x角,旋转x角差
下面是我封装的cardSprite
//创建翻牌sprite, 参数:卡片里面的图,卡片的封面,翻牌所花时间
CardSprite* card = CardSprite::create("1.png", "2.png", ); card->setPosition(ccp(size.width * ., size.height * .)); addChild(card);
card->openCard();//开始翻牌
CardSprite.h
//
// CardSprite.h
// Cocos2dev.com
//
// Created by LiuYanghui on 13-6-17.
//
// #ifndef __Test__CardSprite__
#define __Test__CardSprite__ #include "cocos2d.h"
USING_NS_CC; class CardSprite : public CCSprite
{
public:
CardSprite();
~CardSprite();
static CardSprite* create(const char* inCardImageName, const char* outCardImageName, float duration);
virtual bool init(const char* inCardImageName, const char* outCardImageName, float duration); private:
bool m_isOpened;
CCActionInterval* m_openAnimIn;
CCActionInterval* m_openAnimOut; void initData(const char* inCardImageName, const char* outCardImageName, float duration); public:
void openCard();
}; #endif /* defined(__Test__CardSprite__) */
CardSprite.cpp
//
// CardSprite.cpp
// Cocos2dev.com
//
// Created by LiuYanghui on 13-6-17.
//
// #include "CardSprite.h" #define kInAngleZ 270 //里面卡牌的起始Z轴角度
#define kInDeltaZ 90 //里面卡牌旋转的Z轴角度差 #define kOutAngleZ 0 //封面卡牌的起始Z轴角度
#define kOutDeltaZ 90 //封面卡牌旋转的Z轴角度差 enum {
tag_inCard = ,
tag_outCard
}; CardSprite::CardSprite()
{ } CardSprite::~CardSprite()
{
m_openAnimIn->release();
m_openAnimOut->release();
} CardSprite* CardSprite::create(const char* inCardImageName, const char* outCardImageName, float duration)
{
CardSprite *pSprite = new CardSprite();
if (pSprite && pSprite->init(inCardImageName, outCardImageName, duration))
{
pSprite->autorelease();
return pSprite;
}
CC_SAFE_DELETE(pSprite);
return NULL;
} bool CardSprite::init(const char* inCardImageName, const char* outCardImageName, float duration)
{
if (!CCSprite::init())
{
return false;
}
initData(inCardImageName, outCardImageName, duration);
return true;
} #pragma mark - initData
void CardSprite::initData(const char* inCardImageName, const char* outCardImageName, float duration)
{
m_isOpened = false; CCSprite* inCard = CCSprite::create(inCardImageName);
inCard->setPosition(CCPointZero);
inCard->setVisible(false);
inCard->setTag(tag_inCard);
addChild(inCard); CCSprite* outCard = CCSprite::create(outCardImageName);
outCard->setPosition(CCPointZero);
outCard->setTag(tag_outCard);
addChild(outCard); m_openAnimIn = (CCActionInterval*)CCSequence::create(CCDelayTime::create(duration * .),
CCShow::create(),
CCOrbitCamera::create(duration * ., , , kInAngleZ, kInDeltaZ, , ),
NULL);
m_openAnimIn->retain(); m_openAnimOut = (CCActionInterval *)CCSequence::create(CCOrbitCamera::create(duration * ., , , kOutAngleZ, kOutDeltaZ, , ),
CCHide::create(),
CCDelayTime::create(duration * .),
NULL);
m_openAnimOut->retain();
} #pragma mark - public func
void CardSprite::openCard()
{
CCSprite* inCard = (CCSprite*)getChildByTag(tag_inCard);
CCSprite* outCard = (CCSprite*)getChildByTag(tag_outCard);
inCard->runAction(m_openAnimIn);
outCard->runAction(m_openAnimOut);
}
cocos2d-x 卡牌翻牌效果的实现的更多相关文章
- iOS UIcollectionView 实现卡牌翻转效果
- (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...
- CCOrbitCamera卡牌翻转效果
static CCOrbitCamera* create(float t, float radius, float deltaRadius, float angleZ, float deltaAngl ...
- css3 翻牌效果
<!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/h ...
- TCG卡牌游戏研究:《炉石战记:魔兽英雄传》所做的改变
转自:http://www.gameres.com/665306.html TCG演进史 说到卡牌游戏,大家会联想到什么呢? 是历史悠久的扑克牌.风靡全球的<MTG 魔法风云会>与< ...
- css3实现卡牌旋转与物体发光效果
效果演示 http://demo.qpdiy.com/hxw/CSS3/rotate+light.html 物体旋转: 卡牌同一位置放2张图片,通过设置3D动画旋转实现 animation: card ...
- 使用UIKit制作卡牌游戏(三)ios游戏篇
译者: Lao Jiang | 原文作者: Matthijs Hollemans写于2012/07/13 转自朋友Tommy 的翻译,自己只翻译了这第三篇教程. 原文地址: http://www.ra ...
- 使用JS与CSS3的翻转实现3D翻牌效果
之前我们有讨论过使用CSS3如何实现网页水平翻转的效果,而这次我们介绍的是翻转效果更深一层的应用——3D翻牌效果. 这里我们需要使用flip中轴翻转实现,又因为是3D效果,如果希望呈现一定的3D视角, ...
- 在WebGL场景中管理多个卡牌对象的实验
这篇文章讨论如何在基于Babylon.js的WebGL场景中,实现多个简单卡牌类对象的显示.选择.分组.排序,同时建立一套实用的3D场景代码框架.由于作者美工能力有限,所以示例场景视觉效果可能欠佳,本 ...
- DOTA自走棋卡牌及搭配阵容
这个游戏其实就根炉石jjc和A牌轮抽一样,前期要找着质量牌抓,保证你至少不漏.根据你的需求补一些你不会上场的阵容组件,最后根据你的组件和核心紫卡来哪张来决定打什么.另外也要考虑场上另外几家,如果有一家 ...
随机推荐
- zoj 3765
一道区间更新.查询的题: 但是线段树不能做插入: 后来才知道用splay: splay用来做区间查询的话,先将l-1旋转到根节点,然后把r+1旋转到根节点的右节点: 这样的话,根节点的右节点的左子树就 ...
- Ubuntu14.04下Unity桌面托盘图标显示问题
本来想丰富一下功能,遂开始安装大开眼界:Ubuntu下10个厉害的Indicator小程序这里的Indicator小程序. 很不幸,在安装到indicator-multiload的时候,准备注销看一下 ...
- Unity之串口通信(基于三姿态传感器)
原地址:http://www.cnblogs.com/alongu3d/archive/2013/05/02/3054962.html /******************************* ...
- python编码基础知识
http://www.javaeye.com/topic/560229 一 预备知识 字符集1, 常用字符集分类ASCII及其扩展字符集作用:表语英语及西欧语言.位数:ASCII是用7位表示的,能表示 ...
- HDU 1171 Big Event in HDU(DP)
点我看题目 题意 : 给你一个n,然后n组数据,每组两个数字,一个是物品的价值,另外一个是物品的数量,让你尽量将这些东西分成价值相等的两份,如果无法相等就前一份要大于后一份. 思路 :这个题可以转化成 ...
- WINDOWS HYPER-V加新网卡,设置网络出错
新网卡加入,设置好IP之后,HYPER-V需要更改相应外部网络连接,然后重新生成新的虚拟连接网卡. 不然,虚拟机无法正常使用网络. 但我昨天在绑定新的网站时,出现如下错误: Adding a new ...
- 李洪强漫谈iOS开发[C语言-035]-选择结构-与小结
- jquery parent()和parents()区别
parent(exp) 取得一个包含着所有匹配元素的唯一父元素的元素集合. 你可以使用可选的表达式来筛选. 查找段落的父元素中每个类名为selected的父元素. HTML 代码: <div&g ...
- 【HDOJ】2430 Beans
这题目用线段树超时了,其实也差不多应该超时.10^6大数据量.看了一下网上的解法是单调队列.大概了解了一下,是个挺有意思的数据结构.首先,需要求满足0<=(S[r]-S[l])%p<=k时 ...
- Windows系统性能提升方法
看前提醒:在确认没有病毒和流氓软件的前提下,建议优化电脑:以下操作已经在Win7上试验,Win7以上的园友自己试验,自己感受,对电脑无害,但操作时请务必小心 设置虚拟内存 虚拟内存最小值物理内存1.5 ...