Непрерывная прокрутка между tableView и scrollView

У меня есть родительский вид прокрутки с заголовком uiview и табличным представлением. Я пытаюсь вести себя так же, как на странице профиля в Twitter или Instagram. Вы начинаете прокрутку родительского представления прокрутки, и как только заголовок исчезает, происходит непрерывный переход от прокрутки представления прокрутки к прокрутке представления таблицы без необходимости поднимать палец и заменять его в представлении таблицы . Прямо сейчас текущее поведение немного странное. Мне нужно поднять палец и положить его на представление таблицы после того, как смещение содержимого представления прокрутки прошло мимо заголовка, чтобы начать прокручивать представление таблицы.

MainViewController

    import UIKit
    import XLPagerTabStrip

    class MainViewController: UIViewController {

        lazy var headerViewController: UIViewController = {
            let header = UIViewController()
            return header
        }()

        lazy var bottomViewControllers: BottomPageViewController = {
            let bvc = BottomPageViewController()
            return bvc
        }()

        lazy var scrollView: UIScrollView = {
            let sv = UIScrollView()
            sv.delegate = self
            sv.showsVerticalScrollIndicator = false
            sv.bounces = true
            sv.bounces = false
            return sv
        }()


    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.addSubview(scrollView)
        let f = UIScreen.main.bounds
        scrollView.frame = CGRect(x: f.minX, y: f.minY, width: f.width, height: f.height)

        add(headerViewController, to: scrollView, frame: CGRect(x: 0, y: 0, width: f.width, height: 150))
        add(bottomViewControllers, to: scrollView, frame: CGRect(x: 0, y: headerViewController.view.bounds.height, width: f.width, height: f.height))
        scrollView.contentSize = CGSize(width: f.width, height: f.height * 2)

        if let vcs = bottomViewControllers.viewControllers as? [BottomViewController] {
            for vc in vcs {
                vc.delegate = self
            }
        }
    }

}

extension MainViewController: UIScrollViewDelegate {
    func scrollViewDidScroll(_ scrollView: UIScrollView) {
        guard let controllers = bottomViewControllers.viewControllers as? [BottomViewController] else { return }
        let selectedController = controllers[bottomViewControllers.currentIndex]
        if self.scrollView == scrollView {
            selectedController.tableView.isScrollEnabled = self.scrollView.contentOffset.y >= 150
            print(scrollView.contentOffset.y)
            scrollView.isScrollEnabled = !selectedController.tableView.isScrollEnabled
            bottomViewControllers.view.frame.origin.y = max(150, scrollView.contentOffset.y)
        }


    }
}

extension MainViewController: CustomScrollDelegate {
    func tableViewScroll(_ viewController: BottomViewController) {
        print(viewController.tableView.contentOffset.y)
        viewController.tableView.isScrollEnabled = viewController.tableView.contentOffset.y > 0
    }
}

BottomViewController

import UIKit
import XLPagerTabStrip

protocol CustomScrollDelegate {
    func tableViewScroll(_ viewController: BottomViewController)
}

class BottomViewController: UITableViewController {

    var pageTitle: String?
    var pageIndex: Int = 0
    var delegate: CustomScrollDelegate?

    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = .red
        self.tableView.isUserInteractionEnabled = false
        self.tableView.bounces = true
        self.tableView.showsVerticalScrollIndicator = true
        self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: "TETST")
    }

    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        guard let cell = tableView.dequeueReusableCell(withIdentifier: "TETST", for: indexPath) as? UITableViewCell else { return UITableViewCell() }
        return cell
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 1000
    }

    override func scrollViewDidScroll(_ scrollView: UIScrollView) {
        delegate?.tableViewScroll(self)
    }

    init(pageTitle: String, pageIndex: Int) {
        self.pageTitle = pageTitle
        self.pageIndex = pageIndex
        super.init(nibName: nil, bundle: nil)
    }

    required init?(coder: NSCoder) {
        fatalError("init(coder:) has not been implemented")
    }

}

extension BottomViewController: IndicatorInfoProvider {
    func indicatorInfo(for pagerTabStripController: PagerTabStripViewController) -> IndicatorInfo {
        return IndicatorInfo.init(title: pageTitle ?? "Tab \(pageIndex)")
    }
}

person joethemow    schedule 14.12.2019    source источник


Ответы (1)


Вам следует просто добавить свой заголовок в качестве заголовка в UITableView (не заголовок раздела!) И позволить ему прокручиваться вместе с остальной частью UITableView: Как прокручивать заголовок вместе с UITableView?

Также вы можете сделать ссылку UITableView contentSize прямо на ее высоту, чтобы сам UITableView никогда не прокручивался, например: Изменение размера UITableView в соответствии с содержимым

Все зависит от того, насколько сложным будет ваше решение, если вы добавляете строки динамически путем разбиения по страницам и т. Д. Но я думаю, что в большинстве случаев вы добьетесь этого, просто настроив заголовок UITableView в правильном режиме.

person Lucas van Dongen    schedule 14.12.2019
comment
Проблема в том, что у меня есть 2 представления таблицы бок о бок, поэтому мне нужно отдельное представление для глобального заголовка. - person joethemow; 14.12.2019
comment
Возьмите UIScrollView, добавьте внутренний UIView, добавьте заголовок вверху и оба UITableView под ним. Затем отслеживайте contentSize обоих представлений таблиц и установите его как минимальную высоту этого UITableView в качестве ограничения. Теперь самый высокий UITableView всегда будет выталкивать внутренний UIView на правильную высоту, а самый короткий UITableView просто станет длиннее без каких-либо ошибок макета. Сообщите мне, работает ли это, и я обновлю ответ. - person Lucas van Dongen; 15.12.2019