实现效果:
点击弹出小型列表菜单.
view.frame,初始位置等都可通过调用方法自定制.
实现cell数量自适应,当数量大于4时,view高度固定,可滑动.
cell实现纯文字与icon+文字两种状态.自适应.
通过回调响应点击方法.
点任意位置菜单消失.
#实现思路:
本质上这个弹出菜单是一个tableView.
所以我们实现的是一个弹出一个背景透明的全屏View,其中包含一个小tableView.
实现方式:
1.创建弹出View,并添加tableView.
2.使用drawRect方法,添加tableView上的小三角形.
3.创建menuCell,使其实现纯文字,icon+文字两种type
4.创建EWPopMenu类,留出外部方法方便调用
1.创建弹出View,并添加tableView.
/// init
///
/// - Parameters:
/// - width: tableView.width
/// - height: tableView最大height,如果cell数量大于4,则是tableView.frame.size.height
/// - point: 初始点,tableView上的三角形的顶点
/// - items: 每个cell的title数组
/// - imgSource: 每个cell的icon数组,可为空
/// - action: 回调方法
init(width: CGFloat, height: CGFloat, point: CGPoint, items: [String], imgSource: [String], action: ((Int) -> ())?){
super.init(frame:CGRect(x: 0, y: 0, width: ScreenInfo.Width, height: ScreenInfo.Height))
drawMyTableView()
/// view全屏展示
self.frame = CGRect(x: 0, y: 0, width: ScreenInfo.Width, height: ScreenInfo.Height)
/// 获取起始点
self.point