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牌轮抽一样,前期要找着质量牌抓,保证你至少不漏.根据你的需求补一些你不会上场的阵容组件,最后根据你的组件和核心紫卡来哪张来决定打什么.另外也要考虑场上另外几家,如果有一家 ...
随机推荐
- Linux 系统挂载数据盘
适用系统:Linux(Redhat , CentOS,Debian,Ubuntu) * Linux的云服务器数据盘未做分区和格式化,可以根据以下步骤进行分区以及格式化操作. 下面的操作将会把数据盘划 ...
- [状压dp]HDOJ3182 Hamburger Magi
题意 大致是: 有n个汉堡 m块钱 (n<=15) 然后分别给n个汉堡的能量 再分别给n个汉堡所需的花费 然后下面n行 第i行有x个汉堡要在i汉堡之前吃 然后给出这x个汉堡的编号 输出 能获得 ...
- 李洪强漫谈iOS开发[C语言-021]-运算符
- MyGui 3.2.0(OpenGL平台)的编译(五篇文章)
MyGui是一个用来创建用户图形界面的库,用于游戏和3D应用程序.这个库的主要目标是达到:快速.灵活.易用. 1.下载准备: 源代码:http://svn.code.sf.net/p/my-gui/c ...
- SQL Server系统表和常用函数(转)
sysaltfiles 主数据库 保存数据库的文件 syscharsets 主数据库 字符集与排序顺序sysconfigures 主数据库 配置选项syscurconfigs 主数据库 当前配置选项s ...
- ODBC具体使用
应用程序 应用程序对外提供使用者交谈界面,同时对内执行资料之准备工作数据库系统所传回来的结果在显示给使用者看.简单来说,应用程序即ODBC 界面执行下列主要工作:1. Request a connec ...
- 【HDOJ】1356 The Balance
扩展欧几里得的应用. /* 1356 */ #include <iostream> #include <sstream> #include <string> #in ...
- Com和DCOM
COM,DCOM原理及应用 1.DCOM COM的进程透明特性表现在组件对象和客户程序即可以拥有各自的进程空间,也可以共享同一个进程空间,COM负责把客户的调用正确传到组件对象中,并保证参数传递的正确 ...
- [HDU 1963] Investment
Investment Time Limit:10000MS Memory Limit:32768KB 64bit IO Format:%lld & %llu Descrip ...
- 浅谈 HTML5 的 DOM Storage 机制 (转)
在开发 Web 应用时,开发者有时需要在本地存储数据.当前浏览器支持 cookie 存储,但其大小有 4KB 的限制.这对于一些 Ajax 应用来说是不够的.更多的存储空间需要浏览器本身或是插件的支持 ...