iOS实现简易的抽屉效果

 更新时间:2022年08月08日 10:22:29   作者:azhang_coder  
这篇文章主要为大家详细介绍了iOS实现简易的抽屉效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了iOS实现简易的抽屉效果的具体代码,供大家参考,具体内容如下

1.添加需要实现抽屉效果的三个视图,这里需要注意主视图需要放在最后添加

// 左边视图
 ...
// 右边视图
  ...
// 主视图
    UIView *mainView=[[UIView alloc]initWithFrame:self.view.bounds];
    mainView.backgroundColor=[UIColor greenColor];
    _mainView=mainView;
    [self.view addSubview:mainView];

2.实现左滑显示左边视图,右滑出现右边视图

添加平移手势和点击手势,实现左右滑动的监听和点击复位的效果

// 添加平移手势
    UIPanGestureRecognizer *panGes=[[UIPanGestureRecognizer alloc]initWithTarget:self action:@selector(panGes:)];
    [self.mainView addGestureRecognizer:panGes];
    // 添加点击返回手势
    UITapGestureRecognizer *tapGes=[[UITapGestureRecognizer alloc]initWithTarget:self action:@selector(tap)];
    [self.view addGestureRecognizer:tapGes];

在平移手势调用的方法中,通过偏移量来确定mainView的frame,实现动画效果

  • 首先通过translationInView:方法获取偏移量,通过偏移量的正负确定拖动的方向
  • 当手指松开后需要根据mainView的x值确定其视图是定位到原始位置还是其缩放的位置
  • 要其视图由当前点位移到目标位置,可以通过当前点到目标点的位移,然后调用frameWithOffsetX:方法获得mainView的frame
#define targetR 300
#define targetL -300
- (void)panGes:(UIPanGestureRecognizer *)panGes
{
    // 获取偏移量
    CGPoint tranP=[panGes translationInView:self.mainView];
    // 获得位移后的视图
    self.mainView.frame=[self frameWithOffsetX:tranP.x];
    // 判断拖动方向
    if (self.mainView.frame.origin.x<0) {//向左
        self.rightView.hidden=NO;
    }else if(self.mainView.frame.origin.x>0)
    {// 向右
        self.rightView.hidden=YES;
    }
    // 当手指松开时,做自动定位
    CGFloat target=0;
    if (panGes.state==UIGestureRecognizerStateEnded) {
        if (self.mainView.frame.origin.x>0.5*screenW) {
            target=targetR;
        }else if(CGRectGetMaxX(self.mainView.frame)<0.5*screenW)
        {
            target=targetL;
        }
        //offset为当前点到其目标点的位移
        CGFloat offset=target-self.mainView.frame.origin.x;
        [UIView animateWithDuration:0.5 animations:^{
            self.mainView.frame=[self frameWithOffsetX:offset];
        }];
    }

    // 复位
    [panGes setTranslation:CGPointZero inView:self.mainView];

}
#define maxY 120
// 根据mainView在X轴方向位移确定mainView的尺寸
- (CGRect)frameWithOffsetX:(CGFloat)offsetX
{
    CGRect frame=self.mainView.frame;

    frame.origin.x+=offsetX;

    frame.origin.y=fabs(frame.origin.x / screenW * maxY);

    frame.size.height=screenH - frame.origin.y * 2;

    return frame;
}

3.如何让其他文件也能实现抽屉效果

  • 首先拖入文件,然后新建一个新的ViewController,让其继承自我们导入的文件@interface ViewController :AZDrawerController
  • 新建要实现抽屉效果的界面,添加其视图至我们的mainView中,并且让其控制器也成为界面控制器的子控件,让控制器单独的管理
// 当一个控制器的View添加到另一个控制器的View上的时候,那此时View所在的控制器也应该成为上一个控制器的子控制器.
    AZTableViewController *vc1=[[AZTableViewController alloc]init];
    vc1.view.frame=self.mainView.bounds;
    [self.mainView addSubview:vc1.view];
    [self addChildViewController:vc1];

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • iOS开发-调用系统相机和相册获取照片示例

    iOS开发-调用系统相机和相册获取照片示例

    这篇文章主要介绍了iOS开发-调用系统相机和相册获取照片示例的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下。
    2017-02-02
  • iOS如何开发简单的手绘应用实例详解

    iOS如何开发简单的手绘应用实例详解

    这篇文章主要给大家介绍了关于iOS如何开发简单的手绘应用的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • iOS实现一个意见反馈类型的输入栏

    iOS实现一个意见反馈类型的输入栏

    这篇文章主要给大家介绍了关于利用iOS实现一个意见反馈类型的输入栏,通过文中实现的输入栏会用户一个很好的体验效果,文中给了详细的示例代码,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-10-10
  • tableView上面空出20个像素的解决办法

    tableView上面空出20个像素的解决办法

    在IOS开发中,有时候会遇到tableView上面多出来20个像素,是什么原因呢?又该如何来解决他呢,今天我们来探讨下
    2014-09-09
  • IOS中html5上传图片方向问题解决方法

    IOS中html5上传图片方向问题解决方法

    这篇文章主要介绍了IOS中html5上传图片方向问题解决方法的相关资料,需要的朋友可以参考下
    2016-01-01
  • 替代pod update速度慢的lg_pod_plugin安装使用详解

    替代pod update速度慢的lg_pod_plugin安装使用详解

    这篇文章主要介绍了替代pod update速度慢lg_pod_plugin安装使用方式详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-09-09
  • iOS Swift开发之日历插件开发示例

    iOS Swift开发之日历插件开发示例

    本篇文章主要介绍了iOS Swift开发之日历插件开发示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • Android 在页面中显示打包日期的实现方法

    Android 在页面中显示打包日期的实现方法

    下面小编就为大家分享一篇Android 在页面中显示打包日期的实现方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • iOS基础知识之@property 和 Ivar 的区别

    iOS基础知识之@property 和 Ivar 的区别

    这篇文章主要介绍了iOS基础知识之@property 和 Ivar 的区别介绍,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • iOS中的实时远程配置全纪录

    iOS中的实时远程配置全纪录

    这篇文章主要给大家介绍了关于iOS中实时远程配置的相关资料,文中通过示例代码介绍的非常详细,对各位iOS开发者们具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-01-01

最新评论