当前位置:首页 > 开发 > 移动开发 > 正文

两个动画效果

发表于: 2014-04-25   作者:374016526   来源:转载   浏览:
摘要: // 心跳动画 + (void)heartbeatView:(UIView *)view duration:(CGFloat)fDuration {     [[selfclass] heartbeatView:view duration:fDuration maxSize:1.4fdurationPerBeat:0.5f]; } + (void)heartbeatV

// 心跳动画

+ (void)heartbeatView:(UIView *)view duration:(CGFloat)fDuration

{

    [[selfclass] heartbeatView:view duration:fDuration maxSize:1.4fdurationPerBeat:0.5f];

}

+ (void)heartbeatView:(UIView *)view duration:(CGFloat)fDuration maxSize:(CGFloat)fMaxSize durationPerBeat:(CGFloat)fDurationPerBeat

{

    if (view && (fDurationPerBeat > 0.1f))

    {

        CAKeyframeAnimation *animation = [CAKeyframeAnimationanimationWithKeyPath:@"transform"];

        

        CATransform3D scale1 = CATransform3DMakeScale(0.8, 0.8, 1);

        CATransform3D scale2 = CATransform3DMakeScale(fMaxSize, fMaxSize, 1);

        CATransform3D scale3 = CATransform3DMakeScale(fMaxSize - 0.3f, fMaxSize - 0.3f, 1);

        CATransform3D scale4 = CATransform3DMakeScale(1.0, 1.0, 1);

        

        NSArray *frameValues = [NSArray arrayWithObjects:

                                [NSValue valueWithCATransform3D:scale1],

                                [NSValue valueWithCATransform3D:scale2],

                                [NSValue valueWithCATransform3D:scale3],

                                [NSValue valueWithCATransform3D:scale4],

                                nil];

        

        [animation setValues:frameValues];

        

        NSArray *frameTimes = [NSArray arrayWithObjects:

                               [NSNumber numberWithFloat:0.05],

                               [NSNumber numberWithFloat:0.2],

                               [NSNumber numberWithFloat:0.6],

                               [NSNumber numberWithFloat:1.0],

                               nil];

        [animation setKeyTimes:frameTimes];

        

        animation.fillMode = kCAFillModeForwards;

        animation.duration = fDurationPerBeat;

        animation.repeatCount = fDuration/fDurationPerBeat;

        

        [view.layer addAnimation:animation forKey:@"heartbeatView"];

    }else{}

 

}

 

 

 

 

 

// 视图抖动动画

+ (void)shakeView:(UIView *)view duration:(CGFloat)fDuration

{

    if (view && (fDuration >= 0.1f))

    {

        CABasicAnimation* shake = [CABasicAnimationanimationWithKeyPath:@"transform.rotation.z"];

        //设置抖动幅度

        shake.fromValue = [NSNumber numberWithFloat:-0.3];

        shake.toValue = [NSNumber numberWithFloat:+0.3];

        shake.duration = 0.1f;

        shake.repeatCount = fDuration/4/0.1f;

        shake.autoreverses = YES;

        [view.layer addAnimation:shake forKey:@"shakeView"];

    }else{}

 

}

 

两个动画效果

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

编辑推荐
在Android开发过程中,经常会碰到Activity之间的切换效果的问题,下面介绍一下如何实现左右滑动的切
Text主要总结UILabel、UITextField、UITextView、UIMenuController以及UIWebView/WKWebView相关的一
前几天下载了一个软件,activity之间跳转是用的淡出动画效果,今天有时间自己也从网上查了一下资料
前几天下载了一个软件,activity之间跳转是用的淡出动画效果,今天有时间自己也从网上查了一下资料
animate.css 是提供炫酷,有趣,跨浏览器css3动画的网站,你可以在高级项目中使用这些效果,为高级
CSS3添加了几个动画效果的属性,通过设置这些属性,可以做出一些简单的动画效果而不需要再去借助Jav
在jQuery中,虽然有很多动画方法,实现各种各样的动画效果,但综合起来,绝大部分的动画方法仅仅是
google首页的动画效果 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:/
public class RollActivity extends Activity { private View view; private Button btn; private P
在ListView组件中配置动画效果,首先xml配置和上一节课GridView中一模一样,同样需要 anim/anim_set
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号