It feels like this should be fairly simple but nothing i’ve tried so far has worked. In a nutshell, I want to add a fixed image just below the navigation bar in a UITableViewController that i create programmatically. In other words, I want the image to stay just below the navigation bar even as the user scrolls up and down the table view (it’s basically a custom drop-shadow for the navigation bar).
The closest I’ve gotten is the code below (in the UITableViewController’s init method), which adds the image but doesn’t keep it from moving when the user scrolls.
// Add nav bar drop shadow
UIImage *dropShadowImage = [UIImage imageNamed:@"NavBarDropShadow.png"];
UIImageView *dropShadowView = [[UIImageView alloc] initWithImage:dropShadowImage];
[self.view addSubview:dropShadowView];
Is there an easy way to add an add an image to the screen programmatically, position it wherever you like, and have it stay there even as the user scrolls? Thanks for any and all input!
EDIT: IOS5 has a better way to do this. Please check out the new UIAppearance protocol.
Adding this block of code to your code will allow you to draw your shadow on all UINavigationBars in the app. This is a better solution than adding the shadow as a UIImageView:
To make the UINavigationBar higher and thus not clipping your content, override the
layoutSubviewsand set the frame you need (the code above assumes your header is 300 points high).layoutSubviewsdoes nothing by default, but is “lazy” called before lay-outing the view.For more info about this custom size/look overrides that apply to UIView (and any other subclass) have a look here