美文网首页swift UI
Swift - 创建滚动视图的图片轮播器

Swift - 创建滚动视图的图片轮播器

作者: Bobby0322 | 来源:发表于2016-05-27 14:57 被阅读210次

    用Swift创建图片轮播器和用OC创建的方式是一样的,都主要用到UIScrollView和UIImageview这两个控件,有几张图片,就将滚动视图的内容区域大小设置为每一张图片的大小乘以张数即可。然后允许实现分页功能pagingEnabled,最后给对应区域的滚动视图设置相应的图片即可。

    声明必要的属性

    private var image :UIImage?
    private var timer :NSTimer?
    

    创建滚动视图并设置相关属性

    // 创建滚动视图并设置相关属性
        lazy var scollView :UIScrollView? = {
            let scollView = UIScrollView(frame: CGRectMake(10, 50, 300, 130))
            // 设置UIScrollView的contentSize(内容的实际大小)
            let maxW:CGFloat = scollView.frame.size.width * 5
            scollView.contentSize = CGSizeMake(maxW,0)
            // 实现UIScrollView的分页效果
            scollView.pagingEnabled = true
            scollView.delegate = self
            // 隐藏水平滚动指示器
            scollView.showsHorizontalScrollIndicator = false
        
            return scollView
        }()
    

    创建分页控制并设置相关属性

    lazy var pageControl :UIPageControl? = {
            // 创建分页控制并设置相关属性
            let pageControl = UIPageControl(frame: CGRectMake(100,140,120,37))
            
            // 指定UIPageControl的总页数
            pageControl.numberOfPages = 5
            // 指定默认是第0页
            pageControl.currentPage = 0
            
            pageControl.currentPageIndicatorTintColor = UIColor.redColor()
            pageControl.pageIndicatorTintColor = UIColor.blueColor()
            
            return pageControl
        }()
    

    创建图像视图并设置图片

            // 创建图像视图并设置图片
            let imgW:CGFloat  = 300
            let imgH:CGFloat = 130
            let imgY:CGFloat = 0
            
            // 循环创建5个UIImageView到UIScrollView中
            for i in 0..<5 {
                // 设置UIImageView中的图片
                self.image = UIImage(named: "img_0\(i+1).png")
                // 计算每个UIImageView在UIScrollView中的x值
                let imgX:CGFloat = CGFloat(i) * imgW
                // 设置imgView的frame
                let imageView:UIImageView? = UIImageView(frame: CGRectMake(imgX,imgY,imgW,imgH))
                
                imageView?.image = self.image
                imageView?.contentMode = .ScaleAspectFit
                imageView?.clipsToBounds = true
                
                self.scollView?.addSubview(imageView!)
            }
    

    创建定时器实现图片自动轮播

            // 创建定时器实现图片自动轮播
            timer = NSTimer.scheduledTimerWithTimeInterval(2.0, target: self, selector: "scrollImage:", userInfo: nil, repeats: true)
            
            // 修改self.timer的优先级与控件一样
            // 获取当前的消息循环对象
            let runloop:NSRunLoop  = NSRunLoop.currentRunLoop()
            // 改变self.timer对象的优先级
            runloop.addTimer(self.timer!, forMode: NSRunLoopCommonModes)
    

    实现定时器的方法

       // 实现定时器的方法
        func scrollImage(sender:AnyObject) {
            
            // 获取当前的UIPageControl的页码
            var page:Int = self.pageControl!.currentPage
            
            // 判断页码是否到了最后一页,如果到了最后一页,那么设置页码为0(回到第一页),如果没有到达最后一页,则让页码+1
            if page == self.pageControl!.numberOfPages - 1 {
                page = 0
            } else {
                page++
            }
            
            // 用每页的宽度 * (页码 + 1) 计算出了下一页的contentOffset
            let offsetX:CGFloat = (CGFloat)(page) * self.scollView!.frame.size.width
            
            // 设置UIScrollView的contentOffset等于新的偏移的值
            self.scollView!.contentOffset = CGPointMake(offsetX,0)
        }
    

    UIScrollViewDelegate

    // MARK: - UIScrollViewDelegate
    extension ViewController :UIScrollViewDelegate {
        // 实现UIScrollView的滚动方法
        func scrollViewDidScroll(scrollView: UIScrollView) {
            
            // 要在这里根据当前的滚动来计算当前是第几页
            
            // 获取scrollView的x方向的偏移值
            var offsexX:CGFloat = scrollView.contentOffset.x
            
            // 用已经偏移了的值,加上半页的宽度
            offsexX = offsexX + (scollView!.frame.size.width * 0.5)
            
            // 用x方向的偏移的值除以一张图片的宽度(每一页的宽度),取商就是当前滚到了第几页(索引)
            let pagenumber:CGFloat = offsexX / self.scollView!.frame.size.width
            
            // 将页码设置给UIPageControl
            self.pageControl!.currentPage = (Int)(pagenumber)
            
        }
        
        // 即将开始拖拽的方法
        func scrollViewWillBeginDragging(scrollView: UIScrollView) {
            // 调用invalidate一旦停止计时器,那么这个计时器就不可再重用了,下次必须重新创建一个新的计时器对象.
            self.timer?.invalidate()
            // 因为当调用完毕invalidate方法以后,这个计时器对象就已经废了,无法重用了,所以可以直接将self.timer设置为nil
            self.timer = nil
        }
        
        // 拖拽完毕的方法
        func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool) {
            // 重新启动计时器
            timer = NSTimer.scheduledTimerWithTimeInterval(2.0, target: self, selector: "scrollImage:", userInfo: nil, repeats: true)
            
            // 再次修改一下新创建的timer的优先级
            let runloop:NSRunLoop  = NSRunLoop.currentRunLoop()
            runloop.addTimer(self.timer!, forMode: NSRunLoopCommonModes)
        }
    }
    

    Banner

    banner01.jpg banner02.jpg banner03.jpg banner04.jpg

    相关文章

      网友评论

        本文标题:Swift - 创建滚动视图的图片轮播器

        本文链接:https://www.haomeiwen.com/subject/prqfdttx.html