Navigation上的BarButton添加动画效果

这个秘诀就是

UIBarButtonItem *backBarButton = [[UIBarButtonItem alloc] initWithCustomView:<#(UIView *)#>];

然后在view上添加动画效果就好了。

这里view上要添加TapGesture


在viewController中的设置

self.navigationController.navigationBar.clipsToBounds = YES;
    
    UITapGestureRecognizer *tapGesture = [[UITapGestureRecognizer alloc]initWithTarget:self
                                                                                action:@selector(backViewTapped:)];
    backView = [[BackView alloc]initWithFrame:CGRectMake(0, 0, 20, 20)];
    [backView addGestureRecognizer:tapGesture];
    UIBarButtonItem *backBarButton = [[UIBarButtonItem alloc] initWithCustomView:backView];
    [self.navigationItem setLeftBarButtonItem:backBarButton];


backView中加入一个imageView,在imageView上加动画

-(UIImageView *)imageView{
    if(!_imageView){
        _imageView = [[UIImageView alloc]initWithImage:[UIImage imageNamed:@"back"]];
    }
    return _imageView;
}

-(void)move{
    
    CABasicAnimation *animation = [CABasicAnimation animation];
    animation.keyPath = @"transform";
    
    animation.toValue = [NSValue valueWithCATransform3D:CATransform3DMakeTranslation(-5, 0, 0)];
    
    animation.duration = 0.5;
    [self.imageView.layer addAnimation:animation forKey:nil];
    
}

再在viewController中调用move的方法


-(void)viewDidAppear:(BOOL)animated{
    [super viewDidAppear: animated];
    [backView move];
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值