插件扩展:一般插件都支持扩展,对自己我创建的分类进行支持.
找到安装插件的工程文件,全局搜索install 安装路径
根据安装路径查找本地的文件
修改文件中的plist文件,支持本地化内容.
解决文字被渲染.
如果显示出来默认蓝色,首先考虑的属性是tintColor
-tintColor always returns a color. The color returned is the first non-default value in the receiver's superview chain (starting with itself).
If no non-default value is found, a system-defined color is returned.
If this view's -tintAdjustmentMode returns Dimmed, then the color that is returned for -tintColor will automatically be dimmed.
If your view subclass uses tintColor in its rendering, override -tintColorDidChange in order to refresh the rendering if the color changes.
注释:大致意思是说,这个属性会一直返回一个颜色,如果没有默认或者设置颜色,返回系统的颜色也就是经常看到的蓝色.
@property(null_resettable, nonatomic, strong) UIColor *tintColor NS_AVAILABLE_IOS(7_0);
UITabBarItem里没有关于文字颜色的属性,去父类UIBarItem中查找到- (void)setTitleTextAttributes:(nullableNSDictionary *)attributes forState:(UIControlState)stateNS_AVAILABLE_IOS(5_0)UI_APPEARANCE_SELECTOR;这个方法可以设置文字的属性
TextAttribute 富文本属性
关于设置文字在哪个方法中写:
①+ (void)initialize第一次使用类或者他的子类的时候调用,有可能会调用多次.
②+ (void)load第一次加载类的时候调用,只会调用一次 在此,选用这个方法
5.在本项目中,此处文字的字体状态是,Normal状态,而不是高亮状态
6.关于Appearance的使用
①只要遵守了UIAppearance协议就可以使用
②只有带有UI_APPEARANCE_SELECTOR宏属性才可以去设置
③如果使用appearance设置属性,那么必须在显示之前设置.
发布按钮的设置
bug的发现:刚开始设置后,发现按钮图片没有正常显示,之后调整全部tabbarButton按钮图片被渲染的同时,发现按钮未正常显示因为在正常状态下图片尺寸超过了内容区域,同时被渲染.
解决:1.设置图片不被渲染,正常状态和高亮状态下,都不被渲染.按钮位置偏高,设置图片内边距.
2.与实例程序对比,发现系统的按钮没有高亮状态,所以我们需要自定义按钮.
自定义按钮,我们用懒加载的方法,需要注意的是:系统的tabbarbutton不删除,起到一个占位的作用,但必须设置vc2.tabBarItem.enabled=NO;button让它自适应tabbar分配的尺寸 在viewDidLoad中设置button的位置为tabBar 中心点
Q:设置导航条的内容 (系统的Item都是模型)
栈顶控制器决定导航条显示的内容,导航控制器不能决定(栈顶控制器是显示在外面的view)
bug:在我们设置导航条按钮后,超出按钮范围也能被点击
分析:包装成UIBarButtonItem出现问题
解决办法:butto外面包装一个UIView,再添加给UIBarButtonItem
导航条的内容每个控制器都需要设置按钮,抽取一个分类方法,方便调用.
按钮的选中状态必须通过代码来实现,其他设置无效.
bug:还没有要显示界面的时候,view已经被加载.
解决:将各控制器的view背景设置交给各控制器自己去设置,这样完成懒加载.且不会干扰后面的设置.
W:跳转设置界面
push操作,跳转界面后隐藏底部tabbar栏,必须要在push之前进行设置,hidesButtonWhenPush = YES;
重新设置系统提供的返回按钮: 由当前控制器进行管理 frame不是我们想要的,设置UIEdgeInsetsMaken内边距
因为每个界面都一样,需要跳转返回功能,所以返回按钮可以统一配置
注意:统一配置会遇到的bug:
根控制器左边按钮,被返回按钮覆盖
设置时需要进行一个判断,判断该控制器是否为根控制器
判断 childViewControllers是否为空,如果为空则证明为根控制器,不需要设置返回按钮.
注意:不能判断当前控制器是否为数组中childView[0],只有完成push操作时,数组才不为空,此判断无效.
E:全局控制器都被返回按钮覆盖
控制器没有遵从懒加载原则,很有可能是main中对子控制器进行了设置,从而导致子控制器的view先被加载,也就是导航控制器的内容先被设置,而回到main中,initwith又会调用重写的push方法,对导航条内容进行了覆盖.解决:将属于各自控制器的设置放到各自自己的控制器中设置.
滑动返回功能 Q:上一篇中有详细代码解析此功能,请移步.
ios7之后,导航控制器自带滑动返回功能,且是边缘侧滑返回功能.
我们修改了系统自带的返回按钮,导致功能失效.
分析:代理实现手势的方法,可能是代理让手势失效了
代理在这里的作用是一个通知功能,滑动方法的实现在手势中
当我们没有使用自定义按钮时,系统默认侧滑返回的实现,且在根控制器中不能实现,这里的消息传递由代理实现
当我们使用自定义按钮的时候,系统的默认代理会通知手势,此触摸事件不能实现,所以清空代理让他按照默认方法处理,这个时候边缘侧滑功能就实现了.
需求:全屏侧滑返回的实现
/*打印手势interactivePopGestureRecognizer(交互返回)
; target= <(action=handleNavigationTransition:, target=<_UINavigationInteractiveTransition 0x7f9a4d214270>)>>
打印interactivePopGestureRecognizer.delegate代理
<_UINavigationInteractiveTransition: 0x7fda886183b0>
这两个target时同一个类,但不是同一个对象.
*/
干掉系统的手势:self.interactivePopGestureRecognizer.enabled=NO;
因为_UINavigationInteractiveTransition 是私有属性,拿不到这个对象,但是因为手势的代理跟target属于同一个类型,可以用代理对象代替.
创建自己的滑动手势:idtarget =self.interactivePopGestureRecognizer.delegate;
调用系统的滑动方法:handleNavigationTransition:
UIPanGestureRecognizer*pan = [[UIPanGestureRecognizeralloc]initWithTarget:targetaction:@selector(handleNavigationTransition:)];
实现自己的手势,添加到NavigationController 的view上
[self.viewaddGestureRecognizer:pan];
设置代理,实现代理方法,控制手势什么时候触发
pan.delegate=self;