杂⑦碎八之--百思Demo Z2

插件扩展:一般插件都支持扩展,对自己我创建的分类进行支持.

找到安装插件的工程文件,全局搜索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;

你可能感兴趣的:(杂⑦碎八之--百思Demo Z2)