自定义UINavigationBar的背景【转】

简介:

from:http://cocoa.venj.me/blog/custom-navbar-background/

为了让我们的应用程序更加美观,我们往往希望对iPhone自带的控件进行一点自定义。比如,本文即将要讲述的,给UINavigationBar加一个背景。

最简单的一个自定义方法就是修改一下背景色。方法非常简单,那就是使用它的tintColor属性:

1
self.navigationController.navigationBar.tintColor = [UIColor redColor];

这样就轻松地为UINavigationBar加上了红色的背景色–当然你可以使用任何颜色。下面是模拟器中的测试效果:

另外,就是为UINavigationBar加背景图片。这个稍稍复杂一些–特别是对于iOS 5之前的iOS来说。先说说简单的,iOS 5已经为UINavigationBar增加了一个新的方法-setBackgroundImage:forBarMetrics:,专门用于设置UINavigationBar的背景图片。

Updated

删除了在iOS4下有问题的方法。

Update

适用于iOS 4的方法是在AppDelegate.m中创建一个UINavigationBar的Catagory,覆盖-drawRect:方法,如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
@implementation UINavigationBar (CustomImage)
- (void)drawRect:(CGRect)rect {
    UIImage *img = [UIImage imageNamed:@"navbar"];
    [img drawInRect:rect];
}
@end
...
//在后面加入判断是否支持iOS 5的代码,来提供对iOS 5的支持:
if ([bar respondsToSelector:@selector(setBackgroundImage:forBarMetrics:)]) {
    [bar setBackgroundImage:bg forBarMetrics:UIBarMetricsDefault];
}

这种方法将应用到程序中所有的UINavigationBar实例。但是通常来说,是不推荐覆盖系统自带的类中的方法的,所以我并不推荐使用这种方法。

这里介绍了更好的方法。

(全文完)

欢迎加群互相学习,共同进步。QQ群:iOS: 58099570 | Android: 330987132 | Go:217696290 | Python:336880185 | 做人要厚道,转载请注明出处!http://www.cnblogs.com/sunshine-anycall/p/3277824.html
相关文章
|
3月前
|
Android开发
在mPaaS框架中,要自定义通知栏背景色
【1月更文挑战第13天】【1月更文挑战第65篇】在mPaaS框架中,要自定义通知栏背景色
27 1
SwiftUI—如何将颜色、图片和图形作为视图的背景
SwiftUI—如何将颜色、图片和图形作为视图的背景
724 0
SwiftUI—如何将颜色、图片和图形作为视图的背景
|
Swift iOS开发
UISlider自定义滑动条高度(swift)
UISlider滑动条的高度系统默认给我们设定了,没有办法进行改变。可是,我们的设计又是需要改变这个高度的,怎么办呢?这个时候,我们可以写一个UISlider的子类,重写四个方法就能实现了。
3467 0
改变UITableView选中行高亮的颜色
改变UITableView选中行高亮的颜色
90 0
|
XML 前端开发 Android开发
AnimatedPathView实现自定义图片标签
老早用过小红书app,对于他们客户端笔记这块的设计非常喜欢,恰好去年在小红书的竞争对手公司,公司基于产品的考虑和产品的发展,也需要将app社交化,于是在社区分享这块多多少少参照了小红书的设计,这里面就有一个比较有意思的贴纸,标签等设计,这里用到了GpuImage的库,这个demo我也将代码开源了,有需要的去fork我的github的代码,今天要说的是详情页面的AnimatedPathView实
1108 0

热门文章

最新文章