本文最后更新于:2021年12月22日 中午
iOS 5及其以后提供了一个比较强大的工具UIAppearance,我们通过UIAppearance设置一些UI的全局效果,这样就可以很方便的实现UI的自定义效果又能最简单的实现统一界面风格,但是需要注意使用细则:
1、控件遵守了UIAppearance协议,才能对控件进行appearance设置
2、只有被UI_APPEARANCE_SELECTOR这个宏修饰的属性才能使用appearance进行设置,其他属性则不具备该功能
3、appearance设置需要在该控制显示之前设置完成,否则可能无效
它提供如下两个方法:
这个方法是统一全部改,比如你设置UINavigationBar的tintColor,你可以这样写:
1
| [[UINavigationBar appearance] setTintColor:myColor];
|
1
| + (id)appearanceWhenContainedIn:(Class <>)ContainerClass,...
|
这个方法可设置某个类的改变,例如:
设置UIBarButtonItem 在UINavigationBar、UIPopoverController、UITabbar中的效果,就可以这样写:
1
| [[UIBarButtonItem appearanceWhenContainedIn:[UINavigationBar class], [UIPopoverController class], [UITabbar class], nil] setTintColor:myColor];
|
请注意:使用appearance设置UI效果最好采用全局的设置,在所有界面初始化前开始设置,否则可能失效。
具体UI外观修改如下:
修改导航栏背景
代码如下:
1 2 3 4
| UINavigationBar * appearance = [UINavigationBar appearance]; UIImage *navBgImg =[UIImage imageNamed:@"bgImage"];
[appearance setBackgroundImage:navBgImg forBarMetrics: UIBarMetricsDefault];
|
标签栏(UITabbar)
代码如下:
1 2 3 4 5 6
| UITabBar *appearance = [UITabBar appearance];
[appearance setBackgroundImage:[UIImage imageNamed:@"bgImage"]];
UIImage * selectedImage =[[UIImage imageNamed:@"sliderImage"] resizableImageWithCapInsets:UIEdgeInsetsMake(2, 2, 2, 2)] ; [appearance setSelectionIndicatorImage:selectedImage];
|
分段控件(UISegmentControl)
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
| UISegmentedControl *appearance = [UISegmentedControl appearance];
[appearance setBackgroundImage:[UIImage imageNamed:@"image"] forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];
[appearance setBackgroundImage:[UIImage imageNamed:@"bgImage"] forState:UIControlStateSelected barMetrics:UIBarMetricsDefault];
[appearance setDividerImage:[UIImage imageNamed:@"line"] forLeftSegmentState:UIControlStateNormal rightSegmentState:UIControlStateNormal barMetrics:UIBarMetricsDefault];
[appearance setDividerImage:[UIImage imageNamed:@"line"] forLeftSegmentState:UIControlStateSelected rightSegmentState:UIControlStateNormal barMetrics:UIBarMetricsDefault];
[appearance setDividerImage:[UIImage imageNamed:@"line"] forLeftSegmentState:UIControlStateNormal rightSegmentState:UIControlStateSelected barMetrics:UIBarMetricsDefault];
NSDictionary *textAtt1 = @{ NSFontAttributeName: [UIFont systemFontOfSize:18], NSForegroundColorAttributeName: [UIColor blueColor], NSShadowAttributeName: [UIColor whiteColor]};
[appearance setTitleTextAttributes:textAtt1 forState:1];
NSDictionary *textAtt2 = @{ NSFontAttributeName: [UIFont systemFontOfSize:18], NSForegroundColorAttributeName: [UIColor blueColor], NSShadowAttributeName: [UIColor whiteColor]};
[appearance setTitleTextAttributes:textAtt2 forState:0];
|
注意:UIBarbutton有leftBarButton,rightBarButton和backBarButton,其中backBarButton由于带有箭头,需要单独设置。barButton背景设置是ios6.0及以后的,而backbutton是ios5.0及以后的,这里要注意!
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| UIBarButtonItem *appearance = [UIBarButtonItem appearanceWhenContainedIn: [UINavigationBar class], nil];
NSDictionary *textAttributes = @{ NSFontAttributeName: [UIFont systemFontOfSize:18], NSForegroundColorAttributeName: [UIColor blueColor], NSShadowAttributeName: [UIColor whiteColor]};
[appearance setTitleTextAttributes:textAttributes forState:1];
[appearance setBackgroundImage:[UIImage imageNamed:@"image"] forState:UIControlStateNormal style:UIBarButtonItemStyleBordered barMetrics:UIBarMetricsDefault];
[appearance setBackgroundImage:[UIImage imageNamed:@"image"] forState:UIControlStateHighlighted style:UIBarButtonItemStyleBordered barMetrics:UIBarMetricsDefault];
[appearance setBackButtonBackgroundImage:[UIImage imageNamed:@"bgImage"] forState:0 barMetrics:UIBarMetricsDefault];
[appearance setBackButtonBackgroundImage:[UIImage imageNamed:@"image"] forState:1 barMetrics:UIBarMetricsDefault];
[appearance setBackButtonforBarMetrics:UIBarMetricsDefault];
|
1 2 3 4 5 6
| UIToolbar *appearance = [UIToolbar appearance];
[appearance setBarStyle:UIBarStyleBlackTranslucent];
[appearance setBackgroundImage:[UIImage imageNamed:@"bgImage"] forToolbarPosition:UIToolbarPositionAny barMetrics:UIBarMetricsDefault];
|
联系方式
邮箱: xiebangyao_1994@163.com
相关账号: