iOS 下类似UITableView的可循环列表利用UIScrollView制作可以控制另一个UITableView(2)

本文是对之前一篇文章的补充:http://blog.csdn.net/qqmcy/article/details/19282213

代码:http://download.csdn.net/detail/qqmcy/7008341

效果



ViewController.h

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

@interface ViewController : UIViewController<InfiniteScrollPickerDelegate>

@property (strong , nonatomic) InfiniteScrollPicker* m_InfiniteScroll;
@property (strong , nonatomic) InfiniteScrollPicker* m_InfiniteScroll2;

@property (strong , nonatomic) UILabel* m_labelTest;
@property (strong , nonatomic) StaticDataModel* m_StaticData;


@property (assign , nonatomic) BOOL m_bSwitch;
@end

ViewController.m

//
//  ViewController.m
//  InfiniteScrollPickerDemo2
//
//  Created by 杜甲 on 14-2-14.
//  Copyright (c) 2014年 杜甲. All rights reserved.
//

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad
{
    [super viewDidLoad];
    _m_bSwitch = true;
	// Do any additional setup after loading the view, typically from a nib.
    self.m_StaticData = [StaticDataModel getInstance];

    
    NSMutableArray* set1 = [[NSMutableArray alloc] init];
    for (int i = 0; i < self.m_StaticData.m_OrganizationArr.count; i++) {
        
        UIImage* img = [UIImage imageNamed:[NSString stringWithFormat:@"s1_0.png",i]];
        
                    
        [set1 addObject:img];
    }
    
    
    
    self.m_InfiniteScroll = [[InfiniteScrollPicker alloc] initWithFrame:CGRectMake(0, 448, 220, 90)];
  //  self.m_InfiniteScroll.backgroundColor  = [UIColor redColor];
    self.m_InfiniteScroll.Infinitedelegate = self;
    self.m_InfiniteScroll.organizationArr = self.m_StaticData.m_OrganizationArr;
    [self.m_InfiniteScroll setItemSize:CGSizeMake(40, 40)];
    [self.m_InfiniteScroll setImageAry:set1];
    self.m_InfiniteScroll.positionRatio = 2.0f;
    [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];
    
    
    NSMutableArray* set2 = [[NSMutableArray alloc] init];
    for (int i = 0; i < self.m_StaticData.m_OrganizationArr.count; i++) {
        
        UIImage* img = [UIImage imageNamed:[NSString stringWithFormat:@"five.png"]];
        
        
        [set2 addObject:img];
    }

    self.m_InfiniteScroll2 = [[InfiniteScrollPicker alloc] initWithFrame:CGRectMake(60, 208, 220, 90)];
   // self.m_InfiniteScroll2.backgroundColor  = [UIColor redColor];
    self.m_InfiniteScroll2.Infinitedelegate = self;
    self.m_InfiniteScroll2.organizationArr = self.m_StaticData.m_OrganizationArr;
    [self.m_InfiniteScroll2 setItemSize:CGSizeMake(20, 20)];
    [self.m_InfiniteScroll2 setImageAry:set2];
    self.m_InfiniteScroll2.positionRatio = 2.0f;
    self.m_InfiniteScroll2.alphaOfobjs = 0.2f;
    self.m_InfiniteScroll2.heightOffset = 1;
    self.m_InfiniteScroll2.alpha  = 0.0f;
    [self.view addSubview:self.m_InfiniteScroll2];
    
}


-(BOOL)shouldAutorotate
{
    return NO;
}


#pragma mark-  InfiniteScrollPickerDelegate

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

-(void)sliderInfiniteScrollView:(UIView *)view reloadView:(float)offset
{
    if (_m_bSwitch) {
        [UIView animateWithDuration:0.2f animations:^{
             self.m_InfiniteScroll2.alpha = 1.0;
        } completion:^(BOOL finished) {
            
        }];
       
    }
    _m_bSwitch = false;
    [self.m_InfiniteScroll2 scrollRectToVisible:CGRectMake(offset, 48, 220, 90) animated:NO];

}

/*滑动时的回调*/
-(void)sliderInfiniteScrollView:(UIView *)view
{
    [self.m_InfiniteScroll2 scrollRectToVisible:CGRectMake(10, 48, 220, 90) animated:YES];
    self.m_labelTest.text = [self.m_StaticData.m_OrganizationArr objectAtIndex:view.tag];    NSLog(@"slider view.tag = %d",view.tag);
    
    }
/*结束时的回调*/
-(void)infiniteScrollPicker:(InfiniteScrollPicker *)infiniteScrollPicker didSelectAtImageView:(UIView *)view
{
    self.m_labelTest.text = [self.m_StaticData.m_OrganizationArr objectAtIndex:view.tag];
    NSLog(@"stop image tag= %d",view.tag);
}

-(void)infiniteScrollPicker:(InfiniteScrollPicker *)infiniteScrollPicker didSelectAtImageView:(UIView *)view reloadView:(float)offset
{
    self.m_labelTest.text = [self.m_StaticData.m_OrganizationArr objectAtIndex:view.tag];
    
    [self.m_InfiniteScroll2 scrollRectToVisible:CGRectMake(offset, 48, 220, 90) animated:YES];
    
    _m_bSwitch = true;
    
    [UIView animateWithDuration:0.3f animations:^{
            self.m_InfiniteScroll2.alpha = 0.0f;
    } completion:^(BOOL finished) {
        
    }];

}


- (void)didReceiveMemoryWarning
{
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
iOS中,一个视图只能有一个UITableView。但是可以通过创建多个UITableView来实现一个视图中显示多个表格的效果。以下是一个示例代码: 首先,你需要在视图控制器中添加多个UITableView的实例变量: ```swift class YourViewController: UIViewController { var tableView1: UITableView! var tableView2: UITableView! // ... } ``` 然后,在视图加载完成后,你可以创建和配置这些UITableView的实例: ```swift override func viewDidLoad() { super.viewDidLoad() // 创建第一个UITableView tableView1 = UITableView(frame: CGRect(x: 0, y: 0, width: view.frame.width, height: view.frame.height/2)) tableView1.dataSource = self tableView1.delegate = self view.addSubview(tableView1) // 创建第二个UITableView tableView2 = UITableView(frame: CGRect(x: 0, y: view.frame.height/2, width: view.frame.width, height: view.frame.height/2)) tableView2.dataSource = self tableView2.delegate = self view.addSubview(tableView2) // ... } ``` 接下来,你需要实现UITableViewDataSource和UITableViewDelegate协议的相关方法来提供表格的数据和处理交互事件。例如: ```swift extension YourViewController: UITableViewDataSource { func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { if tableView == tableView1 { // 返回第一个UITableView的行数 return 10 } else if tableView == tableView2 { // 返回第二个UITableView的行数 return 5 } return 0 } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) if tableView == tableView1 { // 配置第一个UITableView的单元格 cell.textLabel?.text = "Table View 1 - Row \(indexPath.row)" } else if tableView == tableView2 { // 配置第二个UITableView的单元格 cell.textLabel?.text = "Table View 2 - Row \(indexPath.row)" } return cell } } extension YourViewController: UITableViewDelegate { func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { if tableView == tableView1 { // 处理第一个UITableView的行选中事件 print("Table View 1 - Row \(indexPath.row) selected") } else if tableView == tableView2 { // 处理第二个UITableView的行选中事件 print("Table View 2 - Row \(indexPath.row) selected") } } } ``` 这样,你就可以在同一个视图中使用多个UITableView了。记得在视图控制器中遵循UITableViewDataSource和UITableViewDelegate协议,并在视图加载完成后设置数据源和代理。 希望这能帮到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

杜甲同学

感谢打赏,我会继续努力

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

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

打赏作者

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

抵扣说明:

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

余额充值