亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

ios基于UICollectionView實現橫向瀑布流

2019-10-21 18:22:04
字體:
來源:轉載
供稿:網友

在網上找了許久,一直沒有發現有提供橫向瀑布流效果的。在項目中用到了我就在垂直瀑布流的基礎上,進行了修改,做出了橫向瀑布流的效果。同時也對一些UICollectionView的屬性進行簡單的注釋,方便以后查閱。

1、首先要寫一個繼承與NSObject的布局類,記錄每一行(列)目前的寬度(高度)。再添加一個新的cell的時候進行判斷比較,添加到最短的那一行或一列上。

2、橫向的布局類入下,垂直的話就是講對應的X Y軸數據進行調整即可。
WaterfallFlowLayout為布局類,繼承與NSObject。.h文件入下

#import <UIKit/UIKit.h>// 類的前置聲明@class WaterfallFlowLayout;@protocol WaterfallFlowLayoutDelegate <NSObject>// 動態獲取 item 寬度- (CGFloat) WaterfallFlowLayout:(WaterfallFlowLayout *) layout widthForItemAtIndexPath:(NSIndexPath *) indexPath;@end@interface WaterfallFlowLayout : UICollectionViewLayout@property (nonatomic,assign) id <WaterfallFlowLayoutDelegate> delegate;@property (nonatomic) NSInteger numberOfColumns;@property (nonatomic) CGFloat minimumLineSpacing;@property (nonatomic) CGFloat minimumInteritemSpacing;@property (nonatomic) UIEdgeInsets sectionInset;@end

WaterfallFlowLayout為布局類,繼承與NSObject。.m文件入下

#import "WaterfallFlowLayout.h"@interface WaterfallFlowLayout (){  // 用于記錄每一列布局到的寬度  NSMutableArray * _widthOfColumns;  // 用于保存所有item的屬性 (frame)  NSMutableArray * _itemsAttributes;}@end@implementation WaterfallFlowLayout- (void) setNumberOfColumns:(NSInteger)numberOfColumns {  if (_numberOfColumns != numberOfColumns) {    _numberOfColumns = numberOfColumns;    // 讓原有布局失效,需要重新布局    [self invalidateLayout];  }}- (void)setMinimumLineSpacing:(CGFloat)minimumLineSpacing {  if (_minimumLineSpacing != minimumLineSpacing) {    _minimumLineSpacing = minimumLineSpacing;    [self invalidateLayout];  }}- (void)setMinimumInteritemSpacing:(CGFloat)minimumInteritemSpacing {  if (_minimumInteritemSpacing != minimumInteritemSpacing) {    _minimumInteritemSpacing = minimumInteritemSpacing;    [self invalidateLayout];  }}- (void)setSectionInset:(UIEdgeInsets)sectionInset {  if (!UIEdgeInsetsEqualToEdgeInsets(_sectionInset, sectionInset)) {    _sectionInset = sectionInset;    [self invalidateLayout];  }}//重寫方法 1: 準備布局-(void)prepareLayout {  [super prepareLayout];  // 真正的布局在這里完成  if (_itemsAttributes) {    [_itemsAttributes removeAllObjects];  }else {    _itemsAttributes = [[NSMutableArray alloc] init];  }  if (_widthOfColumns) {    [_widthOfColumns removeAllObjects];  }else {    _widthOfColumns = [[NSMutableArray alloc] init];  }  for (NSInteger i = 0; i < self.numberOfColumns; i++) {    // 初始化每一列的寬度(默認為上邊距)//    _heightOfColumns[i] = @(self.sectionInset.top);    [_widthOfColumns addObject:@(self.sectionInset.left)];  }  // item的總數  NSInteger count = [self.collectionView numberOfItemsInSection:0];//  CGFloat itemWidth = (self.collectionView.frame.size.width - self.sectionInset.left - self.sectionInset.right - (_numberOfColumns-1) * _minimumInteritemSpacing )/_numberOfColumns;  // 總的高度 (集合視圖的寬度)  CGFloat totalHeight = self.collectionView.frame.size.height;  // 有效的高度 (出去間隔及邊界)  CGFloat validHeight = totalHeight - self.sectionInset.top - self.self.sectionInset.bottom - (self.numberOfColumns-1) * self.minimumInteritemSpacing;  // 每一個item的高度  CGFloat itemHeight = validHeight/self.numberOfColumns;  // 設置item的默認寬度  CGFloat itemWidth = itemHeight;  for (NSInteger i = 0; i<count; i++) {    // 最短列的下標    NSInteger index = [self indexOfShortestColumn];    CGFloat originY = self.sectionInset.top + index * (itemHeight +self.minimumInteritemSpacing);    CGFloat originX = [_widthOfColumns[index] floatValue];    // 構造 indexPath    NSIndexPath * indexPath = [NSIndexPath indexPathForItem:i inSection:0];    // 動態的獲取寬度    if ([self.delegate respondsToSelector:@selector(WaterfallFlowLayout:widthForItemAtIndexPath:)]) {      itemWidth = [self.delegate WaterfallFlowLayout:self widthForItemAtIndexPath:indexPath];    }    UICollectionViewLayoutAttributes * attr = [UICollectionViewLayoutAttributes layoutAttributesForCellWithIndexPath:indexPath];    attr.frame = CGRectMake(originX, originY, itemWidth, itemHeight);    // 保存 item 的屬性 到數組中    [_itemsAttributes addObject:attr];    // 更新布局到的一列(最短列) 的高度    _widthOfColumns[index] = @(originX + itemWidth + self.minimumLineSpacing);  }  // 刷新顯示  [self.collectionView reloadData];}//重寫方法 2: 返回指定區域的item的屬性(frame)- (NSArray<UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect {  NSMutableArray * array = [NSMutableArray array];  for (UICollectionViewLayoutAttributes * attr in _itemsAttributes) {    // 判斷兩個矩形是否有交集    if (CGRectIntersectsRect(attr.frame, rect)) {      [array addObject:attr];    }  }  return array;}//重寫方法 3: 返回內容的尺寸-(CGSize)collectionViewContentSize {  CGFloat height = self.collectionView.frame.size.height;  NSInteger index = [self indexOfLongestColumn];  CGFloat width = [_widthOfColumns[index] floatValue] + self.sectionInset.right - self.minimumLineSpacing;  return CGSizeMake(width, height);}- (NSInteger) indexOfLongestColumn {  NSInteger index = 0;  for (NSInteger i = 0; i<_numberOfColumns; i++) {    if ([_widthOfColumns[i] floatValue] > [_widthOfColumns[index] floatValue]) {      index = i;    }  }  return index;}- (NSInteger) indexOfShortestColumn {  NSInteger index = 0;  for (NSInteger i = 0; i<_numberOfColumns; i++) {    if ([_widthOfColumns[i] floatValue] < [_widthOfColumns[index] floatValue]) {      index = i;    }  }  return index;}@end

3、上邊的這個布局類可以直接復制粘貼下來。然后就是創建你的UICollectionView 

在collectionView的cell中可以直接創建imageView或者是label添加到cell上,用來顯示數據。 
collectionView默認section縮進左右是0 
調節橫向cell間距 
layout.minimumLineSpacing = 10; 
調節縱向cell間距 
layout.minimumInteritemSpacing = 20; 
調節瀑布流顯示的行數,當然了你的collectionView的高(寬)足夠顯示幾行(列)就會自動顯示多上行(列); 
layout.numberOfColumns = 3;

#import "RootViewController.h"#import "WaterfallFlowLayout.h"@interface RootViewController () <UICollectionViewDataSource,UICollectionViewDelegateFlowLayout,WaterfallFlowLayoutDelegate>{  UICollectionView * _collectionView;}@end@implementation RootViewController- (void)dealloc {  [_collectionView release];  [super dealloc];}- (void)viewDidLoad {  [super viewDidLoad];  // 創建集合視圖  [self createCollectionView];}- (UICollectionViewLayout *)createLayout {#if 1  WaterfallFlowLayout * layout = [[WaterfallFlowLayout alloc] init];  layout.sectionInset = UIEdgeInsetsMake(20, 20, 20, 20);  layout.minimumLineSpacing = 10;  layout.minimumInteritemSpacing = 20;  layout.numberOfColumns = 3;  layout.delegate = self;  [self performSelector:@selector(changeLayout:) withObject:layout afterDelay:3];#else  UICollectionViewFlowLayout * layout = [[UICollectionViewFlowLayout alloc] init];  layout.minimumLineSpacing = 10;  layout.itemSize = CGSizeMake(150, 100);  layout.sectionInset = UIEdgeInsetsMake(10, 10, 10, 10);#endif  return [layout autorelease];}- (void)changeLayout:(WaterfallFlowLayout *)layout {  layout.numberOfColumns = 3;}- (void)createCollectionView {  CGRect frame = CGRectMake(0, 20, VIEW_WIDTH, VIEW_HEIGHT-20);  _collectionView = [[UICollectionView alloc] initWithFrame:frame collectionViewLayout:[self createLayout]];  _collectionView.backgroundColor = [UIColor cyanColor];  // 設置代理  _collectionView.delegate = self;  _collectionView.dataSource = self;  // 注冊cell 類型 及 復用標識  [_collectionView registerClass:[UICollectionViewCell class] forCellWithReuseIdentifier:@"cellId"];  [self.view addSubview:_collectionView];}#pragma mark - UICollectionViewDataSource- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section {  return 102;}- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath {  UICollectionViewCell * cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"cellId" forIndexPath:indexPath];  UILabel * label = nil;  NSArray * array = cell.contentView.subviews;  if (array.count) {    label = array[0];  }else {    label = [[UILabel alloc] init];//    label.frame = cell.bounds;    label.textAlignment = NSTextAlignmentCenter;    label.font = [UIFont systemFontOfSize:50];    [cell.contentView addSubview:label];    [label release];  }  label.frame = cell.bounds;  label.text = [NSString stringWithFormat:@"%ld",indexPath.item];  label.textColor = [UIColor whiteColor];  cell.backgroundColor = RandomColor;  return cell;}- (CGSize) collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath {  return CGSizeMake( arc4random()%100+200, 110);}-(CGFloat) WaterfallFlowLayout:(WaterfallFlowLayout *)layout widthForItemAtIndexPath:(NSIndexPath *)indexPath{  return arc4random()%150+50;}-(void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath{  NSLog(@"點擊了第 %ld 組,第 %ld 行",indexPath.section,indexPath.row);}- (void)didReceiveMemoryWarning {  [super didReceiveMemoryWarning];}@end

實現的效果如下 

ios,UICollectionView,瀑布流

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到IOS開發頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日本伊人精品一区二区三区介绍| yellow中文字幕久久| 国产精品视频在线播放| 欧美成人免费在线观看| 国产一区二区三区在线| xxxxx成人.com| 大桥未久av一区二区三区| 久久精品视频在线观看| 亚洲日本中文字幕免费在线不卡| 亚洲美女黄色片| 日韩精品在线电影| 国产精品成人观看视频国产奇米| 欧美高清电影在线看| 欧美一级电影免费在线观看| 91在线免费看网站| 中文字幕9999| 中文一区二区视频| 欧美香蕉大胸在线视频观看| 国产精品成久久久久三级| 久久久久久成人精品| 国产精品久久久久久久久久| 精品国产一区久久久| 久久国产精品久久精品| 日韩在线视频线视频免费网站| 国产91精品青草社区| 亚洲成人网在线观看| 国产精品一区二区三区毛片淫片| 亚洲第一综合天堂另类专| 久久精品久久久久久国产 免费| 日本乱人伦a精品| 日韩视频在线观看免费| 亚洲第一二三四五区| 亚洲国产日韩一区| 国产成人avxxxxx在线看| 国产成人在线一区二区| 久久久久久久香蕉网| 538国产精品一区二区在线| 亚洲精品影视在线观看| 高清在线视频日韩欧美| 成人免费午夜电影| 91久久久久久久久| 中文字幕欧美视频在线| 欧美夜福利tv在线| 不卡av日日日| 亚洲成人激情小说| 亚洲视频日韩精品| 九九久久综合网站| 久久人人看视频| 伊人久久五月天| 国产精品盗摄久久久| 成人久久精品视频| 久久久久久久影院| 日韩精品在线影院| 国产精品中文字幕在线观看| 国产97在线|日韩| 国产精品久久久久久久久粉嫩av| 日av在线播放中文不卡| 成人黄色免费看| 欧美日韩亚洲91| 91免费人成网站在线观看18| 亚洲专区在线视频| 免费91麻豆精品国产自产在线观看| 国产精品极品尤物在线观看| 九九久久国产精品| 久久影院中文字幕| 欧美国产亚洲视频| 欧美亚洲国产日韩2020| 久久久国产精彩视频美女艺术照福利| 日韩免费在线观看视频| 欧美夫妻性生活视频| 国产欧美欧洲在线观看| 国产精品美女免费看| 亚洲欧美日本另类| 国模精品视频一区二区三区| 韩国精品久久久999| 一区二区欧美在线| 精品调教chinesegay| 久久久亚洲国产天美传媒修理工| 日韩激情视频在线| 国产日韩亚洲欧美| 国产亚洲精品成人av久久ww| 色综合久久悠悠| 成人免费自拍视频| 亚洲美女精品成人在线视频| 亚洲福利在线观看| 国产精品亚洲美女av网站| 91精品国产免费久久久久久| 91视频国产高清| 国产精品99久久99久久久二8| 欧美激情免费看| 国产精品高潮粉嫩av| 5278欧美一区二区三区| 韩国精品久久久999| 欧美尺度大的性做爰视频| 亚洲成人av在线| 欧美午夜女人视频在线| 日韩中文在线不卡| 国内精品久久久久久影视8| 狠狠色香婷婷久久亚洲精品| 欧美性xxxx在线播放| 欧美www视频在线观看| 欧美日本在线视频中文字字幕| 日韩三级影视基地| 精品亚洲一区二区三区四区五区| 欧美贵妇videos办公室| 亚洲日本中文字幕免费在线不卡| 欧美激情在线视频二区| 欧美激情精品久久久久久变态| 国产精品精品国产| 午夜美女久久久久爽久久| 成人黄色在线免费| 日韩久久免费电影| 亚洲无线码在线一区观看| 日韩高清电影免费观看完整版| 国产精品第1页| 成人高h视频在线| 91亚洲精华国产精华| 亚洲新中文字幕| 亚洲香蕉成人av网站在线观看| 最新91在线视频| 欧美极品少妇与黑人| 91亚洲精品久久久| 欧美成人精品影院| 亚洲色图综合网| 欧美激情一区二区三区成人| 亚洲欧美一区二区三区四区| 国产精品偷伦视频免费观看国产| 精品国产欧美成人夜夜嗨| 亚洲变态欧美另类捆绑| 亚洲乱码一区av黑人高潮| 91中文精品字幕在线视频| 欧美国产日韩一区二区在线观看| 日韩高清中文字幕| 91高清视频在线免费观看| 26uuu另类亚洲欧美日本一| 精品国产精品三级精品av网址| 亚洲影视九九影院在线观看| 欧美丰满少妇xxxxx做受| 91av视频在线免费观看| 欧美亚洲视频一区二区| 国产999精品| 欧美日韩另类字幕中文| 精品国产欧美成人夜夜嗨| 精品久久久av| 成人精品久久一区二区三区| 7777精品视频| 日韩在线观看免费全集电视剧网站| 亚洲图片在线综合| 亚洲区bt下载| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美精品999| 亚洲精品视频在线播放| 中文字幕亚洲色图| 久久久精品日本| 国产一区二区三区免费视频| 亚洲免费电影一区| 国产女同一区二区| 国产91精品久久久久| 久久噜噜噜精品国产亚洲综合| 午夜精品一区二区三区在线视| 国产精品一区久久久| 成人久久一区二区| 欧美日韩裸体免费视频| 国产日韩亚洲欧美|