在tvOS中的UIScrollView

时间:2015-11-16 17:45:09

标签: swift uiscrollview tvos

我有一个类似于下图中的视图层次结构(蓝色是场景的可见部分):

enter image description here

所以我有一个包含很多元素的UIScrollView,其中我只显示了两个按钮,因为它们与问题相关。运行应用程序时,第一个按钮可见,而另一个按钮位于最初可见区域之外。第一个按钮也是首选的FocusView。

现在我正在使用UIFocusGuide更改两个按钮之间的焦点,这可以工作(在didUpdateFocusInContext:中查看)。但是,当Button2聚焦时,我的滚动视图不会向下滚动。

滚动视图固定到superview,我在视图控制器的viewDidLoad中为其指定了适当的内容。

如何让滚动视图滚动?

3 个答案:

答案 0 :(得分:2)

看看UIScrollView.panGestureRecognizer.allowedTouchTypes。它是一个NSNumber数组,其值基于UITouchTypeUITouch.TouchType(取决于语言版本)。默认情况下,allowedTouchTypes包含2个值 - directstylus。这意味着您的UIScrollView实例不会响应来自远程控制的信号。添加以下行来修复它:

Swift 4

self.scrollView.panGestureRecognizer.allowedTouchTypes = [NSNumber(value: UITouchType.indirect.rawValue)]

Swift 4.2& 5

self.scrollView.panGestureRecognizer.allowedTouchTypes = [NSNumber(value: UITouch.TouchType.indirect.rawValue)]

另外,不要忘记为contentSize设置正确的UIScrollView

self.scrollView.contentSize = CGSize(width: 1920.0, height: 2000.0)

答案 1 :(得分:1)

最后,我通过将scrollView.contentSize设置为viewDidLoad中的适当大小来解决此问题。

答案 2 :(得分:0)

您需要添加平移手势识别器。我从这里学到了:http://www.theappguruz.com/blog/gesture-recognizer-using-swift。我添加了更多代码,使其不会奇怪地滚动,例如在水平方向。

var currentY : CGFloat = 0   //this saves current Y position

func initializeGestureRecognizer()
{
    //For PanGesture Recoginzation
    let panGesture: UIPanGestureRecognizer = UIPanGestureRecognizer(target: self, action: Selector("recognizePanGesture:"))
    self.scrollView.addGestureRecognizer(panGesture)
}

func recognizePanGesture(sender: UIPanGestureRecognizer)
{
    let translate = sender.translationInView(self.view)
    var newY = sender.view!.center.y + translate.y

    if(newY >= self.view.frame.height - 20) {
        newY = sender.view!.center.y    //make it not scrolling downwards at the very beginning
    }
    else if( newY <= 0){
        newY = currentY                 //make it scrolling not too much upwards
    }

    sender.view!.center = CGPoint(x:sender.view!.center.x,
        y:newY)
    currentY = newY

    sender.setTranslation(CGPointZero, inView: self.view)
}