1、获取导航栏,状态栏,tabBar高度
1、状态栏
CGFloat statusHeight = [[UIApplication sharedApplication] statusBarFrame].size.height;
2、导航栏
CGFloat navigationHeight = self.navigationController.navigationBar.frame.size.height;
3、TabBar
CGFloat tabBarHeight = self.tabBarController.tabBar.frame.size.height;
2、导航栏的属性设置
1、title的属性
// 单纯设置字体为白色
self.navigationController.navigationBar.barStyle = UIBarStyleBlack;
// 设置任意颜色、字体大小
[self.navigationController.navigationBar setTitleTextAttributes:@{NSFontAttributeName:[UIFont boldSystemFontOfSize:22], NSForegroundColorAttributeName:[UIColor whiteColor]}];
2、导航栏背景颜色
//在设置导航栏背景颜色的时候,首先想到的是系统提供的方法
self.navigationController.navigationBar.barTintColor = [UIColor redColor];
//但是我们会发现设置的颜色不纯,跟实际显示出来的颜色有出入
//那么该如何正确的设置纯的背景颜色呢?有两种方法
1、通过设置navigationBar的属性translucent,设置成NO
2、通过设置navigationBar的背景图片setBackgroundImage
//当你按上述方法操作之后,会发现之前视图里面的view的frame下移64个单位。如果工程还用到导航栏的显示和隐藏的切换,那也会发现frame的变化,让导航栏的切换变得好不自然。
//解决办法:
self.extendedLayoutIncludesOpaqueBars = YES;
3、导航栏半透明
self.navigationController.navigationBar.translucent = YES;
4、隐藏导航栏
[self.navigationController setNavigationBarHidden:YES animated:animated];
5、改变导航栏背景为图片
[self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"image"] forBarMetrics:UIBarMetricsDefault];
3、UIViewAnimationOptions类型
1、常规动画属性设置(可以同时选择多个进行设置)
UIViewAnimationOptionLayoutSubviews:动画过程中保证子视图跟随运动
UIViewAnimationOptionAllowUserInteraction:动画过程中允许用户交互
UIViewAnimationOptionBeginFromCurrentState:所有视图从当前状态开始运行
UIViewAnimationOptionRepeat:重复运行动画
UIViewAnimationOptionAutoreverse :动画执行结束点后反向再执行一次
UIViewAnimationOptionOverrideInheritedDuration:忽略嵌套动画时间设置
UIViewAnimationOptionOverrideInheritedCurve:忽略嵌套动画速度设置
UIViewAnimationOptionAllowAnimatedContent:动画过程中重绘视图(注意仅仅适用于转场动画)
UIViewAnimationOptionShowHideTransitionViews:视图切换时直接隐藏旧视图、显示新视图,而不是将旧视图从父视图移除(仅仅适用于转场动画)
UIViewAnimationOptionOverrideInheritedOptions :不继承父动画设置或动画类型
2、动画速度控制(可从其中选择一个设置)
UIViewAnimationOptionCurveEaseInOut:动画先加速后减速,默认
UIViewAnimationOptionCurveEaseIn :动画由慢到快
UIViewAnimationOptionCurveEaseOut:动画由快到慢
UIViewAnimationOptionCurveLinear :动画匀速执行
3、转场类型(仅适用于转场动画设置,可以从中选择一个进行设置,基本动画、关键帧动画不需要设置)
UIViewAnimationOptionTransitionNone:没有转场动画效果
UIViewAnimationOptionTransitionFlipFromLeft :从左侧翻转效果
UIViewAnimationOptionTransitionFlipFromRight:从右侧翻转效果
UIViewAnimationOptionTransitionCurlUp:向后翻页的动画过渡效果
UIViewAnimationOptionTransitionCurlDown :向前翻页的动画过渡效果
UIViewAnimationOptionTransitionCrossDissolve:旧视图溶解消失显示下一个新视图的效果
UIViewAnimationOptionTransitionFlipFromTop :从上方翻转效果
UIViewAnimationOptionTransitionFlipFromBottom:从底部翻转效果
4、获取键盘高度
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillShow:) name:UIKeyboardWillShowNotification object:nil];
[[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(keyboardWillHide:) name:UIKeyboardWillHideNotification object:nil];
- (void)keyboardWillShow:(NSNotification *)noti {
//键盘的frame
CGRect frame = [[noti.userInfo objectForKey:UIKeyboardFrameEndUserInfoKey] CGRectValue];
}
- (void)keyboardWillHide:(NSNotification *)noti {
}
- (void)dealloc {
[[NSNotificationCenter defaultCenter] removeObserver:self];
}