zoukankan      html  css  js  c++  java
  • UICollectionView 修改Item时函数执行顺序

      项目中使用Collection时,需要添加一些动画。

      当 Collection 插入或移除 item 时,函数执行的顺序:

    空数据插入Item
      1.[UIApplication sendAction:to:from:forEvent] _IOHIDEvent
      2.类insert函数
      3.[UICollectionView _updateRowsAtIndexPaths:updateAction:]
      4.[UICollectionViewData _prepareToLoadData]
      5.-prepareLayout
      6.-prepareForCollectionViewUpdates:
      7.[UICollectionView _viewAnimationsForCurrentUpdate]
      8.-initialLayoutAttributesForAppearingItemAtIndexPath:
      9.[UICollectionView _updateWithItems:tentativelyForRecording:animator]
      10.-finalizeCollectionViewUpdates

    有数据插入Item
      1. ~ 8.
      9.[UICollectionView _doubleSidedAnimateionsForView:withStartingLayoutAttributes:startingLayout:endingLayoutAttributes:endingLayout:withAnimationSetup:animationCompletion:enableCustomAnimations:customAnimationsType:]
      10.-finalLayoutAttributesForDisappearingItemAtIndexPath:
      11.8/10步骤循环(循环次数取决于剩下的Item个数)
      12.-finalizeCollectionViewUpdates

    空数据移除Item
      1.[UIApplication sendAction:to:from:forEvent:] _IOHIDEvent
      2.类remove函数
      3.[UICollectionView _updateRowsAtIndexPaths:updateAction:]
      4.[UICollectionViewData _prepareToLoadData]
      5.-prepareLayout
      6.-prepareForCollectionViewUpdates:
      7.[UICollectionView _viewAnimationsForCurrentUpdate]
      8.-finalLayoutAttributesForDisappearingItemAtIndexPath:
      9.[UICollectionView _updateWithItems:tentativelyForRecording:animator]
      4.finalizeCollectionViewUpdates

    有数据移除Item
      类似有数据插入Item

    参考博客中对这样的描述:

    In general, layout attributes are linearly interpolated from the initial state to the final state to compute the collection view animations. However, for the newly inserted or removed items, there are no initial and final attributes to interpolate from. To compute the animations for such cells, the collection view will ask its layout object to provide the initial and final attributes through the initialLayoutAttributesForAppearingItemAtIndexPath: and finalLayoutAttributesForDisappearingItemAtIndexPath: methods.
    ....
    During the animation of the bounds change, the collection view acts as if the currently displayed items are removed and inserted again in the new bounds, resulting in a series of finalLayoutAttributesForDisappearingItemAtIndexPath: and initialLayoutAttributesForAppearingItemAtIndexPath: calls for each index path.



    > 参考:[Animating Collection Views](https://www.objc.io/issues/12-animations/collectionview-animations/)
  • 相关阅读:
    改造vue-quill-editor: 结合element-ui上传图片到服务器
    webpack2.X、Vue学习以及将两者相结合
    Vuex-一个专为 Vue.js 应用程序开发的状态管理模式
    vue深究第一弹:computed与watch的异同
    管理系统列表和详情配置
    Vue和vue-template-compiler版本之间的问题
    vuex 闲置状态重置方案
    mac install brew
    Android——推断Service是否已经启动
    【android】uses-permission和permission具体解释
  • 原文地址:https://www.cnblogs.com/R0SS/p/5714089.html
Copyright © 2011-2022 走看看