Swift UI – 使用UIScrollView实现页面滚动切换

注:代码已升级至Swift4

UIScrollView提供了以页面为单位滚动显示各个子页面内容的功能,每次手指滑动后会滚动一屏的内容。

实现该功能,需要如下操作:

  1. UIScrollViewisPagingEnabled属性设置成true
  2. 必须通过contentSize属性设置各个页面相加的宽度。比如iPhone手机一屏宽度是320,如果有3个页面,则contentSize就需要设置为320*3=960
  3. 最好将showsHorizontalScrollIndicatorshowsVerticalScrollIndicator设置成false隐藏横向和纵向滚动条。
  4. 如果scrollsToTop不需要也设置成false。

主页面

import UIKit

class ViewController: UIViewController {
    let numOfPages = 3
    let pageWidth = 320
    let pageHeight = 360

    override func viewDidLoad() {
        super.viewDidLoad()

        //scrollView的初始化
        let scrollView = UIScrollView()
        scrollView.frame = self.view.bounds
        //为了让内容横向滚动,设置横向内容宽度为3个页面的宽度总和
        scrollView.contentSize = CGSize(width: pageWidth * numOfPages,
                                        height: pageHeight)
        scrollView.isPagingEnabled = true
        scrollView.showsHorizontalScrollIndicator = false
        scrollView.showsVerticalScrollIndicator = false
        scrollView.scrollsToTop = false

        //添加子页面
        for i in 0..<numOfPages {
            let myViewController = MyViewController(number:(i+1))
            myViewController.view.frame = CGRect(x:pageWidth*i, y:0,
                                                width:pageWidth, height:pageHeight)
            scrollView.addSubview(myViewController.view)
        }
        self.view.addSubview(scrollView)
    }
}

子页面

import UIKit

class MyViewController: UIViewController{
    var number:Int!

    let colorMap = [
        1:UIColor.black,
        2:UIColor.orange,
        3:UIColor.blue
    ]

    init(number initNumber:Int) {
        self.number = initNumber
        super.init(nibName:nil, bundle:nil)
    }

    required init?(coder aDecoder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

    override func viewDidLoad() {
        let numberLabel = UILabel(frame:CGRect(x:130, y:50, width:50, height:30))
        numberLabel.text = "第\(number!)页"
        numberLabel.textColor = UIColor.white
        self.view.addSubview(numberLabel)
        self.view.backgroundColor = colorMap[number]
    }
}
上一篇 Swift UI - 滚动视图(UIScrollView)
下一篇 Swift UI - 日期选择控件(UIDatePicker)
目录
文章列表
1 Docker容器启动报错:Error response from daemon OCI runtime create failed container_linux.go
Docker容器启动报错:Error response from daemon OCI runtime create failed container_linux.go
2
Swift UI - 按钮(UIButton)
Swift UI - 按钮(UIButton)
3
PHP在线IP地址查询
PHP在线IP地址查询
4
携程Apollo服务端部署与操作
携程Apollo服务端部署与操作
5
MySQL 排序
MySQL 排序
最新评论
一位WordPress评论者
一位WordPress评论者
2月12日
您好,这是一条评论。若需要审核、编辑或删除评论,请访问仪表盘的评论界面。评论者头像来自 Gravatar。