IOS ScrollView Tableview 拖动上面图片放大(类似京东登陆)

- (void)layoutSubViews
{
    _logoImage = IMAGENAMED(@"abc.jpg");
    self.tableView = [[UITableView alloc] initWithFrame:self.view.frame style:UITableViewStylePlain];
    
    //scrollView  tableView
    self.tableView.frame = CGRectMake(0, 0, App_Frame_Width, APP_Frame_Height - 44);
    self.tableView.contentInset = UIEdgeInsetsMake(kViewOriginHeight, 0, 0, 0);
    
    [self.tableView registerClass:[UITableViewCell class] forCellReuseIdentifier:@"Cell"];
    self.tableView.dataSource = self;
    self.tableView.delegate = self;
    [self.view addSubview:self.tableView];
    
    
    
    //heardView,
    //这里设置初始坐标,
    self.heardView = [[UIView alloc] initWithFrame:CGRectMake(0, -kViewOriginHeight, App_Frame_Width, kViewOriginHeight)];
    self.heardView.userInteractionEnabled = YES;
    
    [self.tableView addSubview:self.heardView];
    
    
    //heardView 上的子view
    UIImageView *bgImageView = [[UIImageView alloc] init];
    bgImageView.frame = CGRectMake(0, 0, App_Frame_Width, HEIGHT(self.heardView));
    bgImageView.image = _logoImage;
    bgImageView.tag = 101;
    [self.heardView addSubview:bgImageView];
    
    
    UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(App_Frame_Width/2.0 - 50, HEIGHT(self.heardView)/2.0 - 15, 100, 30)];
    
    button.backgroundColor = RGBACOLOR(0, 118, 110, 0.3);
    [button setTitle:@"登陆" forState:UIControlStateNormal];
    
    [button handleControlEvent:UIControlEventTouchUpInside withBlock:^(id sender) {
        NSLog(@"点击哦了");
    }];
    button.tag = 102;
    [self.heardView addSubview:button];
    
    
    
    
}

- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    NSLog(@"self.tabelView.offset = %f", self.tableView.contentOffset.y);
    
    CGFloat yOffst = scrollView.contentOffset.y;
    
    if (yOffst < -kViewOriginHeight) {
        //调整heardView的坐标,使heardView的顶点再界面的顶点不变, 高度变大从而实现效果
        CGRect f = self.heardView.frame;
        f.origin.y = yOffst;
        f.size.height = -yOffst;
        self.heardView.frame = f;
        
        //调整hardView上子控件的坐标
        UIImageView *imageview = (UIImageView*)VIEWWITHTAG(self.heardView, 101);
        float height = HEIGHT(self.heardView);
        float width = height * 3.2;
        imageview.frame = CGRectMake(App_Frame_Width / 2.0 - width/2.0, 0, width, height);
        
        
        UIButton *button = (UIButton*)VIEWWITHTAG(self.heardView, 102);
        
        button.frame = CGRectMake(App_Frame_Width/2.0 - 50, HEIGHT(self.heardView)/2.0 - 15, 100, 30);
    }
    
}
static CGFloat kViewOriginHeight = 100.0f;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
iOS 开发中,嵌套在 `UIScrollView` 中的 `UITableView` 在滑动时可能会与 `UIScrollView` 的滑动手势产生冲突,导致无法正常滑动。这个问题可以通过以下两种方式解决: 1. 禁用 `UIScrollView` 的滑动手势 可以通过设置 `UIScrollView` 的 `panGestureRecognizer` 的 `enabled` 属性为 `NO` 来禁用滑动手势,这样就不会与 `UITableView` 的滑动手势产生冲突了。 ```objc scrollView.panGestureRecognizer.enabled = NO; ``` 2. 实现 `UIGestureRecognizerDelegate` 协议的方法 在 `UIViewController` 中实现 `UIGestureRecognizerDelegate` 协议的 `gestureRecognizer:shouldRecognizeSimultaneouslyWithGestureRecognizer:` 方法,可以控制两个手势是否允许同时识别。在这个方法中,可以判断当前的手势是否为 `UIScrollView` 的滑动手势,如果是,则允许与 `UITableView` 的滑动手势同时识别,否则不允许。 ```objc - (BOOL)gestureRecognizer:(UIGestureRecognizer *)gestureRecognizer shouldRecognizeSimultaneouslyWithGestureRecognizer:(UIGestureRecognizer *)otherGestureRecognizer { if ([gestureRecognizer.view isKindOfClass:[UIScrollView class]] && [otherGestureRecognizer.view isKindOfClass:[UITableView class]]) { return YES; } return NO; } ``` 需要注意的是,在实现这个方法时,要将 `UIScrollView` 的 `delegate` 设置为当前的 `UIViewController`,否则这个方法不会被调用。 ```objc scrollView.delegate = self; ``` 以上两种方式都可以解决嵌套在 `UIScrollView` 中的 `UITableView` 滑动手势冲突的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值