Множественные вызовы ScrollToItem(at:at:animated:) в быстрой последовательности вызывают сбой прокрутки в UICollectionViIOS

Программируем под IOS
Ответить Пред. темаСлед. тема
Anonymous
 Множественные вызовы ScrollToItem(at:at:animated:) в быстрой последовательности вызывают сбой прокрутки в UICollectionVi

Сообщение Anonymous »


В моей настройке у меня есть горизонтальное представление коллекции со стилем чипа. При начальной загрузке первый чип выбирается по умолчанию и соответствует чипу, выполняется вызов API, и его данные загружаются в вертикальный UICollectionView прямо ниже.
р>
При касании любой из фишек в UICollectionView инициируется вызов API, и выбранная ячейка прокручивается в центр представления коллекции с помощью scrollToItem(at: selectedChipIndexPath, at: .centerHorizontally, Animation: true). Кроме того, мне нужно перезагрузить последний выбранный и текущий выбранный indexPath, чтобы указать, что выбрана новая ячейка.

Все работает нормально, если пользователь нажимает на чипы, просматривает загруженные ниже данные, а затем нажимает на следующий чип.

Но если пользователь быстро нажимает на последовательные фишки, то scrollToItem(at: selectedChipIndexPath, at: .centerHorizontally, Animated: true) несколько раз дает сбой в анимации прокрутки, вызывая неприятные ощущения от взаимодействия с пользователем.
>
Вот мой код:

horizontalCollectionView.reloadItems(at: [lastSelectedIndexPath, selectedChipIndexPath]) // API-вызов /* Это асинхронный вызов, который после завершения сообщает ViewController об обновлении его вертикального представления коллекции новыми данными. */ viewModel.fetchProductData(forPositon: selectedChipIndexPath) DispatchQueue.main. asyncAfter (.now() + .секунды(0,4)) { HorizontalCollectionView.scrollToItem(at: selectedChipIndexPath, at: .centerHorizontally, анимированный: true) } Если я не задержу прокрутку на несколько миллисекунд, анимация прокрутки представления коллекции начнет сильно глючить.

Так может ли кто-нибудь указать мне в правильном направлении, как я могу обрабатывать или ставить в очередь несколько вызовов scrollToItem(at:at:animated:), чтобы моя анимация прокрутки CollectionView не давала сбоев.< /п> Я пытался обернуть scrollToItem(at:at:animated:) в пакетные обновления, но это не сработало.

Обновление 1:

Вот как в основном выглядит мой пользовательский интерфейс

Горизонтальный просмотр коллекции: для категорий продуктов

Вертикальное представление коллекции: для самих продуктов


Изображение


Обновление 2:

Решение, предоставленное DonMag, работает, но оно создает другую проблему: согласно моим проектам, мне нужно изменить тип шрифта с обычного на полужирный для UILabel внутри чипов, когда он выбран, это приводит к размер рамки метки увеличивается, и для большей части текста метка обрезается, поскольку я просто манипулирую представлениями, а не перезагружаю сами ячейки.

Я попытался сделать недействительным макет потока CollectionView. Но это снова привело меня к той же проблеме с прокруткой.
Реклама
Ответить Пред. темаСлед. тема

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

  • Похожие темы
    Ответы
    Просмотры
    Последнее сообщение

Вернуться в «IOS»