複数のセクション(連絡先アプリなど)を持つテーブルを作成しようとしていますが、すべてうまくいき、このセクションを表す文字を表示する各セクションの上にカスタムセクションヘッダーを作成しました。問題は、連絡先のようにしたいことですヘッダーが次のヘッダーが折りたたまれるまでヘッダーが一番上に留まる場所...これはどうやって起こりますか
私は次のコードを使用しています(わかりやすくするため)
- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
// Return the number of sections.
return [stateIndex count];
}
- (UIView *)tableView:(UITableView *)aTableView viewForHeaderInSection:(NSInteger)section
{
UILabel *sectionHeader = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 200, 40)];
sectionHeader.backgroundColor = [UIColor clearColor];
sectionHeader.font = [UIFont boldSystemFontOfSize:18];
sectionHeader.textColor = [UIColor whiteColor];
sectionHeader.text = [stateIndex objectAtIndex:section];
sectionHeader.textAlignment=UITextAlignmentCenter;
return sectionHeader;
}
//---set the index for the table---
- (NSArray *)sectionIndexTitlesForTableView:(UITableView *)tableView {
return stateIndex;
}
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
//---get the letter in each section; e.g., A, B, C, etc.---
NSString *alphabet = [stateIndex objectAtIndex:section];
//---get all states beginning with the letter---
NSPredicate *predicate =
[NSPredicate predicateWithFormat:@"SELF beginswith[c] %@", alphabet];
NSArray *states = [resultPoets filteredArrayUsingPredicate:predicate];
//---return the number of states beginning with the letter---
return [states count];
}
- (UITableViewCell *)tableView:(UITableView *)aTableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *CellIdentifier = @"Cell";
PoemsCell *cell = [aTableView dequeueReusableCellWithIdentifier:CellIdentifier];
int row = indexPath.row;
//---get the letter in the current section---
NSString *alphabet = [stateIndex objectAtIndex:[indexPath section]];
//---get all states beginning with the letter---
NSPredicate *predicate =
[NSPredicate predicateWithFormat:@"SELF beginswith[c] %@", alphabet];
NSArray *states = [resultPoets filteredArrayUsingPredicate:predicate];
if ([states count]>0) {
//---extract the relevant state from the states object---
NSString *cellValue = [states objectAtIndex:row];
cell.poemText.text = cellValue;
}
return cell;
}
これは、「グループ化」ではなく「プレーン」のテーブルビュースタイルを使用する場合、自動的に機能します。
ドキュメントから:
ITableViewStylePlain:プレーンテーブルビュー。セクションヘッダーまたはフッターはインラインセパレータとして表示され、テーブルビューがスクロールされるとフロートします。
ITableViewStyleGrouped:セクションが異なる行のグループを表示するテーブルビュー。セクションのヘッダーとフッターはフロートしません。