iOS 滚动视图 UIScrollView 代理方法 相关属性 状态栏 滚动条 回弹 弹簧效果

iOS 滚动视图 UIScrollView 代理方法 相关属性 状态栏 滚动条 回弹 弹簧效果

#import "ViewController.h"

@interface ViewController () <span style="color:#ff0000;"><UIScrollViewDelegate></span>

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    // 定义屏幕宽度和高度
    CGFloat width  = [UIScreen mainScreen].bounds.size.width;
    CGFloat height = [UIScreen mainScreen].bounds.size.height;
    
    // 创建名为scrollView的滚动视图,设置可滚动区域为屏幕大小
    UIScrollView * scrollView = [[UIScrollView alloc] initWithFrame:CGRectMake(0, 0, width, height)];
    
    // 设置滚动视图的水平和垂直偏移量,可以移动的大小
    scrollView.contentSize = CGSizeMake(width * 2, height * 2);
    
    // 设置滚动视图的代理,在下面滚动视图的代理方法时使用,不使用代理方法可不加
    scrollView.delegate = self;
    
    // 界面的回弹的效果,弹簧效果,
    scrollView.bounces = NO;
    
    // 是否允许用户超出指定的范围进行缩放
    scrollView.bouncesZoom = YES;
    
    // 是否开启滚动视图的分页模式,以滚动区域大小滚动
    scrollView.pagingEnabled = NO;
    
    // 垂直方向遇到边框是否反弹
    scrollView.alwaysBounceVertical = NO;
    
    // 水平方向遇到边框是否反弹
    scrollView.alwaysBounceHorizontal = NO;
    
    // 是否显示水平方向的滚动条
    scrollView.showsHorizontalScrollIndicator = YES;
    
    // 是否显示垂直方向的滚动条
    scrollView.showsVerticalScrollIndicator = YES;
    
    // 指定滚动条在scrollerView中的位置
    scrollView.scrollIndicatorInsets = UIEdgeInsetsMake(0, 0, 0, 0);
    
    // 是否锁定同时进行水平和垂直滚动的操作,YES时只允许一个方向,为初始方向
    scrollView.directionalLockEnabled = NO;
    
    // 滚动视图的滚动条颜色
    scrollView.indicatorStyle = UIScrollViewIndicatorStyleDefault;
    
    // 滚动视图的缩放系数
    scrollView.maximumZoomScale = 2.0;
    scrollView.minimumZoomScale = 0.2;
    
    // 将这个滚动视图添加到主视图上
    [self.view addSubview:scrollView];
}

// 视图发生滚动时调用,带有contentOffset的属性
-(void)scrollViewDidScroll:(UIScrollView*)scrollView {
    NSLog(@"视图已经滚动了,位移是 %@",NSStringFromCGPoint(scrollView.contentOffset));
}

// 视图滚动到了边界时调用,撞到边界时
-(void)scrollViewWillBeginDragging:(UIScrollView*)scrollView {
    NSLog(@"视图已经滚动到了边界 %@",NSStringFromCGPoint(scrollView.contentOffset));
}

// 用户抬起手指时调用,可配合下面的减速方法使用
-(void)scrollViewDidEndDragging:(UIScrollView*)scrollView willDecelerate:(BOOL)decelerate {
    NSLog(@"用户手指抬起 %@",NSStringFromCGPoint(scrollView.contentOffset));
}

// 滚动视图减速时调用
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView {
    NSLog(@"滚动视图要减速了,注意");
}

// 滚动视图减速动画完成时调用
-(void)scrollViewDidEndDecelerating:(UIScrollView*)scrollView {
    NSLog(@"滚动视图减速动画已经完成");
}

// 点击状态栏时是否返回到页面头部
-(BOOL)scrollViewShouldScrollToTop:(UIScrollView*)scrollView {
    return YES;
}

// 滚动视图返回到页面头部时调用
-(void)scrollViewDidScrollToTop:(UIScrollView*)scrollView {
    NSLog(@"点击了状态栏,滚动视图返回到了页面头部");
}

@end

 

转载于:https://my.oschina.net/huqiji/blog/2251563

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值