首页 > 其他 > 详细

在UITableView中识别作用滑动,实现上下翻页的功能

时间:2014-06-02 19:15:25      阅读:365      评论:0      收藏:0      [点我收藏+]

目前有三种方案:

1.

UIScrollView + UITableView。

实现方法,在UIScrollView中,加入UITableView即可

设置UIScrollView的代理和方法

bubuko.com,布布扣
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
    int currentPostion = scrollView.contentOffset.x;
    if (currentPostion - 0 > 50) {
        NSLog(@"Scroll right now ");
    }
    else if (0 - currentPostion > 50)
    {
        NSLog(@"Scroll left now");
    }
}
bubuko.com,布布扣

 

2.利用UISwipeGestureRecognizer 

原文地址:http://www.2cto.com/kf/201312/265158.html

bubuko.com,布布扣
-(void)viewDidLoad{

UISwipeGestureRecognizer *recognizer;

recognizer = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(handleSwipeFrom:)];

[recognizer setDirection:(UISwipeGestureRecognizerDirectionRight)];

[[self view] addGestureRecognizer:recognizer];

recognizer = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(handleSwipeFrom:)];

[recognizer setDirection:(UISwipeGestureRecognizerDirectionLeft)];

[[self view] addGestureRecognizer:recognizer];

recognizer = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(handleSwipeFrom:)];

[recognizer setDirection:(UISwipeGestureRecognizerDirectionUp)];

[[self view] addGestureRecognizer:recognizer];

recognizer = [[UISwipeGestureRecognizer alloc]initWithTarget:self action:@selector(handleSwipeFrom:)];

[recognizer setDirection:(UISwipeGestureRecognizerDirectionDown)];

[[self view] addGestureRecognizer:recognizer];

}

-(void)handleSwipeFrom:(UISwipeGestureRecognizer *)recognizer{

if(recognizer.direction==UISwipeGestureRecognizerDirectionDown) {

NSLog(@"swipe down");

//执行程序

}

if(recognizer.direction==UISwipeGestureRecognizerDirectionUp) {

NSLog(@"swipe up");

//执行程序

}


if(recognizer.direction==UISwipeGestureRecognizerDirectionLeft) {

NSLog(@"swipe left");

//执行程序

}


if(recognizer.direction==UISwipeGestureRecognizerDirectionRight) {

NSLog(@"swipe right");

//执行程序

}


}
bubuko.com,布布扣

 

3.

原文地址:http://www.cppblog.com/Khan/archive/2013/02/27/198100.html

UITableView 屏蔽了左右滑动事件.  通过重载的方式可以注入事件touch事件, 供开发者使用..

bubuko.com,布布扣
 #import <UIKit/UIKit.h>
 @protocol TouchTableViewDelegate <NSObject>
 @optional
 - (void)tableView:(UITableView *)tableView touchesBegin:(NSSet *)touches withEvent:(UIEvent *)event;
 - (void)tableView:(UITableView *)tableView touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event;
 - (void)tableView:(UITableView *)tableView touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event;
 - (void)tableView:(UITableView *)tableView touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event;
 @end
bubuko.com,布布扣

bubuko.com,布布扣
 #import "TouchTableView.h"
 
 @implementation TouchTableView
 
 @synthesize touchDelegate = _touchDelegate;
 
 - (void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event {
     [super touchesBegan:touches withEvent:event];
     
     if ([_touchDelegate conformsToProtocol:@protocol(TouchTableViewDelegate)] &&
         [_touchDelegate respondsToSelector:@selector(tableView:touchesBegin:withEvent:)])
     {
         [_touchDelegate tableView:self touchesBegin:touches withEvent:event];
     }
 }
 
 - (void)touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event {
     [super touchesCancelled:touches withEvent:event];
     
     if ([_touchDelegate conformsToProtocol:@protocol(TouchTableViewDelegate)] &&
         [_touchDelegate respondsToSelector:@selector(tableView:touchesCancelled:withEvent:)])
     {
         [_touchDelegate tableView:self touchesCancelled:touches withEvent:event];
     }
 }
 
 - (void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event {
     [super touchesEnded:touches withEvent:event];
     
     if ([_touchDelegate conformsToProtocol:@protocol(TouchTableViewDelegate)] &&
         [_touchDelegate respondsToSelector:@selector(tableView:touchesEnded:withEvent:)])
     {
         [_touchDelegate tableView:self touchesEnded:touches withEvent:event];
     }
 }
 
 - (void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event {
     [super touchesMoved:touches withEvent:event];
     
     if ([_touchDelegate conformsToProtocol:@protocol(TouchTableViewDelegate)] &&
         [_touchDelegate respondsToSelector:@selector(tableView:touchesMoved:withEvent:)])
     {
         [_touchDelegate tableView:self touchesMoved:touches withEvent:event];
     }
 }
 
 @end
bubuko.com,布布扣
 
调用方法 :
1. 头文件中加入delegate
bubuko.com,布布扣
@interface MoneyViewCtl : UIViewController<UITableViewDataSource, UITableViewDelegate, SDWebDataDownloaderDelegate, EGORefreshTableHeaderDelegate, TouchTableViewDelegate>{

    

    IBOutlet UISegmentedControl *_sigTime;

    IBOutlet TouchTableView *_tableview;

 

}

@end
bubuko.com,布布扣

 2. .m文件中设置好delegate

_tableview.touchDelegate = self;

 3. .m文件中实现如下事件 

bubuko.com,布布扣
#pragma mark - TouchTableViewDelegate lifecycle

- (void)tableView:(UITableView *)tableView touchesBegin:(NSSet *)touches withEvent:(UIEvent *)event{

    NSLog(@"touchesBegin");

}

- (void)tableView:(UITableView *)tableView touchesCancelled:(NSSet *)touches withEvent:(UIEvent *)event{

    NSLog(@"touchesCancelled");

}

 

- (void)tableView:(UITableView *)tableView touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event{

    NSLog(@"touchesEnded");

}

- (void)tableView:(UITableView *)tableView touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event{

    NSLog(@"touchesMoved");

}
bubuko.com,布布扣

 

在UITableView中识别作用滑动,实现上下翻页的功能,布布扣,bubuko.com

在UITableView中识别作用滑动,实现上下翻页的功能

原文:http://www.cnblogs.com/JuneWang/p/3764373.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!