2014-10-10 17 views
6

ho vista UICollection a lavorare con sé dimensionamento celle come indicato sul WWDC 2014.UICollectionView con selfsizing cellule non calcolare correttamente contentSize

voglio metterlo all'interno di un UITableViewCell e visualizzare una nuvola di tag (buon riferimento di quello che ho voglio raggiungere è in applicazione Foursquare: http://i59.tinypic.com/sxd9qf.png)

Il mio problema è che con celle di dimensionamento automatico, la dimensione del contenuto non viene restituita correttamente. ho preparato qualche rapido demo per mostrare il problema:

- (void)viewDidLoad 
{ 
    [super viewDidLoad]; 

    self.elements = [NSMutableArray array]; 
    for (int i = 0; i < 23; i++) 
    { 
     [self.elements addObject:[self randomString]]; 
    } 

    UICollectionViewFlowLayout* layout = [[UICollectionViewFlowLayout alloc] init]; 
    layout.estimatedItemSize = CGSizeMake(50, 30); 

    self.collectionView=[[UICollectionView alloc] initWithFrame:self.view.frame collectionViewLayout:layout]; 
    [self.collectionView setDataSource:self]; 
    [self.collectionView setDelegate:self]; 

    UINib *cellNib = [UINib nibWithNibName:@"CustomCell" bundle:nil]; 
    [self.collectionView registerNib:cellNib forCellWithReuseIdentifier:@"CustomCell"]; 
    [self.collectionView setBackgroundColor:[UIColor blueColor]]; 
    [self.view addSubview:self.collectionView]; 
} 

- (void) viewDidAppear:(BOOL)animated 
{ 
    [super viewDidAppear:animated]; 

    self.collectionView.frame = CGRectMake(0, 0, self.collectionView.frame.size.width, self.collectionView.contentSize.height); 
} 

- (NSInteger)collectionView:(UICollectionView *)collectionView numberOfItemsInSection:(NSInteger)section 
{ 
    return [self.elements count]; 
} 

- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath 
{ 
    CustomCell* cell=[collectionView dequeueReusableCellWithReuseIdentifier:@"CustomCell" forIndexPath:indexPath]; 
    cell.customLabel.text = [self.elements objectAtIndex:[indexPath row]]; 
    return cell; 
} 

quando lo faccio modo vecchio e rimuovere estimatedItemSize e utilizzare ItemSize invece o metodo delegato per calcolare una dimensione - funziona correttamente, quindi penso che sta usando estimatedItem dimensione per ottenere la dimensione del contenuto.

C'è un modo per farlo funzionare con celle di dimensionamento automatico e autorizzare UICollectionView al suo contenuto?

+1

err ... So che non sta aiutando, ma per il momento raccomanderei di non utilizzare la cella di auto-dimensionamento nelle viste di raccolta. Sembra che Apple abbia fatto un lavoro non proprio eccezionale implementando questi https://devforums.apple.com/search.jspa?resultTypes=MESSAGE&peopleEnabled=true&q=self-sizing. –

+0

Quindi quale sarà il modo di implementarlo come lo voglio? :) Anche con le calibri manuali ho un problema con la previsione di quanto spazio ho bisogno per UICollectionView per visualizzarne il contenuto - Ho bisogno di previsione per UITableViewCell height :) –

risposta

1

ho finito per calcolare le dimensioni per conto mio:

- (CGSize) sizeForCellAtIndexPath:(NSIndexPath*) indexPath isMoreButton:(BOOL) isMoreButton 
{ 
    TagCell* cell = (TagCell*) [[LayoutHelper sharedLayoutHelper] collectionCellFromNib:@"TagCell"]; 
    cell.tagLabel.text = [self.contactHashTags objectAtIndex:indexPath.row]; 
    CGSize size = [cell systemLayoutSizeFittingSize:UILayoutFittingCompressedSize]; 
    CGSizeMake(size.width, cell.frame.size.height); 
} 

- (CGSize) sizeForCellAtIndexPath:(NSIndexPath*) indexPath isMoreButton:(BOOL) isMoreButton 
{ 
    CGSize size = [self.dataSource sizeForCellAtIndexPath:indexPath isMoreButton:isMoreButton]; 

    //limit cell to view width 
    size.width = MIN(size.width, self.frame.size.width); 
    return size; 
} 
+1

FWIW, anche in iOS 10 Ho lo stesso problema con le celle auto-dimensionamento. Nel prossimo runloop la dimensione è corretta. Il dimensionamento manuale è l'unica soluzione. –

1

mia soluzione ... aggiungere un inserto al volo.

func collectionView(_ collectionView: UICollectionView, willDisplay cell: UICollectionViewCell, forItemAt indexPath: IndexPath) { 
    let isLastItem = indexPath.item == (collectionView.numberOfItems(inSection: indexPath.section) - 1) 
    guard isLastItem else { 
     return 
    } 

    DispatchQueue.main.async { 
     let inset = (cell.frame.maxX - collectionView.contentSize.width) + 10 // 10 is the right padding I want for my horizontal scroll 
     collectionView.contentInset = UIEdgeInsets(top: 0.0, left: 0.0, bottom: 0.0, right: inset) 
    } 
} 
Problemi correlati