0
@property (strong,nonatomic)NSMutableSet*selectedRows;
@property(nonatomic,retain) IBOutlet UITableView *tableView;

...

self.selectedRows = [NSMutableSet new];

...

-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    if ([self.selectedRows containsObject:indexPath]){
        [self.selectedRows removeObject:indexPath];
    }else{
        [self.selectedRows removeAllObjects];//test 1 item only
        [self.selectedRows addObject:indexPath];
    }
    [tableView reloadRowsAtIndexPaths:@[indexPath] withRowAnimation:UITableViewRowAnimationAutomatic];
}



-(CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath{
     NSLog(@"heightForRowAtIndexPath %@ \nSelected %@", indexPath,self.selectedRows);
    for (NSIndexPath*item in self.selectedRows) {
        if ([item compare:indexPath]==NSOrderedSame) {
            NSLog(@"EXIST1");
        }        
        if (item.section == indexPath.section && item.row == indexPath.row) {
            NSLog(@"EXIST2");
        }
    }

    if ([self.selectedRows containsObject:indexPath] == YES) {
        NSLog(@"EXIST3");
    }

    return 44.0f;
}

セルを再描画した後、選択したセルをフィルター処理する必要があります。

問題は、ログにこれだけが記録される理由です: EXIST1 EXIST2

EXIST3はどこですか?

簡単なテスト:

NSMutableSet*s =[NSMutableSet new];

NSIndexPath*p1 = [NSIndexPath indexPathForRow:1 inSection:1];
NSIndexPath*p2 = [NSIndexPath indexPathForRow:1 inSection:1];

NSComparisonResult r1= [p1 compare:p2];

NSLog(@"p1 compare p2 = %@", r1==NSOrderedSame?@"YES":@"NO" );

[s addObject:p1];

NSLog(@"contain p1 =%@", [s containsObject:p1]==YES?@"YES":@"NO" );
NSLog(@"contain p2 =%@", [s containsObject:p2]==YES?@"YES":@"NO" );
NSLog(@"s = %@",s);

結果

2014-01-08 04:42:57.477 test[28342:70b] p1 compare p2 = YES
2014-01-08 04:42:57.478 test[28342:70b] contain p1 =YES
2014-01-08 04:42:57.478 test[28342:70b] contain p2 =YES
2014-01-08 04:42:57.479 test[28342:70b] s = {(
    <NSIndexPath: 0x8b2e0d0> {length = 2, path = 1 - 1}
)}
4

2 に答える 2

1

小さな NSIndexPath カテゴリの修正

@interface NSIndexPath (Extended)
-(NSUInteger)hash;
@end


@implementation NSIndexPath (Extended)
-(NSUInteger)hash{
    char str[11];
    int row = self.row;
    int section = self.section;
    sprintf(str, "%d%d", section,row);

    unsigned int val = 0;
    char *p;
    int i;
    p = str;
    for(i = 0; p[ i ]; i++){
        if (i ==0) {
            val = (unsigned char)p[i] << CHAR_BIT;
        }
        else
            val |= (unsigned char)p[i];
    }
    return val;
}
@end
于 2014-01-08T03:53:27.190 に答える
0

私は同じ問題を抱えていました。セットをフィルタリングすることで解決しました。どちらがより効率的かはわかりませんが、これは私の目的には十分なパフォーマンスでした。コードは heightForRowAtIndexPath への呼び出しからのものです

NSSet * set = [self.hiddenPaths filteredSetUsingPredicate:[NSPredicate predicateWithFormat:@"section == %u AND row == %u",indexPath.section, indexPath.row]];

if (![set count])
{
  return 0.0f;//cell at indexPath is hidden
}
于 2014-01-17T15:57:37.997 に答える