How can I customize the selection state of my UICollectionViewCell subclass?

前端 未结 5 1984
再見小時候
再見小時候 2021-02-01 04:02

I have a custom UICollectionViewCell subclass that overwrites initWithFrame: and layoutSubviews to setup its views. However, I\'m now trying to do two

相关标签:
5条回答
  • 2021-02-01 04:23

    Add a public method performSelectionAnimations to the definition of MyCollectionViewCell that changes the desired UIImageView and performs the desired animation. Then call it from collectionView:didSelectItemAtIndexPath:.

    So in MyCollectionViewCell.m:

    - (void)performSelectionAnimations {
        // Swap the UIImageView
        ...
    
        // Light bounce animation
        ...
    }
    

    And in your UICollectionViewController:

    - (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath {
        MyCollectionViewCell *cell = (MyCollectionViewCell *)[collectionView cellForItemAtIndexPath:indexPath];
        [cell performSelectionAnimations];
    }
    

    Notice I've taken out the call to [cell setSelected:YES], since that should already be taken care of by the UICollectionView. From the documentation:

    The preferred way to select the cell and highlight it is to use the selection methods of the collection view object.

    0 讨论(0)
  • 2021-02-01 04:32

    In your custom UICollectionViewCell subclass, you can implement didSet on the isSelected property.

    Swift 3:

    override var isSelected: Bool {
        didSet {
            if isSelected {
                // animate selection
            } else {
                // animate deselection
            }
        }
    }
    

    Swift 2:

    override var selected: Bool {
        didSet {
            if self.selected {
                // animate selection
            } else {
                // animate deselection
            }
        }
    }
    
    0 讨论(0)
  • 2021-02-01 04:34

    If you want to show animation on selection then following method might helpful to you :

     - (void)collectionView:(UICollectionView *)collectionView didSelectItemAtIndexPath:(NSIndexPath *)indexPath {
         NSLog(@"cell #%d was selected", indexPath.row);
    
    
         // animate the cell user tapped on
         UICollectionViewCell  *cell = [collectionView cellForItemAtIndexPath:indexPath];
    
         [UIView animateWithDuration:0.8
                               delay:0
                             options:(UIViewAnimationOptionAllowUserInteraction)
                          animations:^{
                              [cell setBackgroundColor:UIColorFromRGB(0x05668d)];
                          }
                          completion:^(BOOL finished){
                              [cell setBackgroundColor:[UIColor clearColor]];
                          }
          ];
    
    
     }
    
    0 讨论(0)
  • 2021-02-01 04:36

    In your custom UICollectionViewCell subclass you could override the setSelected: as so:

    - (void)setSelected:(BOOL)selected {
        [super setSelected:selected];
    
        if (selected) {
            [self animateSelection];
        } else {
            [self animateDeselection];
        }
    }
    

    I have found that on repeated touches this method is called on a cell even if it's already selected so you may want to just check that you are really changing state before firing unwanted animations.

    0 讨论(0)
  • 2021-02-01 04:45

    Should not mess with state when overridden in this way:

    override var isSelected: Bool {
    
        get {
            return super.isSelected
        }
    
        set {
            super.isSelected = newValue
            .
            .
            .
        }
    }
    
    0 讨论(0)
提交回复
热议问题