zoukankan      html  css  js  c++  java
  • 执行对象cocos2dx 2.x action动作整理集合

    在本篇文章中,我们主要介绍执行对象的内容,自我感觉有个不错的建议和大家分享下

        1.基本动作
         Cocos2d供给的基本动作:刹时动作、延时动作、运作速度。
         刹时动作:就是不须要时间,马上就完成的动作。刹时动作的共同基类是 InstantAction。
         Cocos2d供给以下刹时动作:

        

    •   放置 – Place

                    效果类似于 node.Position = ccp(x, y)。之所以作为一个动作来实现是为了可以与其他动作形成一个连续动作。

        

    •   隐藏 – Hide

                   效果类似于 [node setVisible:NO]. 之所以作为一个劢作来实现是为了可以与其他动作形成一个连续动作。

        

    •  显示 – Show

                   效果类似于 [node setVisible:YES]. 之所以作为一个动作来实现是为了可以与其他动作形成一个连续动作。

        

    • 可见切换 – ToggleVisibility

        
    2.延时动作
          延时动作就是指动作的完成须要一定时间。因此actionWithDuration 是延时动作执行时的第一个参数,延时动作的共同基类是 CCIntervalAction(包含了组合动作类)。
          Cocos2d供给以下刹时动作(函数命名规则是:XxxxTo: 意味着运动到指定的位置, XxxxBy:意味着运动到按照指定的 x、y 增量的位置。[x、y 可所以负值]):

        

    •  挪动到 – CCMoveTo
    • 挪动– CCMoveBy
    • 跳跃到 – CCJumpTo   设置终点位置和跳跃的高度和次数。
    • 跳跃 – CCJumpBy   设置终点位置和跳跃的高度和次数。
    • 贝塞尔 – CCBezierBy  支撑 3 次贝塞尔曲线:P0-出发点,P1-出发点切线方向,P2-终点切线方向,P3-终点。
    • 放大到 – CCScaleTo   设置放大倍数,是浮点型。
    • 放大 – CCScaleBy
    • 旋转到 – CCRotateTo
    • 旋转 – CCRotateBy
    • 闪烁 – CCBlink   设定闪烁次数
    • 色调变化到 – CCTintTo
    • 色调变换 – CCTintBy
    • 变暗到 – CCFadeTo
    • 由无变亮 – CCFadeIn
    • 由亮变无 – CCFadeOut

        
    3.组合动作
       按照一定的次序将上述基本动作组合起来,形成连贯的一套组合动作。组合动作包含以下几类:

        

    •  序列 – CCSequence

              Sequence 的应用非常简略,该类也从 CCIntervalAction 派生,本身就能够被 CocosNode 对象执行。该类的作用就是线序排列若干个动作,然后按先后次序逐一执行。

        

    • 同步 – Spawn

              Spawn 的应用非常简略,该类也从 IntervalAction 派生,本身就能够被CocosNode 对象执行。该类的作用就是同时并列执行若干个动作,但要求动作都必须是可以同时执行的。比如:挪动式翻转、变色、变大小等。
          须要特别注意的是,同步执行最后的完成时间由基本动作中用时最大者决议。

        

    • 重复有线次数 – Repeate
        每日一道理
    试试看——不是像企鹅那样静静的站在海边,翘首企盼机会的来临,而是如苍鹰一般不停的翻飞盘旋,执著的寻求。 试试看——不是面对峰回路转、杂草丛生的前途枉自嗟叹,而是披荆斩棘,举步探索。 试试看——不是拘泥于命运的禁锢,听凭命运的摆布,而是奋力敲击其神秘的门扉,使之洞开一个新的天地。微笑着,去唱生活的歌谣。

               重复无穷次数的动作,该类也从 IntervalAction 派生,可以被 CocosNode 对象执行。

        

    • 反动作 – Reverse

               反动作就是反向(逆向)执行某个动作,支撑针对动作序列的反动作序列。反动作不是一个专门的类,而是 CCFiniteAction 引入的一个接口。不是全部的类都支撑反动作,XxxxTo 类平日不支撑反动作,XxxxBy 类平日支撑。

        

    •  动画 – Animation

              动画就是让精灵自身连续执行一段影象,形成模拟运动的效果:行走时的精灵状态、打斗时的状态等。

        

    • 无穷重复 – RepeatForever

              RepeatForever 是从 Action 类直接派生的,因此无法参与序列和同步;自身也无法反向执行。该类的作用就是无穷期执行某个动作或动作序列,直到被停止。

    4.速度变化
          基本动作和组合动作实现了针对精灵的各种运动、动画效果的改变,但这样的改变的速度是不变的,通过 CCEaseAction 为基类的类系和 CCSpped 类我们可以很方便的修改精灵执行劢作的速度:由快至慢还是由慢至快。

        

    • EaseIn 由慢至快。
    • EaseOut 由快至慢
    • EaseInOut 由慢至快再由快至慢。
    • EaseSineIn
    • 由慢至快。

        

    • EaseSineOut 由快至慢
    • EaseSineInOut 由慢至快再由快至慢。
    • EaseExponentialIn 由慢至极快。
    • EaseExponentialOut 由极快至慢。
    • EaseExponentialInOut 由慢至极快再由极快至慢。
    • Speed 人工设定速度,还可通过 SetSpeed 一直调整。

        5.扩展动作

        

    •    延时动作 – Delay ,比如在动作序列中增加一个时间间歇

        

    • 函数调用
    • 函数

                  在动作序列旁边或者结束调用某个函数,执行任何须要执行的任务:动作、状态修改等。id acf = [CCCallFunc actionWithTarget:self selector:@selector(CallBack1)];对应的函数为:- (void) CallBack1 {
    [sprite runAction:[CCTintBy actionWithDuration:0.5 red:255 green:0 blue:255]]; }

        

    • 带对象参数--调用自定义函数时,传递以后对象。id acf = [CallFuncN actionWithTarget:self selector:@selector(CallBack2:)];对应的自定义函数:(这里,我们直接应用了该对象)
      - (void) CallBack2:(id)sender {
      [sender runAction:[CCTintBy actionWithDuration:1 red:255 green:0 blue:255]]; }
    • 带 对象、数据参数--用自定义函数时,传递以后对象和一个常量(也可所以指针)。id acf = [CCCallFuncND actionWithTarget:self selector:@selector(CallBack3:data:) data:(void*)2];对应的自定义函数,我们应用了传递的对象和数据:
      -(void) CallBack3:(id)sender data:(void*)data {
      [sender runAction:[CCTintBy actionWithDuration:(NSInteger)data red:255 green:0 blue:255]]; }

    文章结束给大家分享下程序员的一些笑话语录: 真正的程序员喜欢兼卖爆米花,他们利用CPU散发出的热量做爆米花,可以根据米花爆裂的速度听出正在运行什么程序。

  • 相关阅读:
    11月2日
    Rain和小爱的幸福山洞
    乍冷初寒
    支付宝接口源代码
    因没有设置文件夹权限导致的发布的页面不能在文本中写人数据
    asp.net真的是并行处理request的吗?
    Javascript学习笔记
    .net Windows服务程序和安装程序制作图解
    String.Trim()真相大揭秘
    c#基础知识总结学习
  • 原文地址:https://www.cnblogs.com/xinyuyuanm/p/3084576.html
Copyright © 2011-2022 走看看