ios – 交换时淡化UIBarButtonItem

前端之家收集整理的这篇文章主要介绍了ios – 交换时淡化UIBarButtonItem前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
当我更改我的UIBarButtonItems时,它们会突然改变,不像默认情况下会提供一个漂亮而快速的淡入淡出动画.当在视图控制器之间进行切换时,您可以看到这一点,例如,后退按钮将淡入淡出.我该如何模拟相同的效果

解决方法

更新 – 基于此答案 – https://stackoverflow.com/a/10939684/2649021

看起来你必须做这样的事情才能使按钮本身淡出.

[self.navigationItem setRightBarButtonItem:nil animated:YES];

并做这样的事情让它淡入

[self.navigationItem setRightBarButtonItem:myButton animated:YES];

否则,如果你想要更多地控制动画属性,你必须创建一个我认为的自定义视图.

编辑:我刚刚确认您可以使用此方法淡化UIBarButtonItem自定义视图.

作为测试,我创建了一个简单的项目,并将UIBarButtonItem放到导航栏上.我为视图控制器创建了一个插座.在视图控制器上的viewDidLoad中,我设置了一个自定义视图

-(void)viewDidLoad{
    [super viewDidLoad];
    UILabel *lbl = [[UILabel alloc]initWithFrame:CGRectMake(0,40,40)];
    lbl.text = @"test";
    UIView *customView = [[UIView alloc]initWithFrame:CGRectMake(0,40)];
    [customView addSubview:lbl];
    self.barButtonItem.customView = customView;
}

作为viewDidAppear中的测试,我给它制作了动画

-(void)viewDidAppear:(BOOL)animated
{
    [UIView animateWithDuration:3.0 
                          delay:3.0 
                        options:UIViewAnimationOptionCurveEaSEOut        
                            animations:^{
                                self.barButtonItem.customView.alpha = 0;
                   } 
                     completion:^(BOOL finished) {
                                NSLog(@"animation complete");
}];

编辑:这里是苹果文档的链接,可以全面解释UIView动画.
https://developer.apple.com/library/ios/documentation/windowsviews/conceptual/viewpg_iphoneos/animatingviews/animatingviews.html

猜你在找的iOS相关文章