CAKeyframeAnimation(关键帧动画)的简单使用

- (void)keyFramAnimation {
    //关键帧动画
    CAKeyframeAnimation *animation = [CAKeyframeAnimation animationWithKeyPath:@"position.x"];
    animation.duration = 0.3;
    //配置关键帧每一帧的值
    animation.values = @[@160,@150,@150,@170,@160];
//    animation.path
    //配置关键帧每一帧起始时间,范围 0 - 1
    animation.keyTimes = @[@0.0,@(1/6),@(3/6),@(5/6),@1.0];
    //配置关键帧每一帧之间的线性变换
//    animation.timingFunctions = @[
//        [CAMediaTimingFunction functionWithName:
//         kCAMediaTimingFunctionEaseInEaseOut],
//        [CAMediaTimingFunction functionWithName:
//         kCAMediaTimingFunctionEaseInEaseOut],
//        [CAMediaTimingFunction functionWithName:
//         kCAMediaTimingFunctionEaseInEaseOut],
//        [CAMediaTimingFunction functionWithName:
//         kCAMediaTimingFunctionEaseInEaseOut],
//        ];
    [self.view.layer addAnimation:animation forKey:@"position"];
}


输入验证失败的抖动效果:

- (void)animation {
    
    UITextField *name = (UITextField *)[self.view viewWithTag:10];
    CAKeyframeAnimation *kayFram = [CAKeyframeAnimation animationWithKeyPath:@"position"];
    kayFram.duration = 0.1;
    kayFram.repeatCount = 3;
    UIBezierPath *path = [[UIBezierPath alloc]init];
    [path moveToPoint:name.center];
    [path addLineToPoint:CGPointMake(name.center.x - 5,name.center.y)];
    [path addLineToPoint:CGPointMake(name.center.x + 5,name.center.y)];
    
    [path closePath];
    kayFram.path = path.CGPath;
    [path release];
    [name.layer addAnimation:kayFram forKey:@"position"];
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值