`
jaybril
  • 浏览: 50545 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

UIScrollView 滚动视图

 
阅读更多

UIScrollView 类负责所有基于 UIKit 的滚动操作。

一、创建

CGRect bounds = [ [ UIScreen mainScreen ] applicationFrame ] ;  
UIScrollView* scrollView = [ [UIScrollView alloc ] initWithFrame:bounds ];  

当你创建完滚动视图后,你可以将另一个视图的内容粘合到滚动视图的空白页上。这回创建一个滚动的内容窗口:

[ scrollView addSubview:myView]; 

  

你必须给出内容的实际大小,这样滚动视图才知道滚动的范围:

scrollView.contentSize = myView.frame.size;  

 

要开启缩放功能需要调整视图的两个属性,分别是maxinumZoomScale 和 mininumZoomScale 。这样就可以允许用户使用捏合手势调整内容大小:

scrollView.maxinumZoomScale = 2.0;//允许放大2倍  
scrollView.mininumZoomScale = 0.5;//允许放大到0.5倍  


要打开缩放功能,你还需要增加一个UIScrollViewDelegate 代理,通过一个名为 viewForZoomingScrollView

的方法做出响应。这个方法会返回进行缩放时所使用的 UIView 对象:

scrollView.delegate = self;  
- (UIView*)viewForZoomingInScrollView:(UIScrollView*)scrollView{  
  retutn myView;  
}  


Tips:对于大规模数据,你可能会在最初使用一个低于实际大小(1.0)的缩放比例,让用户可以平滑地进行放大。

 

二、属性

除了上面用到的缩放属性外,滚动视图还有会让你多其他属性,可以对现实内容的行为进行微调。你可以对 UIScrollView 类进行多方位定制。下面这些属性是最常用的。

1.indicatorStyle

指定你希望使用的滚动条指示器的类型。默认行为是在白边界上绘制黑色的滚动条,这在大多数背景下都适用。可用风格如下:

UIScrollViewIndicatorStyleDefault  
UIScrollViewIndicatorStyleBlack  
UIScrollViewIndicatorStyleWhite  

2.contentOffset

一个CGPoint结构,其中包含有要显示内容相对于窗口左上角的偏移量。默认是从0×0开始的,但是你也可以将显示内容放在其他位置。

3.directionalLockEnabled

默认行为是允许用户同时进行横向和纵向的滚动。将这个属性设置为YES会导致将用户的滚动行为锁定成只允许横向或纵向进行,具体方向由初始姿态决定。

4.bounces

当用户抵达滚动区域边缘时,这个功能允许用户稍微拖动到边界外一点。当用户松开手指后,这个区域会像个橡皮筋一样,弹回到原位,给用户一个可见的提示,表示他已经到达了文档开始或结束位置。如果不想让用户的滚动范围能够超出可见内容,可以将这个属性设置为NO。

5.bouncesZoom

类似于bounces 选项,这个方法可以令用户的缩放操作超出最大或最小缩放级别,然后弹回到范围以内。如果你不想让用户能够超出你指定的范围进行缩放,将这个属性设置为NO。

6.pagingEnabled

当开启了分页功能时,滚动视图被分割成多个独立区段,二用户的滚动体验则变成了页面翻转,你可以用这个属性来进行页面翻转。

三、委托方法

可以赋予滚动视图一个委托,下列委托方法会在特定时刻收到通知。

-(void)scrollViewDidScroll:(UIScrollView*)scrollView;//会在视图滚动时收到通知。包括一个指向被滚动视图的指针,从中可以读取contentOffset属性以确定其滚动到的位置。  

 

-(void)scrollViewWillBeginDragging:(UISCrollView*)scrollView;//当用户首次在某个方向上进行拖动时得到通知。这个方法会得到被作为参数传递的滚动视图指针,也同样可以从中读取 contentOffset 属性。  

 

-(void)scrollViewDidEndDragging:(UIScrollView*)scrollView willDecelerate:(BOOL)decelerate;  
//当用户抬起拖动到手指时得到通知。还会得到一个布尔值,知名报告滚动视图最后位置之前,是否需要减速。  

 

-(void)scrollViewWillBeginDecelerate:(UIScrollView*)scrollView;//当用户抬起手指而视图需要继续移动时,会收到通知。这个方法可以用来读取 contentOffset属性,从而判断出当用户抬起手指前最后一次滚动到的位置,虽然这个位置并不会使滚动条的最终停止位置。  

 

-(void)scrollViewDidEndDecelerating:(UIScrollView*)scrollView;//当上面提到的减速完毕、滚动视图停止时得到通知。收到这个通知的时刻,滚动视图的contentOffset属性会反映出滚动条最终停止的位置。  

 

-(void)scrollViewDidEndZooming:(UIScrollview*)scrollView withView:(UIView*)view atScale:(float)scale;//当用户对内容进行缩放时,会收到通知。缩放比例表示为一个浮点值,会作为参数传递进来。  

 

-(BOOL)scrollViewShouldScrollToTop:(UIScrollView*)scrollView;  
-(void)scrollViewDidScrollToTop:(UIScrollView*)scrollView;  
//当用户点出iPhone状态条时,滚动视图委托可以决定视图是否滚动回到开头。  




转:http://www.cnblogs.com/pengyingh/articles/2429790.html
分享到:
评论

相关推荐

    UIScrollView滚动视图

    首先,UIScrollView提供了滚动功能,通过设置其contentSize属性,我们可以定义滚动视图的总尺寸,使其大于实际显示区域,从而实现滚动。contentSize的宽高分别对应于滚动视图在水平和垂直方向上的内容大小。而...

    UIScrollView滚动视图的无限循环切换,自动顺序,逆序图片播放

    在iOS开发中,`UIScrollView` 是一个非常重要的控件,它允许用户在超过视图边界的内容上进行滚动操作。在本教程中,我们将探讨如何利用`UIScrollView`实现一个无限循环切换图片的功能,同时支持自动顺序和逆序播放。...

    iOS应用开发中UIScrollView滚动视图的基本用法总结

    在项目开发时遇到一个问题,我在UIViewController上面直接创建了一个UIScrollerView,把UIScrollerView作为一个子视图添加到了UIViewController, 又再UIScrollerView中添加了一个UISlider的组件,在手势滑动的过程...

    iOS UIScrollView滚动视图/无限循环滚动/自动滚动的实例代码

    `contentSize`定义了滚动视图的内容大小,它应该大于或等于滚动视图本身的尺寸,以允许滚动。`pagingEnabled`属性设置为YES时,会使得滚动视图每次移动一整个屏幕宽度的距离,适合于创建类似页面翻动的效果。`...

    UIScrollView 循环滚动 手势 自动 滚动

    在iOS开发中,`UIScrollView` 是一个至关重要的控件,用于展示可滚动的内容,比如滚动视图、页面控制器等。本教程将详细讲解如何实现`UIScrollView`的循环滚动功能,并结合手势识别和自动滚动,以提升用户体验。我们...

    swift-使用Swfit扩展为UIView添加随UIScrollView滚动产生视差效果

    在Swift中,我们可以利用扩展(Extension)来为现有的UIView类添加新的功能,例如实现随UIScrollView滚动的视差效果。这个"swift-使用Swift扩展为UIView添加随UIScrollView滚动产生视差效果"的主题主要涵盖了以下...

    UIScrollView自动滚动以及手动滚动的实现

    UIScrollView内部包含一个可变大小的内容视图(content view),这个内容视图的大小可以远大于UIScrollView本身,从而允许用户滚动查看超出屏幕的部分。为了实现自动滚动,我们需要设置一个定时器(NSTimer)来定期...

    UIScrollview循环滚动

    在iOS开发中,UIScrollView是苹果提供的一种视图控件,用于展示可滚动的内容,比如图片、文字或者多个子视图。"UIScrollview循环滚动"这个知识点涉及到如何让UIScrollView的内容无限滚动,就像一个轮播图一样。在这...

    ios UIScrollView响应touch事件

    这种设计保证了用户可以同时与`UIScrollView`的子视图交互,比如点击按钮或拖动其他可交互元素,而不会打断整体的滚动操作。 开发者还可以自定义`UIScrollView`的触摸行为,例如通过重写`touchesBegan:withEvent:`...

    UIScrollView实现图片无限滚动Demo

    总之,这个Demo展示了如何利用`UIScrollView` 和`UIPageControl` 实现图片无限循环滚动的功能,对于iOS开发者来说,理解和掌握这一技术对于创建各种类型的滚动视图是非常有帮助的。通过深入研究这个示例代码,开发者...

    ios期末课设-水果商城

    2) 在商城页面,用UIScrollView 滚动视图,实现轮播图 3) 用自定义的cell进行组装UITableView 表格视图, 展示各种各样的水果图片和价格 4) 进入水果详情页,采用AVPlayerViewController进行播放科普视频,并采用...

    (0024)-iOS/iPhone/iPAD/iPod源代码-滚动视图(ScrollView)-Vertical Swipe Views

    在iOS开发中,滚动视图(UIScrollView)是一个至关重要的组件,它允许用户通过手势滚动查看超过屏幕尺寸的内容。本文将深入探讨"(0024)-iOS/iPhone/iPad/iPod源代码-滚动视图(ScrollView)-Vertical Swipe ...

    ios-滚动视图扩展.zip

    在iOS开发中,滚动视图(UIScrollView)是一个非常重要的组件,它允许用户通过手势滚动查看超过屏幕大小的内容。本项目“ios-滚动视图扩展.zip”提供了一个GitHub仓库的完整下载,旨在帮助开发者深入理解和扩展滚动...

    ios-滚动视图.zip

    在iOS开发中,滚动视图(UIScrollView)是一个非常重要的组件,它允许用户通过手势滚动查看超过屏幕尺寸的内容。本教程将深入探讨滚动视图的概念、使用场景以及如何在实际项目中进行有效应用。 首先,我们要了解`...

    ios-3行代码搞定无限滚动视图.zip

    在iOS开发中,滚动视图(UIScrollView)是十分常见的组件,它允许用户通过手指滑动来查看超过屏幕大小的内容。无限滚动视图则更进一步,它在用户滚动到底部或顶部时无缝地加载新的内容,营造出一种无边界的浏览体验...

    ios-封装自动滚动视图.zip

    在iOS开发中,滚动视图(UIScrollView)是一个非常重要的组件,它允许用户查看超过屏幕大小的内容。本项目“ios-封装自动滚动视图.zip”是一个初学者实践的成果,旨在帮助开发者更好地理解和应用滚动视图的自定义...

    iOS 无限滚动视图

    在iOS开发中,"无限滚动视图"是一种常见的用户界面元素,主要用于展示一系列图片或内容,通常用在首页 banner 或者商品展示等场景。标题提到的 "DCCycleScrollView" 是一个开源项目,作者是 Daichuan,它实现了无限...

Global site tag (gtag.js) - Google Analytics