您的位置:首页 > 移动开发 > IOS开发

iOS --自定义导航栏

2016-02-23 00:00 405 查看

自定义导航栏 JPNavigationBar,继承UINavigationBar

实现统一设置导航栏左右按钮偏移量距离屏幕

方案一:自定义左右导航栏按钮,判断如果是左右按钮,然后修改左右按钮的frame

#import "JPNavigationBar.h"#import "JPNavigationLeftItem.h" // 自定义类继承UIButton#import "JPNavigationRightItem.h" // 自定义类继承UIButton#import "UIView+Frame.h"  // 分类,快速修改frame#define KMargin 8@implementation JPNavigationBar- (void)layoutSubviews{
[super layoutSubviews];    for (UIView *view in self.subviews) {        // 1、设置导航左边按钮的间距
if ([view isKindOfClass:[JPNavigationLeftButton class]]) {
view.x = KMargin;
}        // 2、设置导航按钮右边按钮的间距
if ([view isKindOfClass:[JPNavigationRightButton class]]) {
view.x = self.width - KMargin - view.width;
}
}


方案二:通过frame判断,导航栏左右按钮,然后修改左右按钮的frame

#import "JPNavigationBar.h"@implementation JPNavigationBar/**
*  调整子控件布局
*/- (void)layoutSubviews
{
[super layoutSubviews];    for (UIButton *button in self.subviews) {        if (![button isKindOfClass:[UIButton class]]) continue;        if (button.centerX < self.width * 0.5) { // 左边的按钮
button.x = 0;
} else if (button.centerX > self.width * 0.5) { // 右边的按钮
button.x = self.width - button.width;
}
}
}@end
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: