一劳永逸,iOS自定义ActionSheet封装流程

640?wx_fmt=jpeg

黑客技术 点击右侧关注,了解黑客的世界! 640?wx_fmt=jpeg

640?wx_fmt=jpeg

Java开发进阶 点击右侧关注,掌握进阶之路! 640?wx_fmt=jpeg

640?wx_fmt=jpeg

Linux编程 点击右侧关注,免费入门到精通! 640?wx_fmt=jpeg


作者丨卖报的小画家Sure

https://www.jianshu.com/p/cfb87a7db7b1


正文


最近更新项目需求,需要重构导航选取模块,故将封装流程进行分享,效果图如下:


640?wx_fmt=other

导航选取弹窗


根据效果图情况,可知标题栏位置需自定义,且选项位置等文字样式可调节,因此无法利用系统的UIActionSheet或UIAlertController进行实现,需自定义视图,并考虑到适用场景,该ActionSheet后续会用于其他功能模块中,所以要封装成通用类。


继续分析需求,用什么控件作为主体会更好呢?没错,UITableView是在适合不过了,见刨析图:


640?wx_fmt=png


刨析图


如上设计的优势在于可将自定义View传入做为TableView的表头视图tableHeaderView。对于选项位置若需定制其它样式可自定义Cell进行设置。因此可满足自定义ActionSheet的多种场景。


根据刨析图,首先我们分别创建maskView与主体TableView。这里需注意的是为了实现效果我们需要将TableView的颜色置为透明。



 


并且我们要将TableView分为两组,即主体选项与取消按钮分离,因此设置代理方法:



 


接下来进行处理视图的圆角效果。TableView主体做圆角效果这个不用多说,需要注意的是如何处理好TableViewCell的圆角形式,若仍然简单设置layer.cornerRadius会出现如下情况:


640?wx_fmt=png


效果图


显然很难看,设计看到估计会崩溃,因此我们需要做的处理为仅为选项中的最后一项做圆角处理,即图中的高德地图选项,并且为了美观效果,要达到只为其左下角与右下角做处理。


这里我们需要借助UIBezierPath与CAShapeLayer进行实现。判断是否为最后选项,然后进行如下设置。



 


其中byRoundingCorners即为设置所需处理边角参数。有如下枚举克进行选择:



 


比如将byRoundingCorners设置为UIRectCornerTopLeft| UIRectCornerBottomRight,即左上与右下设置,View的效果为:

640?wx_fmt=other

效果图


经过上述调整,视图的圆角效果完成,最后设置组尾透明视图即可:



 


做好如上处理后基本的UI效果即已完成。


接下来我们考虑外漏方法问题,简单模拟UIActionSheet的创建形式,公开方法:



 


调用如下:



 


这样即可将所需头视图、取消文字传入,并处理选项事件等。


最后简单给予视图显示与隐藏的效果,并在欠当的时机调用即可,且这里我们需要调节TableView的高度,使其适应所包含内容高度。



 



至此,该需求效果已基本完成,如上摘取部分代码,demo已上传github,需要可自行下载。


https://github.com/LSure/SureCustomActionSheet


 推荐↓↓↓ 

640?wx_fmt=jpeg

?16个技术公众号】都在这里!

涵盖:程序员大咖、源码共读、程序员共读、数据结构与算法、黑客技术和网络安全、大数据科技、编程前端、Java、Python、Web编程开发、Android、iOS开发、Linux、数据库研发、幽默程序员等。

640?wx_fmt=png万水千山总是情,点个 “ 在看” 行不行
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值