UICollectionView佈局功能

来源:http://www.cnblogs.com/xueyao/archive/2016/02/11/5186764.html
-Advertisement-
Play Games

UIConllectionView和UITableView類似,也是展示數據,但不同於UITableView那種規則的佈局,UICollectionView可以實現不規則的佈局,即瀑布流。 創建UICollectionView UICollectionView *collectionView = [


UIConllectionView和UITableView類似,也是展示數據,但不同於UITableView那種規則的佈局,UICollectionView可以實現不規則的佈局,即瀑布流。

創建UICollectionView

UICollectionView *collectionView = [[UICollectionView alloc] initWithFrame:[[UIScreen mainScreen] bounds] collectionViewLayout:layout];

集合視圖的創建,必須要指定佈局,如果沒有佈局,顯示不了任何東西,即layout。

 //創建一個佈局對象,採用系統佈局類UICollectinviewFlowLayout
    UICollectionViewFlowLayout *layout = [[UICollectionViewFlowLayout alloc] init];

因為是系統的佈局類,所以也是規則的,但可以自定義FlowLayout的,可以根據自己的需求,來創建不規則的網格。

可以對各個的佈局細節分別進行設置

//設置最小的行間距
    layout.minimumLineSpacing = 20;
    //設置item與item之間的間距
    layout.minimumInteritemSpacing = 10;
    
    //集合視圖的分區間隔               //四個值  上左下右
    layout.sectionInset = UIEdgeInsetsMake(20, 10, 10, 10);
    
    //設置集合視圖的滑動方向
    layout.scrollDirection = UICollectionViewScrollDirectionVertical;// 向下
    layout.scrollDirection = UICollectionViewScrollDirectionHorizontal;  // 向右
    CGFloat totalWidth = self.view.frame.size.width;
    //設置每一個item的尺寸大小
//    layout.itemSize = CGSizeMake((totalWidth - 40) / 3, 80);

當然,簽訂協議之後也可以通過方法進行設置

說到協議 ,協議 分為兩個部分,數據源協議UICollectionViewDelegateSource和代理協議UICollectionViewDelegate

因為涉及到佈局,也會簽訂的佈局協議UICollectionViewDelegateFlowLayout

- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath{
    return CGSizeMake((kWidth - 40) / 3, 100);
}
- (UIEdgeInsets)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout insetForSectionAtIndex:(NSInteger)section{
    return UIEdgeInsetsMake(0, 0, 0, 0);
}

- (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout minimumLineSpacingForSectionAtIndex:(NSInteger)section{
    return 20;
}
- (CGFloat)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout*)collectionViewLayout minimumInteritemSpacingForSectionAtIndex:(NSInteger)section{
    return 20;
}  

UICollectionViewDataSource和UITableView一樣,也有兩個必須要實現的方法

//顯示個數
- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section{
    return 50;
}
//每個cell顯示的內容
- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath{
    MyCollectionViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"reuse" forIndexPath:indexPath];
    cell.contentView.backgroundColor = [UIColor colorWithRed:kColor green:kColor blue:kColor alpha:1.0];
    cell.numberLabel.text = [NSString stringWithFormat:@"%ld",indexPath.row];
    return cell;
}

我這邊cell的顯示內容是顯示一個Label。自定義cell,來設置label的格式。

同UITableView一樣,每個item都可以點擊,觸發 方法

//item點擊之後觸發的方法
- (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath{
    NSLog(@"分區數%ld, 行數%ld",indexPath.section, indexPath.row);
}

值得註意的是,集合視圖不像表視圖那樣,集合視圖,如果想顯示內容,就必須註冊cell

//集合視圖如果想要顯示內容,就必須將cell進行註冊
    [collectionView registerClass:[MyCollectionViewCell class] forCellWithReuseIdentifier:@"reuse"];

註意:

集合視圖的不規則佈局在日常使用還是比較頻繁的,因為每個空間佈局都不一定會是規則,也會有差別,通過自定義FlowLayout..來顯示不同的佈局

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用box-shadow屬性實現圓角效果代碼實例:通常實現圓角效果我們使用border-radius,其實我們也可以使用box-shadow屬性來實現。兩個屬性的具體用法這裡就不多介紹了,具體可以參閱以下兩個文章:(1).圓角效果可以參閱CSS3實現圓角效果一章節。(2).box-shadow可以參
  • 利用jquery實現的批量設置指定type類型input標簽的樣式:input標簽具有多種類型,如果input標簽眾多的話,並且需要動態的設置它們的樣式,那麼使用jquery將是一個良好的選擇。代碼實例: $("input[type=text]").each(function(){ $(this).
  • 點擊彈出居中帶有透明遮罩層視窗:本章節介紹一下如何點擊一個按鈕實現彈出一個居中視窗,並且此視窗帶有半透明的遮罩層效果,此效果在當下比較流行,當然還有更為複雜的實現方式,當然效果也更為絢麗,下麵介紹的代碼能夠簡單實現此效果。代碼如下: <!DOCTYPE html> <html> <head> <me
  • box-shadow並不會增加元素的實際占據空間:關於此屬性的用法這裡就不多做介紹了,具體可以參閱CSS3的box-shadow屬性用法詳解一章節。對元素引用此屬性之後,元素在外觀上是看起來體積變大了,其實並沒有更多的占據空間。代碼實例如下: <!DOCTYPE html> <html> <head
  • jquery實現的豎向動態柱狀條效果:很多數據統計效果中,柱狀條方式的算是比較常見的一種,形象直觀,下麵就是一段能夠實現此功能的代碼實例,並且具有一定的動態效果,下麵就對代碼做一下分享,並詳細介紹一下它的實現過程。代碼如下: <!DOCTYPE html> <html> <head> <meta c
  • 原生javascript實現的水平圖片無縫滾動效果:圖片水平無縫滾動效果在大量的網站都有應用,特別是一些企業網站在展示產品的時候,因為是動態效果,所以能夠給網站增色不少,相比靜態圖片展示更能夠吸引用戶的註意力,下麵就通過實例代碼介紹一下如何實現此效果。代碼如下: <!DOCTYPE html> <h
  • _1.問題描述:_在使用NSString *path = [[NSBundle mainBundle]pathForResource:picName ofType:nil];方法獲取圖片絕對路徑時,獲取到路徑為 null, 即路徑獲取失敗,運行提示類似如下異常:【Could not load the...
  • 跨了一年的問題,凌晨四點終於解決,此時的心情無法形容!!! 凌晨四點的覺悟 === 此時的心情像是心裡有一萬個媽蛋能吐出來的感覺,無法形容的奇妙的感覺!!!好想吐槽!!!問題並不是很複雜,只是需求太多,在網上沒有找到類似的demo,而且網上很多blog或者技術文章都有自己的見解,我還沒有找到一篇能十
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...