SWIFT用ScrollView加图片制作Banner

简介: 网上参考OBJC写的用ScrollView图片轮播效果,照着画了个,先上效果图: 附上代码: 1 @IBOutlet weak var pc: UIPageControl! 2 @IBOutlet weak var sv:UIScrollView! 3 4...

网上参考OBJC写的用ScrollView图片轮播效果,照着画了个,先上效果图:

附上代码:

 1 @IBOutlet weak var pc: UIPageControl!
 2     @IBOutlet weak var sv:UIScrollView!
 3     
 4     var timer:NSTimer!
 5     
 6     override func viewDidLoad() {
 7         super.viewDidLoad()
 8         
 9         for i in 1...6{ //loading the images
10             let image = UIImage(named: "pic\(i).jpg")!
11             let x = CGFloat(i - 1) * self.view.frame.width //这一步获取ScrollView的宽度时我用IPHONE6实体机测试是320,右边会出现第二张图片的一部分,最后还是用ROOT VIEW的宽度
12             var imageView = UIImageView(frame: CGRectMake(x, 0, self.view.frame.width, sv.bounds.height))
13             imageView.image = image
14             sv.pagingEnabled = true
15             sv.showsHorizontalScrollIndicator = false
16             sv.scrollEnabled = true
17             sv.addSubview(imageView)
18             sv.delegate = self
19         }
20         
21         sv.contentSize = CGSizeMake((self.view.frame.width * 6), sv.frame.height)
22         pc.numberOfPages = 6
23         pc.currentPageIndicatorTintColor = UIColor.redColor()
24         pc.pageIndicatorTintColor = UIColor.whiteColor()
25         addTimer()
26         
27     }
28     
29     func scrollViewDidScroll(scrollView: UIScrollView) {
30         let width = self.view.frame.width
31         let offsetX = scrollView.contentOffset.x
32         let index = (offsetX + width / 2) / width
33         pc.currentPage = Int(index)
34     }
35     
36     func scrollViewWillBeginDragging(scrollView: UIScrollView) {
37         removeTimer()
38     }
39     
40     func scrollViewDidEndDragging(scrollView: UIScrollView, willDecelerate decelerate: Bool) {
41         addTimer()
42     }
43     
44     func addTimer() {
45         timer = NSTimer.scheduledTimerWithTimeInterval(5, target: self, selector: "nextImage", userInfo: nil, repeats: true)
46     }
47     
48     func removeTimer() {
49         timer.invalidate()
50     }
51 
52     
53     func nextImage() {
54         var pageIndex = pc.currentPage
55         if pageIndex == 5 {
56             pageIndex = 0
57         } else {
58             pageIndex++
59         }
60         
61         var offsetX = CGFloat(pageIndex) * self.view.frame.width
62         sv.setContentOffset(CGPointMake(offsetX, 0), animated: true)
63     }

 

目录
相关文章
|
Swift
Swift -banner滚动图自定义
Swift -banner滚动图自定义
236 0
Swift -banner滚动图自定义
|
Swift
swift之图片浏览器
swift之图片浏览器
390 0
swift之图片浏览器
|
存储 Swift
Swift - Cell自适应+代码约束(SnapKit)横竖屏支持平铺+根据URL获取图片size
Swift - Cell自适应+代码约束(SnapKit)横竖屏支持平铺+根据URL获取图片size
220 0
|
Swift
Swift - 根据图片URL获取图片的大小
Swift - 根据图片URL获取图片的大小
557 0
|
缓存 Swift iOS开发
iOS开发swift版异步加载网络图片(带缓存和缺省图片)
iOS开发swift版异步加载网络图片(带缓存和缺省图片)
484 0
|
Swift 计算机视觉
图片轮播器(swift)
如何实现一个无限循环,无缝衔接的图片轮播器 自己实现一次以后就不用使用轮播器的框架了 能用代码解决的问题就不在这里瞎BB了  O(∩_∩)O 首先先在Carousel文件件夹创建以下几个文件 CarouselFlowLayout.
1030 0
|
iOS开发 Swift
Swift学习笔记(4)使用UIImagePickerController实现从设备图片库和照相机获取图片
Swift学习笔记(4)使用UIImagePickerController实现从设备图片库和照相机获取图片 设备图片库和照相机是图像的两个重要来源,使用UIKit中提供的图像选择器UIImagePickerController可以轻易地实现从设备图片库和照相机获取图片。 目录 Swift学习笔记4使用UIImagePickerController实现从设备
4288 0
|
Swift
swift UIImage加载远程图片和圆角矩形
  原文地址:http://www.cnblogs.com/sxlfybb/p/3791973.html UIImage这个对象是swift中的图像类,可以使用UIImageView加载显示到View上。
1365 0
|
存储 Swift
Swift Core Data 图片存储与读取Demo
实体的模型定义: 实体的class定义: @objc(ImageEntity) class ImageEntity: NSManagedObject { @NSManaged...
1046 0