UITabbarItem imageview 实现点击有放大然后还原的动画效果

本文详细介绍了如何在iOS应用中为UITabBarController的选中状态添加动画效果。通过使用KVC获取UIControl及UITabBarSwappableImageView,作者展示了如何自定义动画并将其应用于tabBar的图标上,实现图标缩放的视觉效果。
在UITabBarController代理方法中添加动画,先通过KVC获取UIControl,然后在获取上面的UITabBarSwappableImageView,最后将动画添加到imageview的layer上。
#pragma mark UITabBarControllerDelegate的代理方法
- (BOOL)tabBarController:(UITabBarController *)tabBarController shouldSelectViewController:(UIViewController *)viewController
{
    UIControl*tabBarButton = [viewController.tabBarItem valueForKey:@"view"];
    if (tabBarButton) {
        UIImageView * tabBarSwappableImageView = [tabBarButton valueForKey:@"info"];
        if ([tabBarSwappableImageView isKindOfClass:NSClassFromString(@"UITabBarSwappableImageView")]) {
            CAKeyframeAnimation * animation;
            animation = [CAKeyframeAnimation animationWithKeyPath:@"transform"];
            animation.duration = 0.3;
            animation.removedOnCompletion = YES;
            animation.fillMode = kCAFillModeForwards;
            NSMutableArray *values = [NSMutableArray array];
            [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(0.9, 0.9, 1.0)]];
            [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.2, 1.2, 1.0)]];
            [values addObject:[NSValue valueWithCATransform3D:CATransform3DMakeScale(1.0, 1.0, 1.0)]];
            animation.values = values;
            [tabBarSwappableImageView.layer addAnimation:animation forKey:nil];
        }
    }
    return YES;
}

 

转载于:https://www.cnblogs.com/weipeng168/p/10270409.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值