关于IOS9.0遇到的一些问题




关于IOS9.0 需要配置白名单适配啥的,这里有个链接,写的很详细,可以参考下:https://github.com/ChenYilong/iOS9AdaptationTips



接下来就说在 真机在IOS9 上遇到的一些问题:





1,多语言问题




由于 手上做的app 是国际化的app,因此做了多语言,使用了系统的NSlocalizedString。多语言做了法语,西班牙, 葡萄牙 三种语言,但是有些用户反馈:当手机切换到非这三种语言的时候,本该显示英文的,却显示了中文(出现这种问题,应该是 IOS多语言备选规则问题)。所以决定自己写个方法去加载多语言包


</pre><pre name="code" class="objc">if ([SYSTEM_LANG isEqualToString:@"fr-CA"] || [SYSTEM_LANG isEqualToString:@"fr"])  // 法国 及 地区 语言
    {
        NSString *pathString = [[NSBundle mainBundle] pathForResource:@"fr" ofType:@"lproj"];
        NSBundle *enLanguageBundle = [NSBundle bundleWithPath:pathString];
        valueString = [enLanguageBundle localizedStringForKey:keyString value:nil table:nil];
    }
    else if ([SYSTEM_LANG isEqualToString:@"es-MX"] || [SYSTEM_LANG isEqualToString:@"es"]) // 西班牙 及 地区 语言
    {
        NSString *pathString = [[NSBundle mainBundle] pathForResource:@"es" ofType:@"lproj"];
        NSBundle *enLanguageBundle = [NSBundle bundleWithPath:pathString];
        valueString = [enLanguageBundle localizedStringForKey:keyString value:nil table:nil];
    }
    else if ([SYSTEM_LANG isEqualToString:@"pt"] || [SYSTEM_LANG isEqualToString:@"pt-PT"] )
    {
        NSString *pathString = [[NSBundle mainBundle] pathForResource:@"pt" ofType:@"lproj"];
        NSBundle *enLanguageBundle = [NSBundle bundleWithPath:pathString];
        valueString = [enLanguageBundle localizedStringForKey:keyString value:nil table:nil];
    }

以上代码我用的是  

isEqualToString 方法,但是  [[[NSUserDefaults standardUserDefaults] objectForKey:@"AppleLanguages"] objectAtIndex:0]   这个方法在IOS9返回的字符串 多了“-CH”,导致判断不成功,法语语言系统下显示的不是法语,而是英语。只需要把 isEqualToString 方法 改为   hasPrefix (只判断前缀) 即可解决。


2,UIPickerView 问题






在IOS6,IOS7,IOS8  写过 UIpickerView的都知道,这个控件的高度是不需要自己设置的,你可以把高度设置为0照样可以显示,当你获取这个控件高度的时候,返回的不是0,而是该控件的真实高度。但是在IOS9.0,你设置的是0,获取改控件高度的时候 给你返回的也是0,IOS9.0 该控件给你返回的是你设置的高度,有兴趣的童鞋可以去尝试下。


UIView *coverView = [[UIView alloc] initWithFrame:CGRectMake(0, 0, SCREEN_SIZE.width, SCREEN_SIZE.height)];
                    coverView.tag = COVER_VIEW_TAG;
                    coverView.backgroundColor = RGBACOLOR(0, 0, 0, 1);
                    coverView.alpha = 0;
                    
                    UIButton *cancelBtn = [UIButton buttonWithType:UIButtonTypeCustom];
                    cancelBtn.tag = CANCEL_BTN_TAG;
                    cancelBtn.frame = CGRectMake(0, 0, 60, 44);
                    [cancelBtn setTitle:[StaticMethods getLanTextStrByKey:@"CANCEL"] forState:UIControlStateNormal];
                    cancelBtn.titleLabel.adjustsFontSizeToFitWidth = YES;
                    [cancelBtn setTitleColor:RGBACOLOR(0, 122, 255, 1) forState:UIControlStateNormal];
                    [cancelBtn addTarget:self action:@selector(timeAction:) forControlEvents:UIControlEventTouchUpInside];
                    
                    UIButton *comfirmBtn = [UIButton buttonWithType:UIButtonTypeCustom];
                    comfirmBtn.tag = COMFIRM_BTN_TAG;
                    comfirmBtn.frame = CGRectMake(coverView.bounds.size.width-60, 0, 60, 44);
                    [comfirmBtn setTitle:[StaticMethods getLanTextStrByKey:@"OK"] forState:UIControlStateNormal];
                    comfirmBtn.titleLabel.adjustsFontSizeToFitWidth = YES;
                    [comfirmBtn setTitleColor:RGBACOLOR(0, 122, 255, 1) forState:UIControlStateNormal];
                    [comfirmBtn addTarget:self action:@selector(timeAction:) forControlEvents:UIControlEventTouchUpInside];
                    
                    UIPickerView *pickerView = [[UIPickerView alloc] initWithFrame:CGRectMake(0, 44, coverView.frame.size.width, 219.0)];
                    pickerView.backgroundColor = [UIColor whiteColor];
                    pickerView.delegate = self;
                    pickerView.dataSource = self;
                    [pickerView selectRow:0 inComponent:0 animated:NO];
                    [self pickerView:pickerView didSelectRow:0 inComponent:0];
                    [pickerView selectRow:initValue2-1 inComponent:1 animated:NO];
                    [self pickerView:pickerView didSelectRow:initValue2-1 inComponent:1];
                    pickerView.tag = PICKERVIEW_TAG;
                    
                    UIView *buttonBgView = [[UIView alloc] initWithFrame:CGRectMake(0, coverView.frame.size.height, coverView.frame.size.width, 44+pickerView.frame.size.height)];
                    buttonBgView.tag = BUTTON_BG_VIEW_TAG;
                    buttonBgView.backgroundColor = RGBACOLOR(227, 227, 227, 1);
                    [buttonBgView addSubview:cancelBtn];
                    [buttonBgView addSubview:comfirmBtn];
                    [buttonBgView addSubview:pickerView];
                    
                    [self.view addSubview:coverView];
                    [self.view addSubview:buttonBgView];
                    [UIView animateWithDuration:0.2f animations:^{
                        coverView.alpha = 0.6;
                        buttonBgView.center = CGPointMake(buttonBgView.center.x, buttonBgView.center.y-buttonBgView.frame.size.height);
                    } completion:^(BOOL finished) {
                        
                    }];
                    [pickerView release];
                    [buttonBgView release];
                    [coverView release];






3, UIAlertView问题     




(1),早在IOS8.0的时候,苹果就推荐我们使用 UIAlertController 来代替UIAlerView,但是小编那个时候偷懒,UIalerView在IOS8.0 照样是可以用的,就没有去理会,但是IOS9.0更新的时候,测试那边发现 在IOS9.0系统下的设备 UIAlertView 圆角会变化 并且该控件会抖动,具体抖动的原因有可能是IOS9.0的动画做了修改,导致不兼容引起的。好,抖动,圆角变化是吧,没关系,把所有的UIalerView 做个判断 IOS8.0以上 就使用 UIAlertController,并且把动画设置为NO,好,这解决了抖动 和 圆角的问题,完美。。。



if (SYSTEM_IOS8)
    {
        if ([self.navigationController.visibleViewController isKindOfClass:[UIAlertController class]])
        {
            [self dismissViewControllerAnimated:NO completion:^{
                [ConnectManager writeLog:@"end Login"];
            }];
            return YES;
        }
    }
    else
    {
        if (self.retainAlertView && self.retainAlertView.tag==LOGIN_ALERTVIEW_TAG) {
            self.retainAlertView.delegate = nil;
            [self.retainAlertView dismissWithClickedButtonIndex:self.retainAlertView.cancelButtonIndex animated:NO];
            self.retainAlertView = nil;
            
            return YES;
        }
    }





(2),改了之后,圆角 和 抖动 是没有了,但是self.navigationController.visibleViewController 貌似有所不同 了。用UIAlertController 之后,当该控件 弹出来 的时候  self . navigationController . visibleViewController 并不是 ViewControllers 堆栈中 元素,而是 UIAlertController对象(估计UIAlertController 是一个模态的形式弹出来的)。如果使用了self.navigationController.visibleViewController 做判断是否是self(self 指的是当前ViewController)的童鞋 要注意这可能会有些问题,小编 已经 把slef.navigationController.visibleViewController 改为了[self.navigationController.viewControllerslastObject]  来做判断了,这样就没有什么问题。


以前是:

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
}

- (BOOL)isSelfShowInWindow
{
    if (self.navigationController.visibleViewController == self) //当前显示视图 是否是自己
    {
        //逻辑处理
        return YES;
    }
    return NO;
}

改为:


- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
}

- (BOOL)isSelfShowInWindow
{
    if ([self.navigationController.viewControllers lastObject] == self) //当前显示视图 是否是自己
    {
        //逻辑处理
        return YES;
    }
    return NO;
}



(3),以上两个问题 都是体力活,改好了之后没什么问题,但是又有新的问题: 模态弹出,系统动画冲突。



小编编译app在跑着跑着的,突然发现 self.navigationController setViewControllers 这个方法没有执行,然后在控制台 看到 编译器 输出这么一句 “ while an existing transition or presentation is occurring; the navigation stack will not be updated”,看到这句话 顿时就有点蒙了,仔细想了想应该UIAlertController引起的。很有可能是IOS9 系统动画冲突了,这个真是蛋疼,但是IOS8 好像也是又出现过。



UIAlertController 弹出是模态弹出,当这个弹出或者动画没有结束的时候,任何pop,push,setViewControllers 貌似都是没有用的。



解决的办法就是:延迟执行 push,pop ,setViewControllers 方法(系统卡顿 也可能会无法pop,push),或者自定义UIAlertController控件,当然不使用该控件也是可以的。