Paging UIScrollView with peeking neighbor pages

后端 未结 3 514
Happy的楠姐
Happy的楠姐 2020-12-13 22:38

Look at the App Store app, on either the iPhone or the iPad, specifically the piece on the screen of app details that shows screenshots. The screenshot viewer shows you the

相关标签:
3条回答
  • 2020-12-13 22:42

    Don't forget to forward the touches to the scrollview subviews if you want your content to stay interactive outside the bounds.

    The following example is true if you've put your scrollview content in an extra container. If this isn't the case, the loop over the subviews and return the one that gets hit by your touch.

    - (UIView*)hitTest:(CGPoint)pt withEvent:(UIEvent*)event 
    {
        UIView *contentView = [self.subviews count] ? [self.subviews objectAtIndex:0] : nil;
        return [contentView hitTest:pt withEvent:event];
    }
    
    0 讨论(0)
  • 2020-12-13 22:45

    You need to add a view 'behind' the scroll view which covers the entire area where your pages will be visible. This view should implement -hitTest:withEvent:. This method will get called by the OS to determine where to route a particular touch event. All you need to do is return your scroll view for any points within this backing view:

    Objective-C

    - (UIView *) hitTest: (CGPoint) pt withEvent: (UIEvent *) event {
        if (CGRectContainsPoint(self.bounds, pt)) return self.scrollView;
        return [super hitTest: pt withEvent: event];
    }
    

    Swift 4.0

    override func hitTest(_ point: CGPoint, with event: UIEvent?) -> UIView? {
        return self.bounds.contains(point) ? self.scrollView : super.hitTest(point, with: event)
    }
    
    0 讨论(0)
  • 2020-12-13 22:47

    I don't have a high enough ranking to comment on the answers above but you can find a tutorial and sample code on Ray Wenderlich's site: How To Use UIScrollView to Scroll and Zoom Content

    This code does use the techniques listed above, specifically the hit test logic.

    0 讨论(0)
提交回复
热议问题