質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.51%

  • iOS

    4679questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

UICollectionviewCellをアニメーション付きでxibを入れ替えたい

受付中

回答 0

投稿

  • 評価
  • クリップ 0
  • VIEW 1,061

SatoTakeshiX

score 106

UICollectionViewのCellのカスタムセルをXibで作りました。
CustomCollectionViewCell.xibとSecondCollectionViewCell.xibの2つです。
カスタムセルのCustomCollectionViewCell.xibにはUIButtonを配置して、タップしたらSecondCollectionViewCell.xibにビューを入れ替えたいと思っています。
ボタンをタップしたら、indexPathを精査して、データソースのフラグをYesにしてreloadDataを行えば、ビューの入れ替えをすることができました。
このXibのビューの入れ替えをアニメーション付きで行いたいのですが、
どのような方向性で実装すればいいのかが検討つかない状態です。
お知恵をお借りしたいと思うのでよろしくお願い致します。

@interface ViewController ()
@property (weak, nonatomic) IBOutlet UICollectionView *myCollection;
@property NSMutableArray *dataArray;

@end
@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    
    self.myCollection.dataSource = self;
    self.myCollection.delegate  = self;
    
    self.dataArray = [NSMutableArray array];
    
    for (int i = 0; i < 9; i++) {
        
        NSMutableDictionary *dic = [@{
                                      @"isSelected" : [NSNumber numberWithBool:NO],
                                      @"buttonText" : @"tap me !"
                                      } mutableCopy];
        
        [self.dataArray addObject:dic];
    }
//Xibの登録
     [self.myCollection registerNib:[UINib nibWithNibName:@"CustomCollectionViewCell" bundle:nil] forCellWithReuseIdentifier:@"samplecell"];
     [self.myCollection registerNib:[UINib nibWithNibName:@"SecondCollectionViewCell" bundle:nil] forCellWithReuseIdentifier:@"secondCell"];
}

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

- (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath {

//データソースの配列をみて、isSelectedの真偽値によってxibのセルを分ける
    UICollectionViewCell *cell = nil;
    
    BOOL b = [[self.dataArray[indexPath.row] objectForKey:@"isSelected"] boolValue];
    

       SecondCollectionViewCell *secondcell = [collectionView dequeueReusableCellWithReuseIdentifier:@"secondCell" forIndexPath:indexPath];
        secondcell.backgroundColor = [UIColor redColor];
    

       CustomCollectionViewCell *firstcell = [collectionView dequeueReusableCellWithReuseIdentifier:@"samplecell" forIndexPath:indexPath];
            firstcell.backgroundColor = [UIColor greenColor];
       ;
        NSString *str =[self.dataArray[indexPath.row] objectForKey:@"buttonText"];
        
        firstcell.buttonInCell.titleLabel.text = str;
        
        [firstcell.buttonInCell addTarget:self action:@selector(handleTouchButton: event:) forControlEvents:UIControlEventTouchUpInside];


    if (!secondcell && !firstcell) {
        return cell;
    }else if (b){
        return secondcell;
        
    }else{
        return firstcell;
    }
}

- (CGSize)collectionView:(UICollectionView *)collectionView
                  layout:(UICollectionViewLayout*)collectionViewLayout
  sizeForItemAtIndexPath:(NSIndexPath *)indexPath;
{
//データソースの"isSelected"によって高さを変化させる
    CGSize cellSize = CGSizeMake(self.myCollection.frame.size.width, 44);

        
    NSNumber *isSecelecell = [self.dataArray[indexPath.row] objectForKey:@"isSelected"];
    
    BOOL isSe = [isSecelecell boolValue];
    
    if (isSe) {
        cellSize = CGSizeMake(self.myCollection.frame.size.width, 156);

    }
    return cellSize;
}

- (void)handleTouchButton:(UIButton *)sender event:(UIEvent *)event {
//ボタンタップでそのセルのindexPathを取得
    NSIndexPath *selectedIndexPath = nil;
    selectedIndexPath = [self.myCollection indexPathForItemAtPoint:[self.myCollection convertPoint:sender.center fromView:sender.superview]];
    NSNumber *nsBool = [self.dataArray[selectedIndexPath.row] valueForKey:@"isSelected"];
    
    
    BOOL b = [nsBool boolValue];
    
    if (!b) {
        b = YES;
           [self.dataArray[selectedIndexPath.row] setObject:[NSNumber numberWithBool:b] forKey:@"isSelected"];
    }
    
    [self.myCollection reloadData];
    
}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

同じタグがついた質問を見る

  • iOS

    4679questions

    iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。