iOS开发 仿陌陌首页上拉下拉效果

  • 这几天产品小弟说要把首页做成像陌陌的首页,作为一个程序员本来是想剁了他的,但是考虑到最近工作不好找,就忍了的。。。

陌陌首页分析:

陌陌操作图.gif

陌陌首页长这样

  • 往上推的时候明显感觉是下面的盖住了上面的,所以可以分成几个图层,上面的在最下面的图层,下面的tableview在上层。

  • 其中主要的问题就是 下面的tableview的滑动手势 和 页面的滑动冲突,所以就是依靠pan手势,
    思路就是 :在某个区域范围里面,禁止掉tableview的滑动,超出之后,禁止掉Pan手势;

  • 手势的两个代理方法

// 在手势冲突时候调用,默认返回NO表示默认不能同时识别两个手势
- (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer;

//在手势想要从UIGestureRecognizerStatePossible状态变化的时候调用,返回NO则表示手势状态是UIGestureRecognizerStateFailed
- (BOOL)gestureRecognizerShouldBegin:(UIGestureRecognizer *)gestureRecognizer;

-(void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSKeyValueChangeKey,id> *)change context:(void *)context{
   if ((pan.state == UIGestureRecognizerStateEnded) && (frame.origin.y == level2)) {
  .....................................................................
}
}
  • 在手势的代理方法里面禁掉tableview的滑动,然后对pan进行手势的监控,判断手势滑动结束并且不在互动范围里面的时候禁掉手势, 放开tableview的滑动。

效果图见下面


效果图.gif

具体Demo见github链接 下载就能运行
https://github.com/1784777348ly/MOMOHomePage

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1 CALayer IOS SDK详解之CALayer(一) http://doc.okbase.net/Hell...
    Kevin_Junbaozi阅读 5,215评论 3 23
  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,019评论 3 119
  • 美国经济学家研究婚姻问题的主要变量是个人收入,但我们中国似乎更关注双方的家庭出身。 现在中国最受关注的婚姻模式,大...
    缘享阅读 156评论 0 1
  • 2017年10月1日,我在徐州站等140。晚点已经2分钟了,我背着6瓶啤酒,前面的刘康在玩手机,打那个傻逼的消除游...
    奇异脑回路阅读 261评论 0 0
  • 观《我爱你》有感 我爱你,父母对子女,子女对父母,丈夫对妻子,妻子对丈夫…… 影片中的以爱情为主,亲情为辅,讲我爱...
    dear荷露阅读 196评论 0 1