Spécifiez le numéro de ligne et de colonne pour UICollectionView
Je veux montrer un UICollectionView qui contient exactement 2 lignes et 100 cellules dans chaque ligne.
// 1
- (NSInteger)collectionView:(UICollectionView *)view numberOfItemsInSection:(NSInteger)section {
return 100;
}
// 2
- (NSInteger)numberOfSectionsInCollectionView: (UICollectionView *)collectionView {
return 2;
}
// 3
- (UICollectionViewCell *)collectionView:(UICollectionView *)cv cellForItemAtIndexPath:(NSIndexPath *)indexPath {
MyCell *cell = [cv dequeueReusableCellWithReuseIdentifier:@"cell" forIndexPath:indexPath];
cell.lbl.text = @"Data";
return cell;
}
Je reçois ceci:
Comment puis-je spécifier un numéro de ligne pour UICollectionView? Je veux créer une table 2x100.
Essaye ça:
// 1
- (NSInteger)collectionView:(UICollectionView *)view numberOfItemsInSection:(NSInteger)section {
return 2;
}
// 2
- (NSInteger)numberOfSectionsInCollectionView: (UICollectionView *)collectionView {
return 100;
}
// 3
- (UICollectionViewCell *)collectionView:(UICollectionView *)cv cellForItemAtIndexPath:(NSIndexPath *)indexPath {
MyCell *cell = [cv dequeueReusableCellWithReuseIdentifier:@"cell" forIndexPath:indexPath];
cell.lbl.text = @"Data";
return cell;
}
Pour 3 cellules par ligne. Ajoutez ce code.
- (CGSize)collectionView:(UICollectionView *)collectionView layout:(UICollectionViewLayout *)collectionViewLayout sizeForItemAtIndexPath:(NSIndexPath *)indexPath
{
return CGSizeMake(collectionView.frame.size.width/3.2 , 100);
}
L'approche la plus générale pour réaliser n colonnes dans la vue de collection qui est compatible dans n'importe quelle orientation est
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAtIndexPath indexPath: NSIndexPath) -> CGSize {
// flow layout have all the important info like spacing, inset of collection view cell, fetch it to find out the attributes specified in xib file
guard let flowLayout = collectionViewLayout as? UICollectionViewFlowLayout else {
return CGSize()
}
// subtract section left/ right insets mentioned in xib view
let widthAvailbleForAllItems = (collectionView.frame.width - flowLayout.sectionInset.left - flowLayout.sectionInset.right)
// Suppose we have to create nColunmns
// widthForOneItem achieved by sunbtracting item spacing if any
let widthForOneItem = widthAvailbleForAllItems / nColumns - flowLayout.minimumInteritemSpacing
// here height is mentioned in xib file or storyboard
return CGSize(width: CGFloat(widthForOneItem), height: (flowLayout.itemSize.height))
}
Pour Swift: lignes par colonne (En utilisant @SakhshiSingla Answer)
override func numberOfSectionsInCollectionView(collectionView: UICollectionView) -> Int {
return 1
}
override func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
return 3
}
func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAtIndexPath indexPath: NSIndexPath) -> CGSize
{
return CGSize(width: collectionView.frame.size.width/3.2, height: 100)
}
Le nombre de sections détermine le nombre de cellules dans chaque ligne, en supposant que la taille des cellules le permet.
Une section commencera toujours une nouvelle ligne.