繁体   English   中英

在iPhone和iPad上放置的视图不同

[英]view placed differently on iphone and ipad

我已经建立了一个应用程序,使用户可以选择覆盖眼镜来拍照。 它确实可以在ipad和ipad mini上正常运行,但在iphone上滚动视图的相对位置错误(请参见图片)。

func setupPages(){
    pageImages = [
        UIImage(named: "glasses_one")!,
        UIImage(named: "glasses_two")!,
        UIImage(named: "glasses_three")!,
        UIImage(named: "glasses_four")!,
        UIImage(named: "glasses_five")!,
        UIImage(named: "glasses_six")!
    ]

    let pageCount = pageImages.count

    for _ in 0..<pageCount {
        pageViews.append(nil)
    }
    print(pageViews.count)

    let pagesScrollViewSize = scrollView.frame.size
    scrollView.contentSize = CGSize(width:  scrollWidth * CGFloat(pageImages.count),
        height: pagesScrollViewSize.height)

    scrollView.backgroundColor = UIColor.blueColor()

    loadVisiblePages()
}

func loadVisiblePages() {
    let pageWidth = scrollView.frame.size.width

    page = Int(floor((scrollView.contentOffset.x * 2.0 + pageWidth) / (pageWidth * 2.0)))
    print(page)
    pageControl.currentPage = page

    for index in 0...5 {
        //print(" -- Index = \(index)")
        loadPage(index)
    }
}

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] {
        print(pageView.description)
        // Do nothing. The view is already loaded.
    } else {
        // 2
        var frame = scrollView.bounds
        frame.origin.x = scrollWidth * CGFloat(page)
        frame.origin.y = 0.0
        frame.size.width = scrollWidth
        // 3
        let newPageView = UIImageView(image: pageImages[page])
        newPageView.contentMode = .ScaleAspectFit
        newPageView.frame = frame
        newPageView.clipsToBounds = false
        scrollView.addSubview(newPageView)


        // 4
        pageViews[page] = newPageView
    }
}

平板电脑

在此处输入图片说明

苹果手机

在此处输入图片说明

我认为您的问题是您需要添加约束以使图像垂直居中。 或者,您也可以通过将“眼镜框架”的框架的宽度和高度设置为一定来解决此问题。 较小的屏幕周围空间较小,但仍处于中间位置。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM