UICollectionView adding image to a cell

后端 未结 2 1839
自闭症患者
自闭症患者 2020-11-28 12:28

I\'m working on a project which uses UICollectionView to display data which may or may not have an image.

The way I\'m using is to check if the image ur

相关标签:
2条回答
  • 2020-11-28 12:42

    Code for Swift 4

    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {   
        return 1   
    }
    
    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "cell", for: indexPath)
    
        var imageview:UIImageView=UIImageView(frame: CGRect(x: 50, y: 50, width: 200, height: 200));
    
            var img : UIImage = UIImage(named:"Your image name")
            imageview.image = img
    
            cell.contentView.addSubview(imageview)
    
        }
    
        return cell
    }
    
    func collectionView(collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAtIndexPath indexPath: NSIndexPath) -> CGSize {
        return CGSize(width: 50, height: 414)
    }
    
    0 讨论(0)
  • 2020-11-28 12:57

    First of all, the way you add images in your cell is pretty dangerous. The reason is that your cells are being reused (for exemple when you scroll, or when you reloadData), and these images are never removed on reuse. So you will start seing them everywhere, and you can even get to the point where your cell contains multiple occurrences of the image. Here are two ways to do it :

    • First way (the good way) : You subclass your UICollectionViewCell, and give the subclass an "imageView" property. Then you do this in your CustomCollectionViewCell.m file :

      // Lazy loading of the imageView
      - (UIImageView *) imageView
      {
          if (!_imageView) {
              _imageView = [[UIImageView alloc] initWithFrame:self.contentView.bounds];
              [self.contentView addSubview:_imageView];
           }
           return _imageView;
       }
      
      // Here we remove all the custom stuff that we added to our subclassed cell
      -(void)prepareForReuse
      {
          [super prepareForReuse];
      
          [self.imageView removeFromSuperview];
          self.imageView = nil;
      }
      

      Then in your ViewController your have to declare the new class of your collectionViewCells like this :

      [self.collectionView registerClass:[CustomCollectionViewCell class] forCellWithReuseIdentifier:@"cell"];
      

      It will ensure that the images are correctly removed on reuse, plus it's way easier to setup the cell in your collectionView delegate.

    • Second way (The dirty way), you remove the views every time you load a new cell :

      - (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView                 cellForItemAtIndexPath:(NSIndexPath *)indexPath
      {
          for (UIView *subview in [cell.contentView subviews]) {
              [subview removeFromSuperview];
          }
      
          if (question.picture != (id)[NSNull null]) {
              //add AsyncImageView to cell
              imageView.contentMode = UIViewContentModeScaleAspectFill;
              imageView.clipsToBounds = YES;
              imageView.tag = IMAGE_VIEW_TAG;
              [cell.contentView addSubview:imageView];
              [[AsyncImageLoader sharedLoader] cancelLoadingImagesForTarget:imageView];
              imageView.imageURL = [NSURL URLWithString:question.picture];
          }
      }
      

      This way is far easier but i wouldn't recommend it :P

    Now try this and let me know how your bug evolves.

    0 讨论(0)
提交回复
热议问题