网上参考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 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
2012-06-27 SAP应用界面开发:3)SELECTION-SCREEN 对象(1)