NavigationBar和StatusBar都有支持動畫的系統接口:
[[UIApplication sharedApplication] setStatusBarHidden:hidden withAnimation:UIStatusBarAnimationSlide];
[self.navigationController setNavigationBarHidden:hidden animated:animated];
但是簡單這樣寫的話,效果不太好,NavigationBar 和StatusBar消失的時候,動畫太快;出現的時候,StatusBar先出現,NavigationBar后滑出,而且動畫比較突兀。
以下代碼能讓NavigationBar 和StatusBar同時消失出現,而且比較平滑 :
- (void)toggleStatusBarAndNavBar:(BOOL)hidden {
UINavigationBar *navBar = self.navigationController.navigationBar;
[[UIApplication sharedApplication] setStatusBarHidden:hidden withAnimation:UIStatusBarAnimationSlide];
[UIView animateWithDuration:0.35 delay:0 options:UIViewAnimationOptionCurveEaseOut animations:^{
// 先顯示navigationBar
if (!hidden)
{
[self.navigationController setNavigationBarHidden:hidden animated:NO];
}
navBar.frame = CGRectMake(navBar.frame.origin.x,
hidden ? -navBar.frame.size.height : 20,
navBar.frame.size.width,
navBar.frame.size.height);
} completion:^(BOOL finished) {
if (hidden)
{
[self.navigationController setNavigationBarHidden:hidden animated:NO];
}
}];
}
- StatusBar的動畫風格選滑入
UIStatusBarAnimationSlide
,手動為NavigationBar的滑出滑入做動畫。 - 動畫風格選
UIViewAnimationOptionCurveEaseOut
,因為消失的時候StatusBar消失比較快,NavigationBar也需要快點消失;出現的時候NavigationBar需要慢點,動畫看起來比較流暢 - 要把握好hidden屬性和frame的變化動畫先后關系。