UITableView+FDIndexPathHeightCache.h 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. // The MIT License (MIT)
  2. //
  3. // Copyright (c) 2015-2016 forkingdog ( https://github.com/forkingdog )
  4. //
  5. // Permission is hereby granted, free of charge, to any person obtaining a copy
  6. // of this software and associated documentation files (the "Software"), to deal
  7. // in the Software without restriction, including without limitation the rights
  8. // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
  9. // copies of the Software, and to permit persons to whom the Software is
  10. // furnished to do so, subject to the following conditions:
  11. //
  12. // The above copyright notice and this permission notice shall be included in all
  13. // copies or substantial portions of the Software.
  14. //
  15. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  16. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  17. // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
  18. // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
  19. // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
  20. // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
  21. // SOFTWARE.
  22. #import <UIKit/UIKit.h>
  23. @interface FDIndexPathHeightCache : NSObject
  24. // Enable automatically if you're using index path driven height cache
  25. @property (nonatomic, assign) BOOL automaticallyInvalidateEnabled;
  26. // Height cache
  27. - (BOOL)existsHeightAtIndexPath:(NSIndexPath *)indexPath;
  28. - (void)cacheHeight:(CGFloat)height byIndexPath:(NSIndexPath *)indexPath;
  29. - (CGFloat)heightForIndexPath:(NSIndexPath *)indexPath;
  30. - (void)invalidateHeightAtIndexPath:(NSIndexPath *)indexPath;
  31. - (void)invalidateAllHeightCache;
  32. @end
  33. @interface UITableView (FDIndexPathHeightCache)
  34. /// Height cache by index path. Generally, you don't need to use it directly.
  35. @property (nonatomic, strong, readonly) FDIndexPathHeightCache *fd_indexPathHeightCache;
  36. @end
  37. @interface UITableView (FDIndexPathHeightCacheInvalidation)
  38. /// Call this method when you want to reload data but don't want to invalidate
  39. /// all height cache by index path, for example, load more data at the bottom of
  40. /// table view.
  41. - (void)fd_reloadDataWithoutInvalidateIndexPathHeightCache;
  42. @end