1. 程式人生 > >Tabbar點選時候超炫小動畫

Tabbar點選時候超炫小動畫

//程式碼貼上到 UITabBarController控制器即可  效果如上

- (void)tabBar:(UITabBar *)tabBar didSelectItem:(UITabBarItem *)item {

    
    NSInteger index = [self.tabBar.items indexOfObject:item];
    
    if (self.selectedIndex != index) {
        [self animationWithIndex:index];
    }
    
}
// 動畫
- (void)animationWithIndex:(NSInteger) index {
    NSMutableArray * tabbarbuttonArray = [NSMutableArray array];
    for (UIView *tabBarButton in self.tabBar.subviews) {
        if ([tabBarButton isKindOfClass:NSClassFromString(@"UITabBarButton")]) {
            [tabbarbuttonArray addObject:tabBarButton];
        }
    }
    CABasicAnimation*pulse = [CABasicAnimation animationWithKeyPath:@"transform.scale"];
    pulse.timingFunction= [CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionEaseInEaseOut];
    pulse.duration = 0.08;
    pulse.repeatCount= 1;
    pulse.autoreverses= YES;
    pulse.fromValue= [NSNumber numberWithFloat:0.7];
    pulse.toValue= [NSNumber numberWithFloat:1.3];
    [[tabbarbuttonArray[index] layer]
     addAnimation:pulse forKey:nil];
    self.selectedIndex = index;
}