`

iOS 左右侧滑

    博客分类:
  • ios
 
阅读更多

网 上有很多第三方的类库实现了这种效果,其实自己代码写的话也是很简单的,下面我将介绍两种方法实现slide view。---- 一种是用第三方类库IIViewDeckController这个类库实现的效果比起其他的都好,另一种是自己代码实现这种效果,效果还ok。


实现方法一(使用第三方库IIViewDeckController):

https://github.com/Inferis/ViewDeck 这个是类库的下载地址,上面有介绍具体如何使用。不过大都不是用storyboard实现的,那么这里我介绍的是如何用storyboard实现。

 

(1 )方法①

首先注意要导入相关的头文件,并且Link the QuartzCore.framework

然后在storyboard中添加三个navigation视图,分别表示中间,左边和右边的视图,并且创建相应的controller。

我的处理是初始化一个IIViewDeckController 实例然后作为子视图添加到最左边的视图中,而用右边的三个navigation视图 作为IIViewDeckController 实例对象的初始参数。

其中要注意的是,要分别在三个navigation视图添加identifier,注意是添加到的是navigation controller对应的视图(即第一个)。

下面看看代码:

[cpp] view plaincopyprint?

  1. - (void)viewDidLoad
  2. {
  3. [super viewDidLoad];
  4. // Do any additional setup after loading the view, typically from a nib.
  5. UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  6. CenterViewController *centerController = (CenterViewController *)[storyboard instantiateViewControllerWithIdentifier:@"CenterViewController"];
  7. LeftViewController *leftController = (LeftViewController *)[storyboard instantiateViewControllerWithIdentifier:@"LeftViewController"];
  8. RightViewController *rightController = (RightViewController *)[storyboard instantiateViewControllerWithIdentifier:@"RightViewController"];
  9. self.containerController = [[IIViewDeckController alloc] initWithCenterViewController:centerController leftViewController:leftController rightViewController:rightController];
  10. self.containerController.leftSize = 100;
  11. self.containerController.rightSize = 200;
  12. self.containerController.view.frame = self.view.bounds;
  13. [self.view addSubview:self.containerController.view];
  14. }
  15. - (void)viewDidLoad
  16. {
  17. [super viewDidLoad];
  18. // Do any additional setup after loading the view, typically from a nib.
  19. UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  20. CenterViewController *centerController = (CenterViewController *)[storyboard instantiateViewControllerWithIdentifier:@"CenterViewController"];
  21. LeftViewController *leftController = (LeftViewController *)[storyboard instantiateViewControllerWithIdentifier:@"LeftViewController"];
  22. RightViewController *rightController = (RightViewController *)[storyboard instantiateViewControllerWithIdentifier:@"RightViewController"];
  23. self.containerController = [[IIViewDeckController alloc] initWithCenterViewController:centerController leftViewController:leftController rightViewController:rightController];
  24. self.containerController.leftSize = 100;
  25. self.containerController.rightSize = 200;
  26. self.containerController.view.frame = self.view.bounds;
  27. [self.view addSubview:self.containerController.view];
  28. }
复制代码


这里创建一个IIViewDeckController 实例,然后把这个实例对象的视图作为子视图添加到这个view中,这样就实现了跳转到我们需要的IIViewDeckController那里了,让我们 创建的IIViewDeckController实例处理左右滑动出现侧边栏的任务了。

(2 )方法②

这里再介绍一种实现方式:让最左边这个视图继承自IIViewDeckController然后在实现文件添加这个方法:

[cpp] view plaincopyprint?

  1. - (id)initWithCoder:(NSCoder *)aDecoder
  2. {
  3. self = [super initWithCoder:aDecoder];
  4. UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  5. self = [super initWithCenterViewController:[storyboard instantiateViewControllerWithIdentifier:@"CenterViewController"]
  6. leftViewController:[storyboard instantiateViewControllerWithIdentifier:@"LeftViewController"]
  7. rightViewController:[storyboard instantiateViewControllerWithIdentifier:@"RightViewController"]];
  8. if (self) {
  9. // Add any extra init code here
  10. }
  11. return self;
  12. }
  13. - (id)initWithCoder:(NSCoder *)aDecoder
  14. {
  15. self = [super initWithCoder:aDecoder];
  16. UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  17. self = [super initWithCenterViewController:[storyboard instantiateViewControllerWithIdentifier:@"CenterViewController"]
  18. leftViewController:[storyboard instantiateViewControllerWithIdentifier:@"LeftViewController"]
  19. rightViewController:[storyboard instantiateViewControllerWithIdentifier:@"RightViewController"]];
  20. if (self) {
  21. // Add any extra init code here
  22. }
  23. return self;
  24. }
复制代码


实现的效果是:

实现方式二(不使用第三方库):

下面简单说说这种滑动出现 侧边栏是怎么回事,明显这就是一个视图层叠,那么简单点的话,就是往一个视图里面添加几个视图,然后添加swipe手势,左右滑动时,响应事件处理,在事 件处理中让最上面的视图的位置发生变化,也就是视图移动,这样就可以显示出下面的视图,这样大致就可以解决了。

这里同样也是使用storyboard。而且storyboard里面的内容和上面的一样(其实解决方式借鉴了上面的方法①)。

首先分别创建对应的中间,左边,右边视图的controller(tableview controller)。

然后创建三个对应的属性

[cpp] view plaincopyprint?

  1. @property(nonatomic, strong) MainViewController *centerController;
  2. @property(nonatomic, strong) RightViewController *rightController;
  3. @property(nonatomic, strong) LeftViewController *leftController;
  4. @property(nonatomic, strong) MainViewController *centerController;
  5. @property(nonatomic, strong) RightViewController *rightController;
  6. @property(nonatomic, strong) LeftViewController *leftController;
复制代码


接着作为subview添加到视图中并添加swipe手势。处理的代码如下:

[cpp] view plaincopyprint?

  1. - (void)viewDidLoad
  2. {
  3. [super viewDidLoad];
  4. // Do any additional setup after loading the view.
  5. UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  6. _centerController = (MainViewController *)[storyboard instantiateViewControllerWithIdentifier:@"MainViewController"];
  7. _leftController = (LeftViewController *)[storyboard instantiateViewControllerWithIdentifier:@"LeftViewController"];
  8. _rightController = (RightViewController *)[storyboard instantiateViewControllerWithIdentifier:@"RightViewController"];
  9. [self.view addSubview:_centerController.view];
  10. [_centerController.view setTag:1];
  11. [_centerController.view setFrame:self.view.bounds];
  12. [self.view addSubview:_leftController.view];
  13. [_leftController.view setTag:2];
  14. [_leftController.view setFrame:self.view.bounds];
  15. [self.view addSubview:_rightController.view];
  16. [_rightController.view setTag:3];
  17. [_rightController.view setFrame:self.view.bounds];
  18. [self.view bringSubviewToFront:_centerController.view];
  19. //add swipe gesture
  20. UISwipeGestureRecognizer *swipeGestureRight = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipeGesture:)];
  21. [swipeGestureRight setDirection:UISwipeGestureRecognizerDirectionRight];
  22. [_centerController.view addGestureRecognizer:swipeGestureRight];
  23. UISwipeGestureRecognizer *swipeGestureLeft = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipeGesture:)];
  24. [swipeGestureLeft setDirection:UISwipeGestureRecognizerDirectionLeft];
  25. [_centerController.view addGestureRecognizer:swipeGestureLeft];
  26. }
  27. -(void) swipeGesture:(UISwipeGestureRecognizer *)swipeGestureRecognizer {
  28. CALayer *layer = [_centerController.view layer];
  29. layer.shadowColor = [UIColor blackColor].CGColor;
  30. layer.shadowOffset = CGSizeMake(1, 1);
  31. layer.shadowOpacity = 1;
  32. layer.shadowRadius = 20.0;
  33. if (swipeGestureRecognizer.direction == UISwipeGestureRecognizerDirectionRight) {
  34. [_leftController.view setHidden:NO];
  35. [_rightController.view setHidden:YES];
  36. [UIView beginAnimations:nil context:nil];
  37. [UIView setAnimationCurve:UIViewAnimationCurveEaseIn];
  38. if (_centerController.view.frame.origin.x == self.view.frame.origin.x || _centerController.view.frame.origin.x == -100) {
  39. [_centerController.view setFrame:CGRectMake(_centerController.view.frame.origin.x+100, _centerController.view.frame.origin.y, _centerController.view.frame.size.width, _centerController.view.frame.size.height)];
  40. }
  41. [UIView commitAnimations];
  42. }
  43. if (swipeGestureRecognizer.direction == UISwipeGestureRecognizerDirectionLeft) {
  44. [_rightController.view setHidden:NO];
  45. [_leftController.view setHidden:YES];
  46. [UIView beginAnimations:nil context:nil];
  47. [UIView setAnimationCurve:UIViewAnimationCurveEaseOut];
  48. if (_centerController.view.frame.origin.x == self.view.frame.origin.x || _centerController.view.frame.origin.x == 100) {
  49. [_centerController.view setFrame:CGRectMake(_centerController.view.frame.origin.x-100, _centerController.view.frame.origin.y, _centerController.view.frame.size.width, _centerController.view.frame.size.height)];
  50. }
  51. [UIView commitAnimations];
  52. }
  53. }
  54. - (void)viewDidLoad
  55. {
  56. [super viewDidLoad];
  57. // Do any additional setup after loading the view.
  58. UIStoryboard *storyboard = [UIStoryboard storyboardWithName:@"MainStoryboard" bundle:nil];
  59. _centerController = (MainViewController *)[storyboard instantiateViewControllerWithIdentifier:@"MainViewController"];
  60. _leftController = (LeftViewController *)[storyboard instantiateViewControllerWithIdentifier:@"LeftViewController"];
  61. _rightController = (RightViewController *)[storyboard instantiateViewControllerWithIdentifier:@"RightViewController"];
  62. [self.view addSubview:_centerController.view];
  63. [_centerController.view setTag:1];
  64. [_centerController.view setFrame:self.view.bounds];
  65. [self.view addSubview:_leftController.view];
  66. [_leftController.view setTag:2];
  67. [_leftController.view setFrame:self.view.bounds];
  68. [self.view addSubview:_rightController.view];
  69. [_rightController.view setTag:3];
  70. [_rightController.view setFrame:self.view.bounds];
  71. [self.view bringSubviewToFront:_centerController.view];
  72. //add swipe gesture
  73. UISwipeGestureRecognizer *swipeGestureRight = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipeGesture:)];
  74. [swipeGestureRight setDirection:UISwipeGestureRecognizerDirectionRight];
  75. [_centerController.view addGestureRecognizer:swipeGestureRight];
  76. UISwipeGestureRecognizer *swipeGestureLeft = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(swipeGesture:)];
  77. [swipeGestureLeft setDirection:UISwipeGestureRecognizerDirectionLeft];
  78. [_centerController.view addGestureRecognizer:swipeGestureLeft];
  79. }
  80. -(void) swipeGesture:(UISwipeGestureRecognizer *)swipeGestureRecognizer {
  81. CALayer *layer = [_centerController.view layer];
  82. layer.shadowColor = [UIColor blackColor].CGColor;
  83. layer.shadowOffset = CGSizeMake(1, 1);
  84. layer.shadowOpacity = 1;
  85. layer.shadowRadius = 20.0;
  86. if (swipeGestureRecognizer.direction == UISwipeGestureRecognizerDirectionRight) {
  87. [_leftController.view setHidden:NO];
  88. [_rightController.view setHidden:YES];
  89. [UIView beginAnimations:nil context:nil];
  90. [UIView setAnimationCurve:UIViewAnimationCurveEaseIn];
  91. if (_centerController.view.frame.origin.x == self.view.frame.origin.x || _centerController.view.frame.origin.x == -100) {
  92. [_centerController.view setFrame:CGRectMake(_centerController.view.frame.origin.x+100, _centerController.view.frame.origin.y, _centerController.view.frame.size.width, _centerController.view.frame.size.height)];
  93. }
  94. [UIView commitAnimations];
  95. }
  96. if (swipeGestureRecognizer.direction == UISwipeGestureRecognizerDirectionLeft) {
  97. [_rightController.view setHidden:NO];
  98. [_leftController.view setHidden:YES];
  99. [UIView beginAnimations:nil context:nil];
  100. [UIView setAnimationCurve:UIViewAnimationCurveEaseOut];
  101. if (_centerController.view.frame.origin.x == self.view.frame.origin.x || _centerController.view.frame.origin.x == 100) {
  102. [_centerController.view setFrame:CGRectMake(_centerController.view.frame.origin.x-100, _centerController.view.frame.origin.y, _centerController.view.frame.size.width, _centerController.view.frame.size.height)];
  103. }
  104. [UIView commitAnimations];
  105. }
  106. }
复制代码


下面稍稍解说一下在swipe手势的事件处理中的一些处理: ①为center视图添加阴影边框

②这里swipe手势响应的是左右滑动,右滑动时是要出现左视图,所以要隐藏右视图,同理就知道如何处理左滑动了。

③cente 视图移动时添加了动画

说明:我这样处理大致还是可以实现这种效果的。下面附上一张在我应用在sina weibo demo中的效果图:

还不错吧!

下面进行一点点补充:上面 我们实现的都是通过swipe滑动最上层的view来实现左右侧移,那么这样就太局限了,那么如何实现例如点击下面view中的LEFT按键来移动上层的 view呢?其实也很简单,我这里的处理是用notification通知,就是在button那里发送一个通知,在上层的view监听。当然呢,也可以 用delegate和kvo实现,但是这个。。。暂时没有研究,就算了,有空再了解一下。

下面附加一下代码:

在下面那层view的controller添加这个方法:

[cpp] view plaincopyprint?

  1. - (IBAction)BackButton:(id)sender {
  2. NSString *myString = @"back";
  3. [[NSNotificationCenter defaultCenter] postNotificationName: @"back" object:myString userInfo: nil];
  4. }
  5. - (IBAction)BackButton:(id)sender {
  6. NSString *myString = @"back";
  7. [[NSNotificationCenter defaultCenter] postNotificationName: @"back" object:myString userInfo: nil];
  8. }
复制代码


在上面这个层的view的controller添加下面的代码:

[cpp] view plaincopyprint?

  1. [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(BackFunc:) name: @"back" object:nil];
  2. id) BackFunc:(NSNotification*) notification {
  3. NSString *get = [notification object];
  4. if ([get isEqualToString:@"back"]) {
  5. [UIView beginAnimations:nil context:nil];
  6. [UIView setAnimationCurve:UIViewAnimationCurveEaseOut];
  7. [_centerController.view setFrame:CGRectMake(0, _centerController.view.frame.origin.y, _centerController.view.frame.size.width, _centerController.view.frame.size.height)];
  8. [UIView commitAnimations];
  9. }
  10. [[NSNotificationCenter defaultCenter] addObserver:self selector:@selector(BackFunc:) name: @"back" object:nil];
  11. -(void) BackFunc:(NSNotification*) notification {
  12. NSString *get = [notification object];
  13. if ([get isEqualToString:@"back"]) {
  14. [UIView beginAnimations:nil context:nil];
  15. [UIView setAnimationCurve:UIViewAnimationCurveEaseOut];
  16. [_centerController.view setFrame:CGRectMake(0, _centerController.view.frame.origin.y, _centerController.view.frame.size.width, _centerController.view.frame.size.height)];
  17. [UIView commitAnimations];
  18. }
  19. }

IIViewDeckController/ViewDeck   附件:

/cms/uploads/soft/130603/4196-1306031H336.zip

类似 Path 2.0 的视图左右滑动的效果,可向左或者向右顺滑的滑动。支持ARC和non-ARC,默认ARC。

PPRevealSideViewController     附件:

/cms/uploads/soft/130603/4196-1306031H409.zip

PPRevealSideViewController实现了类似Facebook和Path的界面滑出效果,可以用来创建常见的抽屉式导航,包括Pan和Tap手势。支持ARC,兼容iOS 4.0-iOS 6.0系统。

 

JASidePanels          附件:

/cms/uploads/soft/130603/4196-1306031H442.zip

JASidePanels 是一个 UIViewController 容器,可从中间界面向左右滑动展现其他界面,设计来源于Path 2.0和Facebook的iOS app。

 

ECSlidingViewController         附件:

/cms/uploads/soft/130603/4196-1306031H511.zip

ECSlidingViewController灵感还是来来源于Path2.0和Facebook的iOS app,是一个ViewController容器,将子ViewController分成两层,显示下边一层内容时,上边一层不完全滑出,从而进行层的切换。

类似的还有MFSideMenu   附件:

/cms/uploads/soft/130603/4196-1306031H537.zip

OCExpandableButton:类似Sparrow(Mail App)可扩展按钮菜单   

原生Objective C中一款简单的可扩展按钮菜单,可以展开或者隐藏,类似于Sparrow(Mail App)的风格,使用起来非常简单。

分享到:
评论

相关推荐

    iOS左右侧滑

    在iOS应用开发中,左右侧滑效果是一种常见的交互设计,让用户可以轻松地访问或切换不同的功能模块。这种效果类似于QQ应用中的侧边栏菜单,它为用户提供了一个无需离开当前界面就能进行其他操作的方式。实现这样的...

    ios实现侧滑功能(纯手写代码)

    - 如果是左右侧滑,可以使用CGAffineTransformMakeTranslation来平移视图。 - 添加动画效果,比如使用UIView的animate(withDuration:animations:)方法,使得滑动更流畅。 4. **交互处理**: - 设置手势的代理,...

    ios-侧滑.zip

    作为RootViewController来管理自控制器, 对UITabBarController管理的自控制器的view添加边缘拖拽手势UIScreenEdgePanGestureRecognizer来随心所欲的实现对显示控制器view的左右拖拽

    swift-iOS侧滑控件支持左右滑动的侧滑菜单可配置单侧滑动

    Swift-iOS侧滑控件,如描述中提到的支持左右滑动的侧滑菜单,是实现这种常见交互模式的有效工具。这种控件允许用户通过在主屏幕内容上进行左滑或右滑手势来展示隐藏的侧边菜单,为用户提供快捷的导航选项。 侧滑...

    iOS 自定义cell侧滑删除

    在iOS开发中,自定义cell侧滑删除是一种常见的交互方式,它使得用户能够方便地对列表中的项目进行删除操作,而无需进入详情页面或者通过其他复杂的步骤。这种功能在诸如邮件应用、联系人应用等中广泛应用。下面我们...

    ios-侧滑 小Demo.zip

    1. **手势识别(Gesture Recognizer)**:在iOS开发中,UIPanGestureRecognizer是用于识别平移手势的类,可以用来检测用户的左右滑动。开发者需要在视图上添加这个手势识别器,并设定相应的处理方法来响应滑动手势。...

    ---ios侧滑列表组件---

    在iOS开发中,侧滑列表(Swipeable List)是一种常见的用户界面组件,它允许用户通过在列表项上向左或向右滑动来触发不同的操作,如删除、标记或访问更多选项。这种交互方式在很多应用程序中都能见到,特别是在邮件...

    ios-侧滑cell.zip

    在iOS开发中,"ios-侧滑cell.zip" 提供了一个常见的用户界面功能,即在UITableView中的Cell实现左右滑动效果。这种设计通常用于显示更多的操作选项,如删除、标记等,用户只需轻轻一滑,就能看到隐藏在背后的菜单。...

    高仿IOS版本 Android 侧滑删除 平滑滚动用Scroller实现

    在Android开发中,为了提升用户体验,常常需要对界面进行各种定制和优化,"高仿IOS版本 Android 侧滑删除 平滑滚动用Scroller实现"这个话题就涉及到了两个关键的技术点:侧滑删除(Swipe-to-Delete)和基于Scroller...

    ios-侧滑菜单JYJSlideMenuController.zip

    在iOS应用开发中,侧滑菜单是一种常见的交互设计,用户可以通过从屏幕边缘向内滑动来显示隐藏的菜单,提供了便捷的导航功能。JYJSlideMenuController是一款在GitHub上开源的侧滑菜单组件,其设计独特,易于使用,为...

    iOS侧滑代码

    通过以上步骤,你可以成功地在你的iOS应用中实现左右侧滑的效果。ECSlidingViewController库的灵活性使得开发者可以根据自己的需求对侧滑行为进行高度定制,为用户提供丰富的交互体验。记得在实际开发中,根据项目的...

    左右侧滑菜单功能

    在iOS应用开发中,左右侧滑菜单功能是一个常见的交互设计,它允许用户通过在屏幕边缘向左或向右滑动来展示或者隐藏一个侧边菜单。这种设计模式常见于许多移动应用,特别是那些需要提供多种导航选项或者设置的App。在...

    ios 导航侧滑

    在iOS应用开发中,导航侧滑(通常称为滑动抽屉菜单或侧滑导航)是一种常见的设计模式,它允许用户通过从屏幕边缘向内滑动来显示一个隐藏的菜单,通常用于实现应用的主要导航功能。这种设计使得在有限的屏幕空间上...

    ios高仿QQ 5.0 侧滑菜单效果

    在iOS应用开发中,侧滑菜单(Slide Menu)是一种常见的设计模式,用于提供导航和快捷访问功能。在“ios高仿QQ 5.0 侧滑菜单效果”这个项目中,我们将探讨如何在iOS平台上创建类似QQ 5.0版本的侧滑菜单,这种效果通常...

    左右侧滑菜单SlideView

    在移动应用开发中,用户界面的设计至关重要,而左右侧滑菜单(SlideView)是许多应用程序中常见的交互元素,尤其在导航栏或者主菜单设计时。它允许用户通过从屏幕边缘向内滑动来显示或隐藏附加功能或选项,提供了一种...

    左右侧滑的实现demo

    在Android应用开发中,左右侧滑的实现是一种常见的交互设计,它通常用于提供侧边栏菜单,增强用户体验。本教程将详细介绍如何通过导入SlidingMenu库来实现这一功能。 首先,`SlidingMenu`是一个非常受欢迎的开源库...

    左右侧滑,中间滑动

    在移动应用开发中,"左右侧滑,中间滑动"是一种常见的交互设计,它通常用于实现多页面切换或者展示更多的功能选项。这种设计在QQ等社交应用中尤为常见,为用户提供便捷的操作方式。本文将详细讲解如何实现这种交互...

    Android 实现类似QQ侧滑菜单,实现左右侧滑 源码

    Android 实现类似QQ侧滑菜单,实现左右侧滑 源码。具有iOS 7/8 parallax effect 风格的侧边菜单,类似于最新版qq的菜单效果。ReisdeMenu 创意灵感来自于Dribbble1还有2,而这个是Android版的ResideMenu,在视觉效果...

    IOS左右滑动显示菜单,类似于FaceBook向左右滑动显示菜单页面

    MFSideMenu是一个流行的iOS库,它允许开发者添加自定义的侧滑菜单到他们的应用程序中,通过简单的手势操作(如左右滑动)来展示或隐藏菜单。这个库的设计灵感来自于Facebook app的导航方式,使得用户界面更加直观和...

Global site tag (gtag.js) - Google Analytics