UIView animation常用用法

UIView 动画一:


利用UIView animation进行平移操作


- (IBAction)click:(id)sender {

    

     [UIView beginAnimations:@"animations" context:nil];

     

     [UIView setAnimationDuration:1.5];

     

     CGRect frame = self.ball.frame;//imageView 的frame

     frame.origin.y += 200 * flag;

    flag =flag*( -1); //取反

     self.ball.frame = frame;

     

     [UIView commitAnimations];

     

     

    /*

    

    [UIView animateWithDuration:1.5 animations:^{

        CGRect frame = self.ball.frame;

        frame.origin.y += 100 * flag;//Y每次加100或减100

        flag *= -1; //取反

        self.ball.frame = frame;

    }];

     */

}


不仅可以得用UIView实现一些常用的动画,还可以通过设置代理来监听动画的开始或结束,如:


- (IBAction)click:(id)sender {

    

    [self.button setAlpha:0.0];

    

    [UIView beginAnimations:@"animations" context:nil];

    

    [UIView setAnimationDuration:1.5];

    [UIView setAnimationDelegate:self];//设置代理

    [UIView setAnimationWillStartSelector:@selector(viewAnimationStart)];//监听开始

    [UIView setAnimationDidStopSelector:@selector(viewAnimationDone)];//监听动画的结束

    

    CGRect frame = self.ball.frame;

    frame.origin.y += 100 * flag;

    flag *= -1; //取反

    self.ball.frame = frame;

    

    [UIView commitAnimations];

    

}


-(void)viewAnimationStart{

    NSLog(@"animation start-----");

}


- (void)viewAnimationDone {

    NSLog(@"animation end-----");

    [UIView beginAnimations:@"animationDone" context:nil];

    [self.button setAlpha:1.0];

    [UIView commitAnimations];

}


UIView 动画之回调:

还可以通过回调来监听动画的完成


    [UIView animateWithDuration:1.5 animations:^{

        CGRect frame = self.ball.frame;

        frame.origin.y += 100 * flag;

        flag *= -1; //取反

        self.ball.frame = frame;

    } completion:^(BOOL finished) {

        NSLog(@"动画结束了。");     

    }];



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值