UIScrollView(基础篇)

UIScorllView

移动设备的屏幕大小是极其有限的,因此直接展示在用户眼前的内容也相当有限
当展示的内容较多,超出一个屏幕时,用户可通过滚动手势来查看屏幕以外的内容
普通的UIView不具备滚动功能,不能显示过多的内容
UIScrollView是一个能够滚动的视图控件,可以用来展示大量的内容,并且可以通过滚动查看所有的内容
举例:手机上的“设置”、其他示例程序


UIScrollView的基本使用


UIScrollView的使用很简单,直接讲需要显示的UI内容添加到UIScrollView中即可。设置UIScrollView的contentSize属性,告诉UIScrollView所有内容的尺寸,也就是告诉它滚动范围。


UIScrollView无法滚动的原因:1:没有设置UIScrollView的contentSize属性。

          2:UIScrollView的scrollviewEnaael属性为NO。

  3:没有接受到点击事件 userInteractionEnabled属性为NO

  4:在XIB的情况下,没有取消autolayout功能呢。(若要UIScrollView滚动)必须取消此功能


UIScrollView的常见属性


(内容偏移量:内容左上角减去scoreView左上角差的值,用户只要稍微动一下,图片就会再次弹回原始的位置)

@property(nonatomicCGPoint contentOffset; 


这个属性用来设置UIScrollView能滚动到的范围

@property(nonatomic)CGSize contentSize; 


这个属性用来记录UIScrollView滚到的位置(能在四周添加额外的滚动区域)

@property(nonatomicUIEdgeInsets contentInset; 


代理

@property(nullable,nonatomic,weak)id<UIScrollViewDelegate> delegate; 


UIScrollView其他属性  


设置UIScrollView是否需要弹簧效果       

@property(nonatomicBOOL bounces;                        

   

当值是 YES 会自动滚动到 subview 的边界。默认是NO

@property(nonatomic,getter=isPagingEnabled)BOOL pagingEnabled__TVOS_PROHIBITED;


设置UIScrollView是否能滚动

@property(nonatomic,getter=isScrollEnabled)BOOL scrollEnabled;  


设置是否显示水平滚动条

@property(nonatomicBOOL showsHorizontalScrollIndicator; 


设置是否显示垂直滚动条

@property(nonatomic)BOOL showsVerticalScrollIndicator;  


touch的时还没有拖动的时候是YES 否则是NO

@property(nonatomic,readonly,getter=isTracking)BOOL tracking;


正在缩放的时候是YES 否则是NO

@property(nonatomic,readonly,getter=isZooming)BOOL zooming;


当滚动后,手指放开但是还在继续滚动中。这个时候是 YES,其它时候是 NO

@property(nonatomic,readonly,getter=isDecelerating)BOOL decelerating;


设置手指放开后的减速率

@property(nonatomicGFloat decelerationRateNS_AVAILABLE_IOS(3_0);


一个浮点数,表示能缩最小的倍数

@property(nonatomic)CGFloat minimumZoomScale;  


一个浮点数,表示能放最大的倍数   

@property(nonatomic)CGFloat maximumZoomScale;     



需要动画   第一个参数是你要滚动到的位置 第二个参数是是否要动画效果

       [self.scrollView setContentOffset:CGPointMake(0,self.scrollView.contentOffset.y)animated:YES];

       是否有弹簧效果

       self.scrollView.bounces =NO;

    

       不管有没有contentSize,都能拥有弹簧效果(一般适用于下拉刷新功能,上拉刷新)

       self.scrollView.alwaysBounceVertical= YES; (弹簧效果)

 

       self.scrollView.alwaysBounceHorizontal= YES;(水平效果可以滚来滚去)

    

       是否要显示滚动条

       self.scrollView.showsHorizontalScrollIndicator =NO;

       self.scrollView.showsVerticalScrollIndicator =NO;

    

       self.scrollView.indicatorStyle =UIScrollViewIndicatorStyleWhite;

    

       NSLog(@"%@",self.scrollView.subviews);

    

        [[self.scrollView.subviews firstObject]removeFromSuperview];

 

   /**

     UIControlStateNormal;

     UIControlStateHighlighted;

     UIControlStateDisabled;禁止状态//只能通过enabled=NO达到这个状态

设置userInteractionEnabled=NO,可以禁止一些事件,比如点击和拉拽(意思是禁止和用户交互)

     */


UISCrollView的代理

1.代理一般都是控制器对象

2.代理一般都是id类型 (注意代理是弱指针,如果是强指针会内存泄露)


遵守代理

@interface ViewController ()<UIScrollViewDelegate>


设置代理

scrollview.delegate = self;



/**

 只要视图在滚动就会一直掉用这个方法


 @param scrollView 滚动视图

 */

- (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

    NSLog(@"滚动");

}


/**

 即将开始拖拽的时候调用


 @param scrollView UIScrollView

 */

- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView

{

    

}


/**

用户即将停止拖拽UIScrollView会调用此方法


 @param scrollView 停止拖拽的UIScrollView

 @param velocity 速度

 @param targetContentOffset 内容偏移

 */

- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset

{

    NSLog(@"即将停止拖拽");

}


/**

 用户已经停止拖拽UIScrollView掉用这个方法


 @param scrollView 停止拖拽的UIScrollView

 @param decelerate 停止拖拽之后的减速速率

 */

- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate

{

    NSLog(@"停止拖拽,做减速运动");

}


/**

 UIScrollView即将做减速运动的时候调用


 @param scrollView 做减速的UIScrollView

 */

- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView

{

    NSLog(@"将要开始做减速运动");

}


/**

 结束减速运动时候调用


 @param scrollView UIScrolleView

 */

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView

{

    NSLog(@"减速运动结束");

}



/**

 结束滚动动画的时候调用


 @param scrollView UIScrollView

 */

- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView

{

    

}


/**

 设置缩放视图


 @param scrollView UIScrollView

 @return 缩放视图

 */

- (nullable UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView

{

    return nil;

}



/**

 视图开始缩放的时候调用


 @param scrollView UIScrpllView

 @param view 缩放的视图

 */

- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(nullable UIView *)view

{

    

}


/**

 结束缩放的时候调用


 @param scrollView UIScrollView

 @param view 缩放的视图

 @param scale 规模

 */

- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(nullable UIView *)view atScale:(CGFloat)scale

{

    

}




/**

 缩放的时候一直调用


 @param scrollView UIScrollView

 */

- (void)scrollViewDidZoom:(UIScrollView *)scrollView

{

    

}



/**

 滚动视图是否能滚动到顶部


 @param scrollView UIScrollView

 @return YES OR NO

 */

- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView

{

    return YES;

}


/**

 滚动到顶部的时候调用


 @param scrollView UIScrolliew

 */

- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView

{

    

}



UIScrollViewdelegate的通信

UIScrollView的内容缩放

当我们用UIScrollView浏览一些内容的时候,有时候需要对内容进行缩放。

UIScrollew不仅能显示大量的内容,还能对其内容进行缩放处理。只要将需要缩放的内容添加到UIScrollew上即可。



缩放实现步骤


跟缩放相关的其他代理方法

准备开始缩放的时候调用 

- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view

 

正在缩放的时候调用

- (void)scrollViewDidZoom:(UIScrollView *)scrollView

 

   核心代码:设置内容大小

     contentSize.height == 0 设置为0仅仅代表竖直方向上不能滚动

    self.scrollView.contentSize = CGSizeMake(count * w, 0);





 UIScrollerView的分页功能


 每一页的尺寸都是跟scrollViewframe.size一样的

 self.scrollView.pagingEnabled = YES; 



- (void)scrollViewDidScroll:(UIScrollView *)scrollView

{

     --四舍五入为整数的方法--  (int)(小数 + 0.5)

     0.3  -> (int)(0.3 + 0.5) == 0

     0.4 -> (int)(0.4 + 0.5) == 0

     1.5 -> (int)(1.5 + 0.5) == 2

     0.7 -> (int)(0.7 + 0.5) == 1

     小数加上0.5再转换成整数,这样页码显示的就是正确的页数(仔细想)

    int page = (int)(scrollView.contentOffset.x / scrollView.frame.size.width + 0.5);

    self.pageControl.currentPage = page;

}

 

- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView

{

    int page = scrollView.contentOffset.x / scrollView.frame.size.width;

    self.pageControl.currentPage = page;

}

 

分页

只要将UIScrollViewpageEnabled属性设置为YESUIScrollView会被分割成多个独立页面,里面的内容就能进行分页展示

一般会配合UIPageControl增强分页效果,UIPageControl常用属性如下 

 

一共有多少页

@property(nonatomic) NSInteger numberOfPages;

当前显示第几页

@property(nonatomic) NSIntegercurrentPage; 

只有一页时,是否需要隐藏页码指示器

@property(nonatomic) BOOL hidesForSinglePage; 

其他页码指示器的颜色

@property(nonatomic,retain) UIColor *pageIndicatorTintColor;

当前页码指示器的颜色

@property(nonatomic,retain) UIColor *currentPageIndicatorTintColor;

 
























评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值