1. #include "HelloWorldScene.h"
  2. #include "SimpleAudioEngine.h"
  3. using namespace cocos2d;
  4. using namespace CocosDenshion;
  5. CCScene* HelloWorld::scene()
  6. {
  7. CCScene *scene = CCScene::create();
  8. HelloWorld *layer = HelloWorld::create();
  9. scene->addChild(layer);
  10. return scene;
  11. }
  12. bool HelloWorld::init()
  13. {
  14. if ( !CCLayer::init() )
  15. {
  16. return false;
  17. }
  18. size = CCDirector::sharedDirector()->getWinSize();
  19. //加一背景
  20. CCLayerColor* background = CCLayerColor::create(ccc4(255, 180, 255, 255), size.width, size.height);
  21. this->addChild(background);
  22. actionIsDone = true;//标示动作是否完毕
  23. createPoker(); //创建扑克
  24. return true;
  25. }
  26. //创建扑克
  27. void HelloWorld::createPoker()
  28. {
  29. //扑克牌正面
  30. CCSprite* pokerFront = CCSprite::create("poker_front.png");
  31. pokerFront->setVisible(false);
  32. pokerFront->setPosition(ccp(size.width/2, size.height/2));
  33. this->addChild(pokerFront,1,123);
  34. //扑克牌反面
  35. CCSprite* pokerBack = CCSprite::create("poker_back.png");
  36. pokerBack->setPosition(pokerFront->getPosition());
  37. this->addChild(pokerBack,1,321);
  38. }
  39. //翻牌动作
  40. void HelloWorld::startOrbitAction()
  41. {
  42. //扑克牌正面
  43. CCSprite* pokerFront = (CCSprite*)this->getChildByTag(123);
  44. //扑克牌反面
  45. CCSprite* pokerBack = (CCSprite*)this->getChildByTag(321);
  46. float orbitTime = 1;
  47. if (pokerFront->isVisible() == false && actionIsDone == true) {
  48. actionIsDone = false;
  49. //第一个參数是旋转的时间,第二个參数是起始半径,第三个參数半径差。第四个參数是起始Z角。
  50. 第五个參数是旋转Z角差。第六个參数是起始X角。最后一个參数旋转X角差,
  51. //顺时钟翻转

            CCOrbitCamera* orbitFront = CCOrbitCamera::create(orbitTime, 1, 0, 270, 90, 0, 0);
  52. CCSequence* sequenceFront = CCSequence::createWithTwoActions(CCShow::create(), orbitFront);
  53. CCTargetedAction* targetFront = CCTargetedAction::create(pokerFront, sequenceFront);
  54. CCOrbitCamera* orbitBack = CCOrbitCamera::create(orbitTime, 1, 0, 0, 90, 0, 0);
  55. pokerBack->runAction(CCSequence::create(orbitBack, CCHide::create(), targetFront, CCCallFunc::create(this, callfunc_selector(HelloWorld::actionIsDownFunc)),NULL));
  56. }else if(pokerFront->isVisible() == true && actionIsDone == true){
  57. actionIsDone = false;
  58. //逆时钟翻转

            CCOrbitCamera* orbitFront = CCOrbitCamera::create(orbitTime, 1, 0, 270, 90, 180, 0);
  59. CCSequence* sequenceFront = CCSequence::createWithTwoActions(CCShow::create(), orbitFront);
  60. CCTargetedAction* targetFront = CCTargetedAction::create(pokerBack, sequenceFront);
  61. CCOrbitCamera* orbitBack = CCOrbitCamera::create(orbitTime, 1, 0, 0, 90, 0, 0);
  62. pokerFront->runAction(CCSequence::create(orbitBack, CCHide::create(), targetFront, CCCallFunc::create(this, callfunc_selector(HelloWorld::actionIsDownFunc)),NULL));
  63. }
  64. }
  65. void HelloWorld::actionIsDownFunc()
  66. {
  67. actionIsDone = true;
  68. }
  69. bool HelloWorld::ccTouchBegan(CCTouch *pTouch, CCEvent *pEvent)
  70. {
  71. //翻牌动作
  72. startOrbitAction();
  73. return true;
  74. }
  75. void HelloWorld::ccTouchMoved(CCTouch *pTouch, CCEvent *pEvent){}
  76. void HelloWorld::ccTouchEnded(CCTouch *pTouch, CCEvent *pEvent){}
  77. void HelloWorld::onEnter()
  78. {
  79. CCDirector::sharedDirector()->getTouchDispatcher()->addTargetedDelegate(this, 0, false);
  80. CCLayer::onEnter();
  81. }
  82. void HelloWorld::onExit()
  83. {
  84. CCDirector::sharedDirector()->getTouchDispatcher()->removeDelegate(this);
  85. CCLayer::onExit();
  86. }
  87. HelloWorld::~HelloWorld(){}

两张扑克牌资源:

               

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc29uZ19odWlfeGlhbmc=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" style="border:none; max-width:100%"> 
        

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvc29uZ19odWlfeGlhbmc=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" style="border:none; max-width:100%; font-family:SimSun; color:rgb(51,102,255); font-size:18px">


cocos2dx 利用CCOrbitCamera实现扑克牌翻牌效果的更多相关文章

  1. Cocos2d-x实现简单的翻牌效果

    触发器互联网影响找了很多.有自己的点重写一个复杂的sprite类来实现.简单的操作来对引擎的使用CCOrbitCamera实现,但是,也存在一些问题,后变反了. 我在用的仅仅是一个简单的翻牌效果,点击 ...

  2. cocos2dx翻牌效果示例

    实现类似翻扑克牌的效果 代码如下: OrbitCamera* rotate1; OrbitCamera* rotate2; if(towardRight){//向右翻转 rotate1=OrbitCa ...

  3. 利用div实现遮罩层效果

    利用div实现遮罩层效果就是利用一个全屏.半透明的div遮住页面上其它元素,典型的例子就是百度的登录界面.下面贴出示例代码: <!DOCTYPE html> <html> &l ...

  4. css3之3D翻牌效果

      最近一直在学css3,发现他真的是越来越牛逼.现在的css3已经不在是以前的css了,它能做出的功能效果是我们没法想象的了.它可以实现flash,可以制作一些js能做出来的效果,还可以写出ps做出 ...

  5. 利用MARQUEE实现正在处理效果

    ASP.NET服务器端事件利用MARQUEE实现正在处理效果   前言:ASP.NET同仁们应该都遇到过当触发一个比较耗时的服务器端事件时,页面会处在一个等待的状态(即假死状态),用户体验非常不好,很 ...

  6. css3 翻牌效果

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

  7. HTML5 CSS3专题 诱人的实例 CSS3打造百度贴吧的3D翻牌效果

    首先感谢w3cfuns的老师~ 今天给大家带来一个CSS3制作的翻牌效果,就是鼠标移到元素上,感觉可以看到元素背后的信息.大家如果制作考验记忆力的连连看.扑克类的游戏神马的,甚至给女朋友写一些话语,放 ...

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

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

  9. jQuery精仿手机上的翻牌效果菜单

    代码简介: jQuery精仿手机上的翻牌效果菜单,很平滑的动画翻牌效果,每点击一下菜单,就会翻去一下,貌似很灵敏的动作.注意:如果预览时没看到效果,请刷新一下页面,让jquery载入就行了,在实际使用 ...

随机推荐

  1. 图片跟着鼠标动js

    <!DOCTYPE html><html><head> <title>duisgf</title> <meta charset=&qu ...

  2. component object model(组件对象模型)

    通常,COM是以 win32动态链接库(dll)或可执行文件(exe)的形式发布. 在COM中,接口就是一切,对于客户来说,一个组件就是一个接口集.COM接口是一个包含一个函数指针数组的内存结构. 组 ...

  3. linux FILE 类型.

    stdio.h 头文件中,有以下内容(用内部行号解释): /* The opaque type of streams. This is the definition used elsewhere. * ...

  4. mysql 存储引擎MYSIAM和INNODB特性比较

    事物:MYISAM不支持事物,MyISAM类型的表强调的是性能,其执行数度比InnoDB 类型更快.如果不考虑事物,大量的select和insert适合MYISAM表 锁:MYISAM支持表锁    ...

  5. PHP include 和 require

    PHP include 和 require 语句 在 PHP 中,您可以在服务器执行 PHP 文件之前在该文件中插入一个文件的内容. include 和 require 语句用于在执行流中插入写在其他 ...

  6. C#中英文混合字符串过长截断

    /// <summary> /// 截断字符串 /// </summary> /// <param name="maxLength">最大长度& ...

  7. Convert String to Long

    问题: Given a string, write a routine that converts the string to a long, without using the built in f ...

  8. 《Javascript模式》之对象创建模式读书笔记

    引言: 在javascript中创建对象是很容易的,可以使用对象字面量或者构造函数或者object.creat.在接下来的介绍中,我们将越过这些方法去寻求一些其他的对象创建模式. 我们知道js是一种简 ...

  9. github 使用方法总结 还有一部分不太懂

    1  github在新的目录下添加新的文件 git init //在相应的目录下添加 git add //添加目录 git commit -m "first commit" git ...

  10. pdf转图片

    public class FileUtil { public static void main(String[] args) { try { System.out.println(System.cur ...