On iOS 7 we get new ways for customizing the UINavigationBar
. Apple has shared a sample project showing how you can change the appearance of the navigation bar by setting a custom back button, right view, title, background color and how to make a cool effect that makes the bar seem extended allowing us to attach other views, such as a label.
This sample project shows how you can embed a segmented control inside the navigation bar (as seen on the App Store app). Contrary to Apple's project, this one doesn't use AutoLayout and the view loads from a nib.
It is important to embed the view you would like to extend the nav bar, by placing it inside a generic view (ExtendedView), which can be used for drawing a one pixel hairline.
Finally the navigation bar doesn't actually get extended, rather it gives this impression by replacing the hairline with a transparent image.
- (void)willMoveToWindow:(UIWindow *)newWindow
{
// Use the layer shadow to draw a one pixel hairline under this view.
[self.layer setShadowOffset:CGSizeMake(0, 1.0f/UIScreen.mainScreen.scale)];
[self.layer setShadowRadius:0];
[self.layer setShadowColor:[UIColor blackColor].CGColor];
[self.layer setShadowOpacity:0.25f];
}
[self.navigationController.navigationBar setTranslucent:NO];
[self.navigationController.navigationBar setShadowImage:[UIImage imageNamed:@"TransparentPixel"]];
[self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"Pixel"] forBarMetrics:UIBarMetricsDefault];