由於項目中用到了表格 那就說說它吧
首先用Cocoapods導入TAXSpreadSheet (如果沒整CocoaPods請參考我之前的博客)
TAXHeaderSheet其實和tableView和collectionView差不多
先初始化TAXHeaderSheet
self.headerSheet = [[TAXHeaderSheet alloc] initWithFrame:CGRectMake(20, 20, 300, 300)];
self.headerSheet.delegate = self;
self.headerSheet.dataSource = self;
[self.view addSubview:self.headerSheet];
然後確定小格子的寬度 高度 幾行 幾列
_headerSheet.sizeForCell = CGSizeMake(50.0, 20.0); //小格的寬度和高度
_headerSheet.widthOfHeaderCell = 50.0;
_headerSheet.widthOfFooterCell = 50.0;
_headerSheet.heightOfHeaderCell = 20.0;
_headerSheet.heightOfFooterCell = 20.0;
_headerSheet.heightOfHeader = _headerSheet.heightOfHeaderCell * _numberOfRowsOfHeader;
_headerSheet.heightOfFooter = _headerSheet.heightOfFooterCell * _numberOfRowsOfFooter;
_headerSheet.widthOfHeader = _headerSheet.widthOfHeaderCell * _numberOfColumnsOfHeader;
_headerSheet.widthOfFooter = _headerSheet.widthOfFooterCell * _numberOfColumnsOfFooter;
再然後 就是 遵循 他的幾個必須遵循的代理方法了 其中 返回cell的這個方法 也如表視圖一樣 必須註冊
@protocol TAXHeaderSheetDataSource <NSObject>
@required
- (UICollectionViewCell*)headerSheet:(TAXHeaderSheet *)headerSheet cellAtRow:(NSUInteger)row column:(NSUInteger)column inSectionType:(TAXHeaderSheetSectionType)sectionType;
- (NSInteger)headerSheet:(TAXHeaderSheet *)headerSheet numberOfRowsInHorizontalSectionType:(TAXHeaderSheetHorizontalSectionType)horizontalSectionType;
- (NSInteger)headerSheet:(TAXHeaderSheet *)headerSheet numberOfColumnsInVerticalSectionType:(TAXHeaderSheetVerticalSectionType)verticalSectionType;
當然 爲了呈現表格的視圖 行和行 列和列也得有距離
- (CGFloat)headerSheet:(TAXHeaderSheet *)headerSheet bottomSpacingBelowRow:(NSUInteger)row inSectionType:(TAXHeaderSheetSectionType)sectionType
{
return 1.0;
}
- (CGFloat)headerSheet:(TAXHeaderSheet *)headerSheet trailingSpacingAfterColumn:(NSUInteger)column inSectionType:(TAXHeaderSheetSectionType)sectionType
{
return 1.0;
}
差不多 到此就可以有大概表格的樣子了 給大家看看 我的效果