Swift - 使用UIScrollView实现页面滚动切换
UIScrollView提供了以页面为单位滚动显示各个子页面内容的功能,每次手指滑动后会滚动一屏的内容。
要实现该功能,需要如下操作:
1,将UIScrollView的pagingEnabled属性设置成true
2,必须通过contentSize属性设置各个页面相加的宽度。比如iphone手机一屏宽度是320,如果有3个页面,则contentSize就需要设置为320*3=960
3,最好将showsHorizontalScrollIndicator和showsVerticalScrollIndicator设置成false隐藏横向和纵向滚动条。
4,如果scrollsToTop不需要也设置成false。
--- 主页面 ---
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
class ViewController : UIViewController { let numOfPages = 3 let pageWidth = 320 let pageHeight = 360 override func viewDidLoad(){ super .viewDidLoad() //scrollView的初始化 var scrollView = UIScrollView () scrollView.frame = self .view.bounds //为了让内容横向滚动,设置横向内容宽度为3个页面的宽度总和 scrollView.contenSize= CGSizeMake ( CGFloat (pageWidth*numOfPages), CGFloat (pageHeight)) scrollView.pagingEnabled = true scrollView.showsHorizontalScrollIndicator = false scrollView.showsVerticalScrollIndicator = false scrollView.scrollsToTop = false //添加子页面 for i in 0..numOfPages{ var myViewController = MyViewController (number:(i+1)) myViewController.view.frame = CGRectMake ( CGFloat (pageWidth*i), CGFloat (0), CGFloat (pageWidth), CGFloat (pageHeight)) scrollView.addSubview(myViewController.view) } self .view.addSubview(scrollView) } } |
--- 子页面 ---
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
|
class MyViewController : UIViewController { var number: Int ! let colorMap=[ 1: UIColor .blackColor(), 2: UIColor .orangeColor(), 3: UIColor .blueColor() ] init (number initNumber: Int ){ self .number = initNumer super . init (nibNmae: nil , bundle: nil ) } override func viewDidLoad(){ var numberLabel = UILabel (frame: CGRectMake (0,0,100,100)) numberLabel.center = self .view.center numberLabel.text = "第\(number)页" numberLabel.textColor = UIColor .whiteColor() self .view.addSubview(numberLabel) self .view.backgroundColor = colorMap[number] } } |
分类:
Swift语言
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
2014-09-25 Android 出现警告Exported service does not require permission
2013-09-25 Android中的JSON详细总结