欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS實現(xiàn)簡易抽屜效果、雙邊抽屜效果

 更新時間:2016年02月27日 09:27:19   投稿:lijiao  
這篇文章主要為大家詳細(xì)介紹了兩款iOS抽屜效果,簡易抽屜效果、以及雙邊抽屜效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了iOS實現(xiàn)抽屜效果的全部代碼,供大家參考,具體內(nèi)容如下

iOS實現(xiàn)簡易抽屜效果,代碼:

@interface ViewController () {
 UIView* _leftView;
}
 
@end
 
@implementation ViewController
 
- (void)viewDidLoad {
 [super viewDidLoad];
 // Do any additional setup after loading the view, typically from a nib.
 
 _leftView = [[UIView alloc] init];
 //把左側(cè)邊的view先隱藏
 _leftView.frame = CGRectMake(-200, 0, 200, self.view.frame.size.height);
 _leftView.backgroundColor = [UIColor greenColor];
 [self.view addSubview:_leftView];
 
 UIPanGestureRecognizer* pan = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(handlePan:)];
 [self.view addGestureRecognizer:pan];
}
 
- (void)handlePan:(UIPanGestureRecognizer*) recognizer {
 CGPoint translation = [recognizer translationInView:self.view];
 //增量后的x坐標(biāo)位置
 CGFloat Xresult = translation.x + _leftView.frame.origin.x;
 
 //向右
 if (translation.x >= 0) {
 //leftView已全部拉出,則無法再向右
 if (_leftView.frame.origin.x >= 0 || Xresult >= 0) {
  _leftView.frame = CGRectMake(0, 0, 200, self.view.frame.size.height);
  
  return;
 }
 } else if (translation.x < 0) {//向左
 //leftView已全部收回,則無法再向左
 if (_leftView.frame.origin.x <= -200 || Xresult <= -200) {
  _leftView.frame = CGRectMake(-200, 0, 200, self.view.frame.size.height);
  return;
 }
 }
 
 CGRect frame = _leftView.frame;
 frame.origin.x += translation.x;
 _leftView.frame = frame;
 
 //清空移動的距離,這是關(guān)鍵
 [recognizer setTranslation:CGPointZero inView:recognizer.view];
 
 //做彈回效果,以中軸為界限
 if (recognizer.state == UIGestureRecognizerStateEnded) {
 if (_leftView.frame.origin.x > -100) {
  [self closeView:NO];
 } else {
  [self closeView:YES];
 }
 }
}
 
- (void)closeView:(BOOL)close {
 if (close) {
 [self moveView:CGRectMake(-200, 0, 200, self.view.frame.size.height)];
 } else {
 [self moveView:CGRectMake(0, 0, 200, self.view.frame.size.height)];
 }
}
 
- (void)moveView:(CGRect)frame {
 [UIView animateWithDuration:0.3 animations:^{
 _leftView.frame = frame;
 } completion:^(BOOL finished) {
  
 }];
}

iOS實現(xiàn)雙邊抽屜效果,代碼:

#import "PathView.h"
#import "UIView+Additions.h"
 
@implementation PathView
 
- (instancetype)init {
 self = [super init];
 if (self) {
 [self setupGestureRecognizer];
 }
 return self;
}
 
- (void)setupGestureRecognizer {
 UIPanGestureRecognizer* pan = [[UIPanGestureRecognizer alloc] initWithTarget:self action:@selector(handlePan:)];
 [self addGestureRecognizer:pan];
}
 
- (void)handlePan:(UIPanGestureRecognizer*)recognizer {
 CGPoint translation = [recognizer translationInView:self];
 
 CGFloat Xresult = translation.x + self.left;
 
 if (translation.x >= 0) {//向右
 if (self.left >= _leftWidth || Xresult >= _leftWidth) {
  self.frame = CGRectMake(_leftWidth, 0, self.width, self.height);
  return;
 }
 }
 else if (translation.x < 0) {//向左
 if (self.left <= -_rightWidth || Xresult <= -_rightWidth) {
  self.frame = CGRectMake(-_rightWidth, 0, self.width, self.height);
  return;
 }
 }
 
 self.left += translation.x;
 
 if (recognizer.state == UIGestureRecognizerStateEnded) {
 if (self.left > _leftWidth / 2) {
  [self openLeft:YES openRight:NO];
 }
  
 else if (self.left < -(_rightWidth / 2)) {
  [self openLeft:NO openRight:YES];
 }
  
 else {
  [self openLeft:NO openRight:NO];
 }
 }
 
 //清空移動的距離
 [recognizer setTranslation:CGPointZero inView:recognizer.view];
}
 
- (void)openLeft:(BOOL)left openRight:(BOOL)right {
 if (!left && !right) {
 [self moveView:CGRectMake(0, 0, self.width, self.height)];
  
 } else if (!left && right) {
 [self moveView:CGRectMake(-_rightWidth, 0, self.width, self.height)];
  
 } else if (left && !right) {
 [self moveView:CGRectMake(_leftWidth, 0, self.width, self.height)];
  
 }
}
 
- (void)moveView:(CGRect)frame {
 [UIView animateWithDuration:0.3 animations:^{
 self.frame = frame;
 } completion:^(BOOL finished) {
  
 }];
}

上面是實現(xiàn)的具體內(nèi)容,所以不做多少注釋,只不過把手勢移到view里面,讓view自己改變自己的frame;再有就是添加了兩個屬性,來指定左右兩邊各自抽屜抽出的寬度,某一邊不需要,只要設(shè)置為0就好了。

以上就是本文的全部內(nèi)容,希望能夠幫助大家順利實現(xiàn)iOS抽屜效果。

相關(guān)文章

  • IOS開發(fā)之CocoaPods安裝和使用教程

    IOS開發(fā)之CocoaPods安裝和使用教程

    CocoaPods應(yīng)該是iOS最常用最有名的類庫管理工具了,通過cocoaPods,只需要一行命令就可以完全解決,當(dāng)然前提是你必須正確設(shè)置它。重要的是,絕大部分有名的開源類庫,都支持CocoaPods。所以,作為iOS程序員的我們,掌握CocoaPods的使用是必不可少的基本技能了。
    2014-09-09
  • IOS應(yīng)用內(nèi)支付返回新舊Receipt適配的方法

    IOS應(yīng)用內(nèi)支付返回新舊Receipt適配的方法

    本篇文章主要介紹了IOS應(yīng)用內(nèi)支付返回新舊Receipt適配的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • iOS開發(fā)之手勢識別實例

    iOS開發(fā)之手勢識別實例

    本篇文章主要介紹了iOS開發(fā)之手勢識別實例,具有一定的參考價值,有需要的可以了解一下。
    2016-11-11
  • iOS通過block在兩個頁面間傳值的方法

    iOS通過block在兩個頁面間傳值的方法

    不知道大家有沒有發(fā)現(xiàn),在實際開發(fā)中使用block的地方特別多,block比delegate和notification有著更簡潔的優(yōu)勢,下面這篇文章我們來簡單了解一下block在兩個頁面之間的傳值。有需要的朋友們可以參考借鑒,下面來一起學(xué)習(xí)學(xué)習(xí)吧。
    2016-11-11
  • iOS webview捕獲H5按鈕方法示例代碼

    iOS webview捕獲H5按鈕方法示例代碼

    這篇文章主要給大家介紹了關(guān)于iOS webview捕獲H5按鈕方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • iOS實現(xiàn)調(diào)用QQ客戶端發(fā)起臨時會話

    iOS實現(xiàn)調(diào)用QQ客戶端發(fā)起臨時會話

    本篇文章主要給大家詳細(xì)分析了用IOS實現(xiàn)調(diào)用QQ客戶端發(fā)起臨時會話的功能,對此有需要的朋友收藏分享下。
    2018-02-02
  • iOS 原生實現(xiàn)掃描二維碼和條形碼功能限制掃描區(qū)域

    iOS 原生實現(xiàn)掃描二維碼和條形碼功能限制掃描區(qū)域

    這篇文章主要介紹了iOS 原生實現(xiàn)掃描二維碼和條形碼功能限制掃描區(qū)域,需要的朋友可以參考下
    2017-03-03
  • iOS字體抖動動畫的實現(xiàn)代碼

    iOS字體抖動動畫的實現(xiàn)代碼

    這篇文章主要介紹了iOS字體抖動動畫的實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-03-03
  • IOS網(wǎng)絡(luò)請求之NSURLSession使用詳解

    IOS網(wǎng)絡(luò)請求之NSURLSession使用詳解

    這篇文章主要介紹了IOS網(wǎng)絡(luò)請求之NSURLSession使用詳解,今天使用NSURLConnection分別實現(xiàn)了get、post、表單提交、文件上傳、文件下載,有興趣的可以了解一下。
    2017-02-02
  • iOS實現(xiàn)百度地圖拖拽后更新位置以及反編碼

    iOS實現(xiàn)百度地圖拖拽后更新位置以及反編碼

    百度地圖已經(jīng)開放了地圖API,大家可以很方便的調(diào)用地圖中的相應(yīng)數(shù)據(jù),并完成各項個性化的展示,下面這篇文章主要給大家介紹了關(guān)于iOS如何實現(xiàn)百度地圖拖拽后更新位置以及反編碼的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-12-12

最新評論