ScrollView

注:本小节详细介绍scrollView的用法

UIScrollView是一个能够滚动的视图控件,可以用来展示大量的内容,并且可以通过滚动查看所有的内容
UIScrollView的用法,将需要展示的内容添加到UIScrollView中
设置UIScrollView的contentView属性,告诉UIScrollView所有内容的尺寸

let scroll = UIScrollView();       
        scroll.backgroundColor = UIColor.grayColor()
        scroll.frame = CGRectMake(10,30,100,150)  //设置scrollview的大小
        scroll.contentSize = CGSizeMake(400,150)   //内容大小
        scroll.pagingEnabled = true                 //是否支持分页
        //scroll.contentOffset = CGPointMake(0,-10)
        scroll.contentInset = UIEdgeInsets(top: 10,left: 10,bottom: 10,right: 10) //内边距

        let imageView =  UIImageView(image: UIImage(named: "dog1"))
        imageView.frame = CGRectMake(10,10,80,130)
        scroll.addSubview(imageView)

        let imageView1 =  UIImageView(image: UIImage(named: "dog2"))
        imageView1.frame = CGRectMake(100+10,130)
        scroll.addSubview(imageView1)

        let imageView2 =  UIImageView(image: UIImage(named: "dog3"))
        imageView2.frame = CGRectMake(100*2+10,130)
        scroll.addSubview(imageView2)

        let imageView3 =  UIImageView(image: UIImage(named: "dog4"))
        imageView3.frame = CGRectMake(100*3+10,130)
        scroll.addSubview(imageView3)

        self.view.addSubview(scroll)

这里我创建了一个scrollview 并设置的一些属性(都有注释) , 然后 添加了四个小狗的图片 。 效果就是横向拖动可轮换显示四张图


滑动可轮换

下面介绍一个可缩放的示例

let scrollview = UIScrollView();
        scrollview.frame = CGRectMake(10,200,viewWidth-20,300)
        scrollview.backgroundColor = UIColor.purpleColor()
        scrollview.contentInset = UIEdgeInsets(top: 10,left:0,bottom: 0,right: 0)

        imageView4 =  UIImageView(image: UIImage(named: "pic1"))
        imageView4!.frame = CGRectMake(0,280)
        scrollview.addSubview(imageView4!)
        scrollview.contentSize=CGSizeMake( viewWidth-20,300);
        scrollview.maximumZoomScale=2.0; //设置最大伸缩比例
        scrollview.minimumZoomScale=0.5; //设置最小伸缩比例

同样是设置一些基本属性 , 然后设置伸缩比例

class ViewController: UIViewController,uiscrollviewdelegate

让我们的controller实现uiscrollviewdelegate这个协议

scrollview.delegate = self

把scrollview的代理 设成当前对象

//告诉scrollview要缩放的是哪个子控件
    func viewForZoomingInScrollView(scrollView: UIScrollView) -> UIView? {
        return imageView4
    }

然后实现这个方法,告诉scrollview要缩放的是哪个子控件
运行看看 确实可以缩放了。。

下面看看uiscrollviewdelegate 中的一些其他的事件

func scrollViewDidScroll(scrollView: UIScrollView) {
        print("只要滚动了就会触发哦。")
    }

    func scrollViewWillBeginDragging(scrollView: UIScrollView) {
        print("开始拖拽视图")
    }

    func scrollViewDidEndDragging(scrollView: UIScrollView,willDecelerate decelerate: Bool) {
        print("结束滚动")
    }

    func scrollViewWillBeginDecelerating(scrollView: UIScrollView) {
        print("将开始降速时")
    }

    func scrollViewDidEndDecelerating(scrollView: UIScrollView) {
        print("减速停止了时执行,手触摸时执行执行")
    }

    func scrollViewDidEndScrollingAnimation(scrollView: UIScrollView) {
        print("滚动动画停止时执行,代码改变时触发,也就是setContentOffset改变时")
    }

    func scrollViewDidEndZooming(scrollView: UIScrollView,withView view: UIView?,atScale scale: CGFloat) {
        print("完成放大缩小时调用")
    }

这里面都清楚的记载了什么时候执行。。很清楚,大家可以试试

最后再附上这些实例的源码(本实例在xcode 7 beta上实现) :scrollview

都提交了发现还少点什么 , 原来少了这个图 。(本图来源于网络)

swift详解之十八------------ScrollView的更多相关文章

  1. ios – UIScrollView内容不允许用户交互

    我有一个启用了分页的UIScrollView,如下所示:在UIScrollView中,我添加了几个UIWebViews,并将其启用的交互设置为是这样的.它打破了UIScrollView上的分页和所有触摸.如果我将用户交互设置为NO,则页面有效,但我无法在UIWebView中突出显示文本.我试着像下面那样对UIScrollView进行子类化,但是会出现同样的情况.任何的想法?

  2. ios – UIScrollView中的UIControll未接收到触摸事件

    我在我的项目中使用SevenSwitch.我需要将它添加到UIScrollView中,但是当我将它添加到滚动视图中时,控件似乎无法接收触摸事件.我尝试了子类滚动视图并覆盖下面的代码:还补充说:但仍然无法接收触摸事件.如何阻止scrollview阻止UIControl接收触摸?

  3. ios – UIScrollView的平滑自定义分页

    我在UIScrollView中有两个(可能更多)视图,并希望使用分页.当我尝试使用UIScrollView的默认分页选项时出现问题,因为视图具有不同的宽度,无法正确分页.所以我已经实现了一个有效的自定义分页代码.但是,当滚动较慢时,它不会按预期运行.(它回到没有动画的原始位置.)以下是我目前通过uiscrollviewdelegate进行自定义分页的方法我想要的是:是)我有的:解决方法尝试下面的自

  4. ios – 如何将UIScrollView的背景图像设置为可伸缩图像?

    我想将UIScrollView的背景图像设置为可伸缩的图像.我试过了:但它并没有伸展.我能做什么?解决方法如果要利用UIImage的可调整大小的属性,则需要使用UIImageView.正如您所注意到的,如果将其设置为背景颜色则不起作用.只需创建一个UIImageView并将其放在UIScrollView后面,如果必须修复它,或者在UIScrollView中放入与contentSize相同的大小,如果你想要滚动它…

  5. ios – 取消选中“调整滚动视图插入”xcode 6后UIScrollView不滚动

    谢谢.解决方法我解决顶部标签和导航栏之间额外填充的方法是在“扩展边缘”部分中取消选中属性检查器中的“顶部条形图”.取消选中后,故事板上的项目可能会移动.不要重新安排它们.运行模拟器,它应该工作.注意:选中“调整滚动视图插入”,否则不滚动任何内容.我的属性:

  6. ios – 滚动指示器在UIScrollView禁用弹跳时被卡住

    难道我做错了什么?如果这是一个错误,那么有没有人知道解决方法或修复?解决方法您是否为滚动视图添加了点击手势,如果没有,请尝试添加它?

  7. ios – 使用双指平移和缩放分页UIScrollView

    *编辑:实际上,在这种情况下它不会滚动.只需轻轻一按,视图就不再顺畅滑动……

  8. ios – UITableView使用UIRefreshControl拖动距离

    我在UITableView上实现UIRefreshControl时遇到了一些麻烦.一切都工作得很好,除了我必须滚动80%的屏幕才能触发UIRefreshControl.有时我甚至无法触发它,因为屏幕底部有一个标签栏,当手指到达时会取消滚动动作.我查看了其他应用程序,即Apple的’Mail’,其中仅滚动屏幕的30%后触发UIRefreshControl.我错过了什么?

  9. xcode – 在Interface Builder中更新UIView类

    我正在XCode界面构建器中构建一个UI.在布置了所需的视图层次结构之后,我意识到靠近层次结构顶部的一个视图应该是UIScrollView而不是UIView.有没有办法轻松地将该视图的类型从UIView更改为UIScrollView,而无需使用自己的子视图层次结构重新布局所有子组件?

  10. ios – 如何为UITableView设置边框?

    我创建了一个由一个UITableView和一个UIScrollView组成的视图,现在我需要为UITableView绘制一个边框,以便它可以与UIScrollView隔离.解决方法查看UIView图层属性,该属性允许您为视图定义可见边框.试试以下内容:…

随机推荐

  1. Swift UITextField,UITextView,UISegmentedControl,UISwitch

    下面我们通过一个demo来简单的实现下这些控件的功能.首先,我们拖将这几个控件拖到storyboard,并关联上相应的属性和动作.如图:关联上属性和动作后,看看实现的代码:

  2. swift UISlider,UIStepper

    我们用两个label来显示slider和stepper的值.再用张图片来显示改变stepper值的效果.首先,这三个控件需要全局变量声明如下然后,我们对所有的控件做个简单的布局:最后,当slider的值改变时,我们用一个label来显示值的变化,同样,用另一个label来显示stepper值的变化,并改变图片的大小:实现效果如下:

  3. preferredFontForTextStyle字体设置之更改

    即:

  4. Swift没有异常处理,遇到功能性错误怎么办?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  5. 字典实战和UIKit初探

    ios中数组和字典的应用Applicationschedule类别子项类别名称优先级数据包contactsentertainment接触UIKit学习用Swift调用CocoaTouchimportUIKitletcolors=[]varbackView=UIView(frame:CGRectMake(0.0,0.0,320.0,CGFloat(colors.count*50)))backView

  6. swift语言IOS8开发战记21 Core Data2

    上一话中我们简单地介绍了一些coredata的基本知识,这一话我们通过编程来实现coredata的使用。还记得我们在coredata中定义的那个Model么,上面这段代码会加载这个Model。定义完方法之后,我们对coredata的准备都已经完成了。最后强调一点,coredata并不是数据库,它只是一个框架,协助我们进行数据库操作,它并不关心我们把数据存到哪里。

  7. swift语言IOS8开发战记22 Core Data3

    上一话我们定义了与coredata有关的变量和方法,做足了准备工作,这一话我们来试试能不能成功。首先打开上一话中生成的Info类,在其中引用头文件的地方添加一个@objc,不然后面会报错,我也不知道为什么。

  8. swift实战小程序1天气预报

    在有一定swift基础的情况下,让我们来做一些小程序练练手,今天来试试做一个简单地天气预报。然后在btnpressed方法中依旧增加loadWeather方法.在loadWeather方法中加上信息的显示语句:运行一下看看效果,如图:虽然显示出来了,但是我们的text是可编辑状态的,在storyboard中勾选Editable,再次运行:大功告成,而且现在每次单击按钮,就会重新请求天气情况,大家也来试试吧。

  9. 【iOS学习01】swift ? and !  的学习

    如果不初始化就会报错。

  10. swift语言IOS8开发战记23 Core Data4

    接着我们需要把我们的Rest类变成一个被coredata管理的类,点开Rest类,作如下修改:关键字@NSManaged的作用是与实体中对应的属性通信,BinaryData对应的类型是NSData,CoreData没有布尔属性,只能用0和1来区分。进行如下操作,输入类名:建立好之后因为我们之前写的代码有些地方并不适用于coredata,所以编译器会报错,现在来一一解决。

返回
顶部