美文网首页
iOS滑动view

iOS滑动view

作者: 站在下一刻 | 来源:发表于2018-12-07 16:02 被阅读13次

一.背景

  • 一般开发中,经常会遇到给一个view添加pan手势,让它可以跟随手指的移动而移动,每次碰到这样的需求的时候,都是找个相似的功能模块拷贝代码,还得花点时间调试,实在是很不方便,于是写了一个UIView的分类去封装了对应实例的滑动操作,完成效果如下:
    1. 滑动的view在中间,向上下方向滑动一段距离消失


      TopBottomDemo.gif
    2. 滑动的view在中间,向左右方向滑动一段距离消失


      leftRightDemo.gif
  1. 滑动的view在屏幕上边,向上方向滑动一段距离消失


    TopToTop.gif
  1. 滑动的view在屏幕下边,向下方向滑动一段距离消失


    BottomToBottom.gif
  1. 滑动的view在屏幕某一位置,向四周滑动一段距离然后靠屏幕边缘停留


    AllDirection.gif

二. 开发步骤

让一个view可以滑动,分为以下几个步骤;

  1. 给view添加pan手势
  2. 添加一个成员变量,记录前一次滑动的point
  3. Pan的手势处理中更改view的frame

都是很简单的操作,在category中需要用objc_setAssociatedObject的方式去保存成员变量
完成这些,view就可以滑动了

三. 功能扩展

如果只是简单的拖动view,那也需要做些额外的工作去完成某些需求,所以这里扩充一些功能,一般可以拖动的view都会有回到原处的功能,或者拖动一段距离松手后就滑动离开屏幕内,如开始的图片所示,所以扩展功能主要添加了动画回到原处和消失在屏幕外的功能

//设置可滑动的距离,以及滑动过程的各个回调
/*
 *  @param inset 以自己为中心,四周可以滑动的距离
 *  @param beginBlock pan手势begin的回调
 *  @param moveBlock pan手势change的回调
 *  @param endBlock pan手势end和cancel的回调
 */
- (void)lh_dragWithBoundsInset:(UIEdgeInsets)inset beginDragBlock:(dispatch_block_t)beginBlock moveBlock:(LHDragViewMoving)moveBlock endDragBlock:(LHDragViewEndDrag)endBlock;

调用后就有了可以滑动的区域,以及自动回到原位的功能

//设置松手后的退出方向,以及滑动到多少才退出的距离
/*
 *  @param direction 动画退出的方向 可以多个方向退出
 *  @param inset 以自己为中心,四周滑动的多少距离松手后触发退出滑动区域的逻辑
 */
- (void)lh_setOutDirection:(LHViewOutDirection)direction backToOriginMoveInset:(UIEdgeInsets)inset;

调用后就可以按照指定方向退出滑动区域,松手后触发退出逻辑的位置由inset指定的

//设置松手后动画的时间
/*
 *  @param timeInterval 动画回到原位或者退出到边缘的时间,根据view实时的位置算比例的到真实的,默认0.3
 */
- (void)lh_setDismissDuration:(NSTimeInterval)timeInterval;

设置动画的时间,会根据当前动画的距离算出占用最长距离的比例,然后得到动画的真正时间

//设置松手后退出滑动区域的相对最初位置的距离
/*
 *  @param inset 松手触发退出滑动区域的逻辑后,回到的位置离最初位置的距离
 */
- (void)lh_setDragOutFrameInset:(UIEdgeInsets)inset;

设置松手view移动的距离inset,分别top, left,bottom,right等偏移

//设置是否允许松手后view的滑动,默认是NO
/*
 *  @param disable 禁止松手自动滑动的功能
 */
- (void)lh_setDragViewUpMoveDisable:(BOOL)disable;

设置禁止松手后的滑动功能

//设置是否允许松手后view的滑动,默认是NO
- (void)lh_setDragViewUpMoveDisable:(BOOL)disable;

详见Demo

相关文章

网友评论

      本文标题:iOS滑动view

      本文链接:https://www.haomeiwen.com/subject/yukwcqtx.html