BRBaseView.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. //
  2. // BaseView.h
  3. // BRPickerViewDemo
  4. //
  5. // Created by renbo on 2017/8/11.
  6. // Copyright © 2017 irenb. All rights reserved.
  7. //
  8. // 最新代码下载地址:https://github.com/91renb/BRPickerView
  9. #import <UIKit/UIKit.h>
  10. #import "BRPickerStyle.h"
  11. NS_ASSUME_NONNULL_BEGIN
  12. typedef void(^BRCancelBlock)(void);
  13. typedef void(^BRDoneClickBlock)(void);
  14. @interface BRBaseView : UIView
  15. /** 选择器标题 */
  16. @property (nullable, nonatomic, copy) NSString *title;
  17. /** 是否自动选择,即滚动选择器后就执行结果回调,默认为 NO */
  18. @property (nonatomic, assign) BOOL isAutoSelect;
  19. /** 自定义UI样式(不传或为nil时,是默认样式) */
  20. @property (nullable, nonatomic, strong) BRPickerStyle *pickerStyle;
  21. /** 取消选择的回调 */
  22. @property (nullable, nonatomic, copy) BRCancelBlock cancelBlock;
  23. /** accessory view for above picker view. default is nil */
  24. @property (nullable, nonatomic, strong) UIView *pickerHeaderView;
  25. /** accessory view below picker view. default is nil */
  26. @property (nullable, nonatomic, strong) UIView *pickerFooterView;
  27. /// 确定按钮点击事件的回调
  28. /// 应用场景:如果是自定义确定按钮,需要在该按钮点击事件方法里,执行一下 doneBlock 回调。目的是触发组件内部执行 resultBlock 回调,回调选择的值
  29. @property (nullable, nonatomic, copy) BRDoneClickBlock doneBlock;
  30. /** 弹框视图(使用场景:可以在 alertView 上添加选择器的自定义背景视图) */
  31. @property (nullable, nonatomic, strong) UIView *alertView;
  32. /** 组件的父视图:可以传 自己获取的 keyWindow,或页面的 view */
  33. @property (nullable, nonatomic, strong) UIView *keyView;
  34. /// 刷新选择器数据
  35. /// 应用场景:动态更新数据源、动态更新选择的值、选择器类型切换等
  36. - (void)reloadData;
  37. /// 扩展一:添加选择器到指定容器视图上
  38. /// 应用场景:可将中间的滚轮选择器 pickerView 视图(不包含蒙层及标题栏)添加到任何自定义视图上(会自动填满容器视图),也方便自定义更多的弹框样式
  39. /// 补充说明:如果是自定义确定按钮,需要回调默认选择的值:只需在自定义确定按钮的点击事件方法里执行一下 doneBlock 回调(目的是去触发组件内部执行 resultBlock 回调,进而回调默认选择的值)
  40. /// @param view 容器视图
  41. - (void)addPickerToView:(nullable UIView *)view NS_REQUIRES_SUPER;
  42. /// 从指定容器视图上移除选择器
  43. /// @param view 容器视图
  44. - (void)removePickerFromView:(nullable UIView *)view;
  45. /// 扩展二:添加自定义视图到选择器(pickerView)上
  46. /// 应用场景:可以添加一些固定的标题、单位等到选择器中间
  47. /// @param customView 自定义视图
  48. - (void)addSubViewToPicker:(UIView *)customView;
  49. /// 扩展三:添加自定义视图到标题栏(titleBarView)上
  50. /// 应用场景:可以添加一些子控件到标题栏
  51. /// @param customView 自定义视图
  52. - (void)addSubViewToTitleBar:(UIView *)customView;
  53. @end
  54. NS_ASSUME_NONNULL_END