抽屉效果

在iOS中非常多应用都用到了抽屉效果,比如腾讯的QQ,百度贴吧…

———

1. 终于效果例如以下图所看到的

———

2.实现步骤

1.開始启动的时候。新建3个不同颜色的View的

1.设置3个成员属性。记录三种颜色的View

@property (nonatomic,weak) UIView* redView;
@property (nonatomic,weak) UIView* greenView;
@property (nonatomic,weak) UIView* blueView;

2.初始化3个View

- (void)setUpthreeViews
{
UIView *blueView = [[UIView alloc]initWithFrame:self.view.bounds];
blueView.backgroundColor = [UIColor blueColor];
[self.view addSubview:blueView];
_blueView = blueView; UIView *greenView = [[UIView alloc]initWithFrame:self.view.bounds];
greenView.backgroundColor = [UIColor greenColor];
[self.view addSubview:greenView];
_greenView = greenView; UIView *redView = [[UIView alloc]initWithFrame:self.view.bounds];
redView.backgroundColor = [UIColor redColor];
[self.view addSubview:redView];
_redView = redView;
}

2.实现滑动的效果

1.通过-(void)touchesMoved:(NSSet )touches withEvent:(UIEvent )event方法来获得当前点和初始点,从而计算出偏移量,然后计算redView的frame的值:

-(void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event
{
UITouch *touch = [touches anyObject];
//获得当前点
CGPoint currentPoint = [touch locationInView:_redView];
//获得起点
CGPoint prePoint = [touch previousLocationInView:_redView];
//计算在x轴方向上的偏移量
CGFloat moveX = currentPoint.x - prePoint.x;
//然后通过在x轴上的偏移量。计算redView的frame
_redView.frame = [self framWithOffsetX:moveX];
}
  1. 假设x移到320时。y移动到60,算出每移动一点x,移动多少y

  2. offsetY = offsetX * 600 / 320 手指每移动一点,x轴偏移量多少,y偏移多少

  3. 为了好看。x移动到320。距离上下的高度须要保持一致。并且有一定的比例去缩放他的尺寸。

  4. touchMove仅仅能拿到之前的frame.当前的高度 = 之前的高度 * 这个比例

    缩放比例:当前的高度/之前的高度 (screenH - 2 * offsetY) / screenH。

    当前的宽度保持不变即可。
  5. y值,计算比較特殊,不能直接用之前的y,加上offsetY,往左滑动。主视图应该往下走,可是offsetX是负数,导致主视图会往上走。所以须要推断是左滑还是右滑
- (CGRect)framWithOffsetX:(CGFloat)offsetX
{
//计算在y轴方向上的偏移量
CGFloat offsetY = offsetX/SCREENWIDTH * MAXYOFFSET;
//依据y方向的偏移量计算缩放比例
CGFloat scale = (SCREENHEIGHT - 2*offsetY)/SCREENHEIGHT;
//假设x < 0表示左滑
if (_redView.frame.origin.x < 0) {
scale = (SCREENHEIGHT + 2*offsetY)/SCREENHEIGHT;
} CGRect frame = _redView.frame;
//计算滑动之后的frame
CGFloat height = frame.size.height*scale;
CGFloat width = frame.size.width;
CGFloat x = frame.origin.x + offsetX;
CGFloat y = (SCREENHEIGHT- height)* 0.5; return CGRectMake(x, y, width, height);
}

2.通过KVO来监听redView的frame的变化,从而推断redView是左滑还是右滑。往左移动。显示右边,隐藏左边 往右移动。显示左边。隐藏右边

- (void)viewDidLoad {
[super viewDidLoad];
[self setUpthreeViews]; // 利用KVO时刻监听_redView.frame改变
// Observer:谁须要观察
// KeyPath:监听的属性名称
// options: NSKeyValueObservingOptionNew监听这个属性新值
[_redView addObserver:self forKeyPath:@"frame" options:NSKeyValueObservingOptionNew context:nil];
} // 仅仅要监听的属性有新值的时候。仅仅要redView.frame一改变就会调用
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary *)change context:(void *)context
{
if (self.redView.frame.origin.x > 0) {
_greenView.hidden = NO;
} else if(self.redView.frame.origin.x < 0){
_greenView.hidden = YES;
}
} // 当对象销毁的时候,一定要移除观察者
- (void)dealloc
{
[_redView removeObserver:self forKeyPath:@"frame"];
}

3.设置触摸结束的时候。redView的frame。假设redView側滑没有到屏幕的一半,则自己主动返回到初始位置。

假设超过屏幕的一半,则停留在一个新的位置


- (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event
{
CGFloat xPos = _redView.frame.origin.x;
//大于屏幕的一半进入新的位置
if (xPos > SCREENWIDTH*0.5) {
[UIView animateWithDuration:0.5 animations:^{
self.redView.frame = [self framWithBigThanX:ENDRIGHTX];
}];
return ;
}
//小于屏幕的一半。大于屏幕负一半的时候,则恢复到初始状态
if (xPos < SCREENWIDTH*0.5 && xPos > -SCREENWIDTH*0.5) {
[UIView animateWithDuration:0.5 animations:^{
self.redView.frame = [UIScreen mainScreen].bounds;
}];
return ;
}
//xPos < -SCREENWIDTH*0.5的时候,进入新的位置
[UIView animateWithDuration:0.5 animations:^{
self.redView.frame = [self framWithSmallThanX:ENDLEFTX];
}]; } - (CGRect)framWithBigThanX:(CGFloat)offsetX
{ CGFloat offsetY = offsetX/SCREENWIDTH * MAXYOFFSET;
CGFloat scale = (SCREENHEIGHT - 2*offsetY)/SCREENHEIGHT; CGFloat height = SCREENHEIGHT*scale;
CGFloat width = SCREENWIDTH;
CGFloat x = offsetX;
CGFloat y = (SCREENHEIGHT- height)* 0.5; return CGRectMake(x, y, width, height);
} - (CGRect)framWithSmallThanX:(CGFloat)offsetX
{
CGFloat offsetY = offsetX/SCREENWIDTH * MAXYOFFSET;
CGFloat scale = (SCREENHEIGHT + 2*offsetY)/SCREENHEIGHT; CGFloat height = SCREENHEIGHT*scale;
CGFloat width = SCREENWIDTH;
CGFloat x = offsetX;
CGFloat y = (SCREENHEIGHT- height)* 0.5; return CGRectMake(x, y, width, height);
}

iOS实现抽屉效果的更多相关文章

  1. iOS LeftMenu抽屉效果与ScrollView共存时的手势冲突

    公司有个项目,需要做左侧滑动,首页是ScrollView嵌套TableView.首页是一个ScrollView,所以当contentOffset是0.0的时候,无法直接滑动出抽屉效果,用户体验感非常差 ...

  2. ios开发抽屉效果的封装使用

    #import "DragerViewController.h" #define screenW [UIScreen mainScreen].bounds.size.width @ ...

  3. iOS开发之抽屉效果实现

    说道抽屉效果在iOS中比较有名的第三方类库就是PPRevealSideViewController.一说到第三方类库就自然而然的想到我们的CocoaPods,今天的博客中用CocoaPods引入PPR ...

  4. ios开发中超简单抽屉效果(MMDrawerController)的实现

    ios开发中,展示类应用通常要用到抽屉效果,由于项目需要,本人找到一个demo,缩减掉一些不常用的功能,整理出一个较短的实例. 首先需要给工程添加第三方类库 MMDrawerController: 这 ...

  5. 玩转iOS开发 - 简易的实现2种抽屉效果

    BeautyDrawer BeautyDrawer 是一款简单易用的抽屉效果实现框架,集成的属性能够对view 滑动缩放进行控制. Main features 三个视图,主视图能够左右滑动.实现抽屉效 ...

  6. iOS中 超简单抽屉效果(MMDrawerController)的实现

    ios开发中,展示类应用通常要用到抽屉效果,由于项目需要,本人找到一个demo,缩减掉一些不常用的功能,整理出一个较短的实例. 首先需要给工程添加第三方类库 MMDrawerController: 这 ...

  7. iOS开发——实用技术OC篇&简单抽屉效果的实现

    简单抽屉效果的实现 就目前大部分App来说基本上都有关于抽屉效果的实现,比如QQ/微信等.所以,今天我们就来简单的实现一下.当然如果你想你的效果更好或者是封装成一个到哪里都能用的工具类,那就还需要下一 ...

  8. 更好的抽屉效果(ios)

    昨天项目基本没啥事了,晚上早早的就回家了,躺在床上无聊地玩着手机(Android的),在清理系统垃圾时被一个“360手机助手”给吸引了, 其实我是被它的那个抽屉效果给吸引了,此时你也许会觉得我out了 ...

  9. iOS详解MMDrawerController抽屉效果(一)

      提前说好,本文绝对不是教你如何使用MMDrawerController这个第三方库,因为那太多人写了 ,也太简单了.这篇文章主要带你分析MMDrawerController是怎么实现抽屉效果,明白 ...

随机推荐

  1. php---依赖倒转(反转控制)原则

    一.简介 依赖注入和控制反转说的实际上是同一个东西,它们是一种设计模式,这种设计模式用来减少程序间的耦合 优点:使用依赖注入,最重要的一点好处就是有效的分离了对象和它所需要的外部资源,使得它们松散耦合 ...

  2. table合并单元格 colspan(跨列)和rowspan(跨行)

    colspan和rowspan这两个属性用于创建特殊的表格. colspan是“column span(跨列)”的缩写.colspan属性用在td标签中,用来指定单元格横向跨越的列数: 在浏览器中将显 ...

  3. WCF WEB HTTP请求 WCF REST FUL

    首先上点概念WCF 很好的支持了 REST 的开发, 而 RESTful 的服务通常是架构层面上的考虑. 因为它天生就具有很好的跨平台跨语言的集成能力,几乎所有的语言和网络平台都支持 HTTP 请求, ...

  4. DataTable转Dictionary

    DataTable dt = new DataTable(); dt.Columns.Add("name"); dt.Columns.Add("no"); dt ...

  5. Codeforces Round #453

    Visiting a Friend Solution Coloring a Tree 自顶向下 Solution Hashing Trees 连续2层节点数都超过1时能异构 Solution GCD ...

  6. MVC:@RenderBody、@RenderPage、@RenderSection用法

    本文导读:在Razor引擎中没有了“母版页”,取而代之的是叫做“布局”的页面(_Layout.cshtml)放在了共享视图文件夹中.模板页:@RenderBody()占位符:局部页面:@RenderP ...

  7. SqlServer数据库表导入SqlLite数据库表保持日期时间类型字段的格式

    在写查询功能的过程中遇到一个这样的问题:按日期范围查询,sql语句是:where dt>=用户选择起始日期&&dt<=用户选择结束日期.数据库中的数据如图1,我选择的测试数 ...

  8. 团体程序设计天梯赛-练习集-L1-027. 出租

    L1-027. 出租 下面是新浪微博上曾经很火的一张图: 一时间网上一片求救声,急问这个怎么破.其实这段代码很简单,index数组就是arr数组的下标,index[0]=2 对应 arr[2]=1,i ...

  9. 死磕itchat源码--__init__.py

    itchat包中的__init__.py是该库的入口:在该文件中的源码如下: # -*- coding: utf-8 -*- from . import content from .core impo ...

  10. Python基础学习_01修改代码所属作者

    1.修改开头的作者Author 2.具体步骤如下图 (1)点击下图所画的按钮 (2)具体操作如图所示,就可以得到自己想要的结果了.