iOS 下类似UITableView的可循环列表利用UIScrollView制作

本文介绍了如何在iOS应用中,通过UIScrollView实现类似UITableView的可循环列表效果,并着重讲解了如何添加滑动到中间和滑动结束时的响应事件。项目代码已提供下载链接。

最近项目循环效果的列表,我在网上搜到一个只有类似效果的例子,我在这个例子的基础之上加入了对应的响应事件。1、滑动到中间的响应事件

2、滑动结束的响应事件。

代码下载:http://download.csdn.net/detail/qqmcy/6926031

ViewController.h

#import <UIKit/UIKit.h>
#import "InfiniteScrollPicker.h"

@interface ViewController : UIViewController<InfiniteScrollPickerDelegate>

@property (strong , nonatomic) InfiniteScrollPicker* m_InfiniteScroll;
@property (strong , nonatomic) UILabel* m_labelTest;

@end

ViewController.m

- (void)viewDidLoad
{
    [super viewDidLoad];
	// Do any additional setup after loading the view, typically from a nib.
    

    
    NSMutableArray* set1 = [[NSMutableArray alloc] init];
    for (int i = 0; i < 40; i++) {
        
        UIImage* img = [UIImage imageNamed:[NSString stringWithFormat:@"s1_0.png",i]];
        
                    
        [set1 addObject:img];
    }
    self.m_InfiniteScroll = [[InfiniteScrollPicker alloc] initWithFrame:CGRectMake(0, 448, 320, 100)];
    self.m_InfiniteScroll.backgroundColor  = [UIColor redColor];
    self.m_InfiniteScroll.Infinitedelegate = self;
    [self.m_InfiniteScroll setItemSize:CGSizeMake(50, 50)];
    [self.m_InfiniteScroll setImageAry:set1];
    [self.view addSubview:self.m_InfiniteScroll];

   // self.view.transform =  CGAffineTransformMakeRotation(M_PI / 2);
        [UIApplication sharedApplication].statusBarOrientation = UIInterfaceOrientationLandscapeRight;
    
    self.m_labelTest = [[UILabel alloc] initWithFrame:CGRectMake(100, 300, 100, 50)];
    
    [self.view addSubview:self.m_labelTest];
    
   
    
}


-(BOOL)shouldAutorotate
{
    return NO;
}


#pragma mark-  InfiniteScrollPickerDelegate

/*点击单张图片的回调*/
-(void)tapImageViewMethod:(UIGestureRecognizer *)gesture
{
    
    self.m_labelTest.text = [NSString stringWithFormat:@"%d",gesture.view.tag];
    NSLog(@"gesture.view.tag = %d",gesture.view.tag);
}

/*滑动时的回调*/
-(void)sliderInfiniteScrollView:(UIView *)view
{
    self.m_labelTest.text = [NSString stringWithFormat:@"%d",view.tag];
    NSLog(@"slider view.tag = %d",view.tag);
}
/*结束时的回调*/
-(void)infiniteScrollPicker:(InfiniteScrollPicker *)infiniteScrollPicker didSelectAtImageView:(UIView *)view
{
    self.m_labelTest.text = [NSString stringWithFormat:@"%d",view.tag];
    NSLog(@"stop image tag= %d",view.tag);
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杜甲同学

感谢打赏,我会继续努力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值