转自: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 卡牌翻牌效果的实现的更多相关文章

  1. iOS UIcollectionView 实现卡牌翻转效果

    - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view, typica ...

  2. CCOrbitCamera卡牌翻转效果

    static CCOrbitCamera* create(float t, float radius, float deltaRadius, float angleZ, float deltaAngl ...

  3. css3 翻牌效果

    <!DOCTYPE html> <head> <meta http-equiv="Content-Type" content="text/h ...

  4. TCG卡牌游戏研究:《炉石战记:魔兽英雄传》所做的改变

    转自:http://www.gameres.com/665306.html TCG演进史 说到卡牌游戏,大家会联想到什么呢? 是历史悠久的扑克牌.风靡全球的<MTG 魔法风云会>与< ...

  5. css3实现卡牌旋转与物体发光效果

    效果演示 http://demo.qpdiy.com/hxw/CSS3/rotate+light.html 物体旋转: 卡牌同一位置放2张图片,通过设置3D动画旋转实现 animation: card ...

  6. 使用UIKit制作卡牌游戏(三)ios游戏篇

    译者: Lao Jiang | 原文作者: Matthijs Hollemans写于2012/07/13 转自朋友Tommy 的翻译,自己只翻译了这第三篇教程. 原文地址: http://www.ra ...

  7. 使用JS与CSS3的翻转实现3D翻牌效果

    之前我们有讨论过使用CSS3如何实现网页水平翻转的效果,而这次我们介绍的是翻转效果更深一层的应用——3D翻牌效果. 这里我们需要使用flip中轴翻转实现,又因为是3D效果,如果希望呈现一定的3D视角, ...

  8. 在WebGL场景中管理多个卡牌对象的实验

    这篇文章讨论如何在基于Babylon.js的WebGL场景中,实现多个简单卡牌类对象的显示.选择.分组.排序,同时建立一套实用的3D场景代码框架.由于作者美工能力有限,所以示例场景视觉效果可能欠佳,本 ...

  9. DOTA自走棋卡牌及搭配阵容

    这个游戏其实就根炉石jjc和A牌轮抽一样,前期要找着质量牌抓,保证你至少不漏.根据你的需求补一些你不会上场的阵容组件,最后根据你的组件和核心紫卡来哪张来决定打什么.另外也要考虑场上另外几家,如果有一家 ...

随机推荐

  1. 一组神奇的 3D Gif 动图

    本文由 极客范 - 黄利民 翻译自 mymodernmet.欢迎加入极客翻译小组,同我们一道翻译与分享.转载请参见文章末尾处的要求. 虽然 gif 动图/动画似乎是无处不在现在了,但有些聪明人已经把 ...

  2. IBM

    http://www.ibm.com/developerworks/cn/data/library/techarticle/dm-1306mongodb2/

  3. ZOJ 2110 Tempter of the Bone(DFS)

    点我看题目 题意 : 一个N×M的迷宫,D是门的位置,门会在第T秒开启,而开启时间小于1秒,问能否在T秒的时候到达门的位置,如果能输出YES,否则NO. 思路 :DFS一下就可以,不过要注意下一终止条 ...

  4. [codility]Prefix-set

    这题很简单,一开始用了set.但后来一想这样其实是n*logn的,而且没有利用所有的数都在0..N-1之间.那么可以直接用vector当hashset. // you can also use inc ...

  5. MyEclipse中文乱码,编码格式设置,文件编码格式 总结

    一.设置新建常见文件的默认编码格式,也就是文件保存的格式.在不对MyEclipse进行设置的时候,默认保存文件的编码,一般跟简体中文操作系统(如windows2000,windowsXP)的编码一致, ...

  6. 133. Clone Graph

    题目: Clone an undirected graph. Each node in the graph contains a label and a list of its neighbors. ...

  7. Spring事务管理--多个ORM框架在使用时的情况分析

    公司的项目已经接近尾声了,总结一下项目中用到的技术,我发现项目中的有些东西还是挺模糊的,只是知道这么用就行了.并不清楚其中的原理.由于公司的项目比较老,是7年前的一个项目了,中间一直有人在维护,也是在 ...

  8. 【HDOJ】1076 An Easy Task

    水题,如题. #include <stdio.h> #define chk(Y) (Y%4==0 && Y%100!=0) || Y%400==0 int main() { ...

  9. hadoop2.2编程:使用MapReduce编程实例(转)

    原文链接:http://www.cnblogs.com/xia520pi/archive/2012/06/04/2534533.html 从网上搜到的一篇hadoop的编程实例,对于初学者真是帮助太大 ...

  10. bzoj1046

    首先这肯定是一道LIS的变形,这次求的是方案,还要求字典序最小 (注意这个字典序最小是指下标最小而不是数最小) 首先预处理以每个数为首,能组成多长的上升序列(这里我们用单调队列解决) 然后按照位置顺序 ...