UIScrollView 中 UIImageView 的对齐方式

Posted

技术标签:

【中文标题】UIScrollView 中 UIImageView 的对齐方式【英文标题】:Alignment of UIImageView within UIScrollView 【发布时间】:2016-08-21 22:58:05 【问题描述】:

我在很多地方都看到过这个话题,但我不明白为什么我的代码完全不起作用。

我有一张从 -90 到 90 度的人造地平线图像。我想通过一个只显示大约-20到20度的小窗口来查看它。然后我想根据我的机器人倾斜的角度上下移动图像。

我首先将 UIImage 添加到 UIImageView。所有的对齐都是正确的。然后我认为上下移动图像的最简单方法是将 UIImageView 添加到 UIScrollView。现在我不知道如何正确对齐。如果我在滚动视图中拖动,我会看到其中的图像,但一旦我放开它就会回到原来的位置。

这是我的代码。这是我编写的第一个 Swift 代码,所以如果有更好的方法可以做到这一点,我欢迎任何嘲笑(开玩笑,要温柔)

override func viewDidLoad() 
    super.viewDidLoad()

    let imageRect = CGRectMake(self.view.frame.width / 2 - 100, self.view.frame.height / 2, 200, 200)

    self.myImageView = UIImageView.init()
    self.myImageView = UIImageView(frame: imageRect)
    self.myImageView.contentMode = UIViewContentMode.Center
    self.myImageView.clipsToBounds = true
    self.myImageView.image = UIImage.init(named:"horizon")
    //self.view.addSubview(self.image)


    self.myScrollView = UIScrollView(frame: imageRect)
    self.myScrollView.contentSize = CGSize(width: imageRect.width, height: imageRect.height)

    self.myImageView.center = self.myScrollView.center
    self.myScrollView.frame = imageRect
    self.myScrollView.backgroundColor = UIColor.blackColor()
    self.myScrollView.contentOffset = CGPoint(x: 0, y: 0)
    self.myScrollView.addSubview(self.myImageView)
    self.view.addSubview(self.myScrollView)

    /////////


    self.connectionStatusLabel.text = "Disconnected"
    self.connectionStatusLabel.textColor = UIColor.redColor()

    self.textBox.font = UIFont(name: self.textBox.font!.fontName, size: 8)

    // Watch Bluetooth connection
    NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(ViewController.connectionChanged(_:)), name: BLEServiceChangedStatusNotification, object: nil)


    NSNotificationCenter.defaultCenter().addObserver(self, selector: #selector(ViewController.dataReceived(_:)), name: BLEDataChangedStatusNotification, object: nil)


    // Start the Bluetooth discovery process
    btDiscoverySharedInstance

【问题讨论】:

【参考方案1】:

您必须将 scrollView 的 contentSize 设置为实际图像大小,而不是 imageView 的大小。并将 imageView 的大小也设置为实际图像大小:

let image = UIImage.init(named:"horizon")
// Set the imageView's size to the actual image size
self.myImageView.frame = CGRect(x: 0, y: 0, width: size.width, height: size.height)
...
...
// Set the scrollView's contentSize to the actual image size
self.myScrollView.contentSize = image.size

【讨论】:

以上是关于UIScrollView 中 UIImageView 的对齐方式的主要内容,如果未能解决你的问题,请参考以下文章

崩溃应用程序

调整容器 uiscrollview 中所有 uiscrollview 的大小

UIScrollView 子视图中的水平 UISwipeGestureRecognizer ? (UIScrollView 只需要识别垂直滚动)

UIScrollView 中的 UITextView 都在另一个 UIScrollView 中

在 UIScrollView 中旋转 UIViewControllers

解决UIScrollView中添加子控件出现“UIScrollView Scrollable Content Size Ambiguity”的办法