Ios 在分页UIScrollView中缩放图像

Ios 在分页UIScrollView中缩放图像,ios,swift,uiscrollview,zooming,Ios,Swift,Uiscrollview,Zooming,我正在创建一个分页UIScrollView如下 这是允许使用UIScrollView对图像进行分页的Swift代码。然而,它有一个局限性。我无法缩放图像 class PagedScrollViewController: UIViewController, UIScrollViewDelegate { @IBOutlet var scrollView: UIScrollView! @IBOutlet var pageControl: UIPageControl! var pageImages:

我正在创建一个分页
UIScrollView
如下

这是允许使用
UIScrollView
对图像进行分页的Swift代码。然而,它有一个局限性。我无法缩放图像

class PagedScrollViewController: UIViewController, UIScrollViewDelegate {

@IBOutlet var scrollView: UIScrollView!
@IBOutlet var pageControl: UIPageControl!

var pageImages: [UIImage] = []
var pageViews: [UIImageView?] = []

override func viewDidLoad() {
    super.viewDidLoad()

    // 1
    pageImages = [UIImage(named:"photo1.png")!,
    UIImage(named:"photo2.png")!,
    UIImage(named:"photo3.png")!,
    UIImage(named:"photo4.png")!,
    UIImage(named:"photo5.png")!]

   let pageCount = pageImages.count

    // 2
    pageControl.currentPage = 0
    pageControl.numberOfPages = pageCount

    // 3
    for _ in 0..<pageCount {
        pageViews.append(nil)
    }

    // 4
    let pagesScrollViewSize = scrollView.frame.size
    scrollView.contentSize = CGSizeMake(pagesScrollViewSize.width * CGFloat(pageImages.count), pagesScrollViewSize.height)

    // 5
    loadVisiblePages()
}

func loadPage(page: Int) {

    if page < 0 || page >= pageImages.count {
        // If it's outside the range of what you have to display, then do nothing
        return
    }

    // 1
    if let pageView = pageViews[page] {
        // Do nothing. The view is already loaded.
    } else {
        // 2
        var frame = scrollView.bounds
        frame.origin.x = frame.size.width * CGFloat(page)
        frame.origin.y = 0.0

        // 3
        let newPageView = UIImageView(image: pageImages[page])
        newPageView.contentMode = .ScaleAspectFit
        newPageView.frame = frame
        scrollView.addSubview(newPageView)

        // 4
        pageViews[page] = newPageView
    }
}

func purgePage(page: Int) {

    if page < 0 || page >= pageImages.count {
        // If it's outside the range of what you have to display, then do nothing
        return
    }

    // Remove a page from the scroll view and reset the container array
    if let pageView = pageViews[page] {
        pageView.removeFromSuperview()
        pageViews[page] = nil
    }

}

func loadVisiblePages() {

    // First, determine which page is currently visible
    let pageWidth = scrollView.frame.size.width
    let page = Int(floor((scrollView.contentOffset.x * 2.0 + pageWidth) / (pageWidth * 2.0)))

    // Update the page control
    pageControl.currentPage = page

    // Work out which pages you want to load
    let firstPage = page - 1
    let lastPage = page + 1


    // Purge anything before the first page
    for var index = 0; index < firstPage; ++index {
        purgePage(index)
    }

    // Load pages in our range
    for var index = firstPage; index <= lastPage; ++index {
        loadPage(index)
    }

    // Purge anything after the last page
    for var index = lastPage+1; index < pageImages.count; ++index {
        purgePage(index)
    }
}


func scrollViewDidScroll(scrollView: UIScrollView!) {
    // Load the pages that are now on screen
    loadVisiblePages()
}

override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


}
class PagedScrollViewController:UIViewController,UIScrollViewDelegate{
@iBCROLLVIEW:UIScrollView!
@IBVAR pageControl:UIPageControl!
var pageImages:[UIImage]=[]
var页面浏览量:[UIImageView?]=[]
重写func viewDidLoad(){
super.viewDidLoad()
// 1
pageImages=[UIImage(名为:“photo1.png”)!,
UIImage(名为:“photo2.png”)!,
UIImage(名为:“photo3.png”)!,
UIImage(名为:“photo4.png”)!,
UIImage(名为:“photo5.png”)!]
让pageCount=pageImages.count
// 2
pageControl.currentPage=0
pageControl.numberOfPages=pageCount
// 3
对于0中的u0..=pageImages.count{
//如果超出了必须显示的范围,则什么也不做
返回
}
// 1
如果let pageView=pageViews[page]{
//不执行任何操作。视图已加载。
}否则{
// 2
var frame=scrollView.bounds
frame.origin.x=frame.size.width*CGFloat(第页)
frame.origin.y=0.0
// 3
让newPageView=UIImageView(图像:pageImages[页面])
newPageView.contentMode=.ScaleSpectFit
newPageView.frame=frame
scrollView.addSubview(newPageView)
// 4
页面浏览量[页面]=新建页面浏览量
}
}
func purgePage(页码:Int){
如果页面<0 | |页面>=pageImages.count{
//如果超出了必须显示的范围,则什么也不做
返回
}
//从滚动视图中删除页面并重置容器阵列
如果let pageView=pageViews[page]{
pageView.removeFromSuperview()
页面浏览量[页面]=零
}
}
func loadVisiblePages(){
//首先,确定当前可见的页面
让pageWidth=scrollView.frame.size.width
让page=Int(floor((scrollView.contentOffset.x*2.0+pageWidth)/(pageWidth*2.0)))
//更新页面控件
pageControl.currentPage=第页
//确定要加载的页面
让firstPage=page-1
让lastPage=page+1
//清除第一页之前的任何内容
对于var index=0;index对于var index=firstPage;index您可以创建一个自定义类,该类派生自
UIScrollView
,名为
ImageScrollView
,其中有一个
UIImageView


使用界面生成器创建此视图。现在,在页面视图数组中,您需要添加
ImageScrollView
而不是
UIImageView
,这样可以实现缩放效果。

使用

这真的很有帮助。谢谢:)