IOS遊戲開發之五子棋OC版_IOS

來源:互聯網
上載者:User

先上效果圖

- 功能展示

- 初進階棋盤轉場效果

實現思路及主要代碼詳解

1.繪製棋盤

利用Quartz2D繪製棋盤.代碼如下

- (void)drawBackground:(CGSize)size{         self.gridWidth = (size.width - 2 * kBoardSpace) / self.gridCount;         //1.開啟映像上下文    UIGraphicsBeginImageContext(size);    //2.擷取上下文    CGContextRef ctx = UIGraphicsGetCurrentContext();         CGContextSetLineWidth(ctx, 0.8f);    //3.1 畫16條豎線    for (int i = 0; i <= self.gridCount; i ++) {      CGContextMoveToPoint(ctx, kBoardSpace + i * self.gridWidth , kBoardSpace);      CGContextAddLineToPoint(ctx, kBoardSpace + i * self.gridWidth , kBoardSpace + self.gridCount * self.gridWidth);    }    //3.1 畫16條橫線    for (int i = 0; i <= self.gridCount; i ++) {      CGContextMoveToPoint(ctx, kBoardSpace, kBoardSpace + i * self.gridWidth );      CGContextAddLineToPoint(ctx, kBoardSpace + self.gridCount * self.gridWidth , kBoardSpace + i * self.gridWidth);    }    CGContextStrokePath(ctx);         //4.擷取產生的圖片    UIImage *image=UIGraphicsGetImageFromCurrentImageContext();    //5.顯示產生的圖片到imageview    UIImageView * imageView = [[UIImageView alloc]initWithImage:image];    [self addSubview:imageView];    UIGraphicsEndImageContext();}

2.點擊棋盤落子

     1)根據落子位置求出該棋子的行號與列號.

     2)判斷落子位置是否已經有棋子,有則不能下.如果沒有,將棋子儲存在字典中,以列號和行號組合起來的字串為key值.

代碼如下:

//點擊棋盤,下棋  - (void)tapBoard:(UITapGestureRecognizer *)tap{       CGPoint point = [tap locationInView:tap.view];    //計算下子的列號行號    NSInteger col = (point.x - kBoardSpace + 0.5 * self.gridWidth) / self.gridWidth;    NSInteger row = (point.y - kBoardSpace + 0.5 * self.gridWidth) / self.gridWidth;    NSString * key = [NSString stringWithFormat:@"%ld-%ld",col,row];    if (![self.chessmanDict.allKeys containsObject:key]) {      UIView * chessman = [self chessman];      chessman.center = CGPointMake(kBoardSpace + col * self.gridWidth, kBoardSpace + row * self.gridWidth);      [self addSubview:chessman];      [self.chessmanDict setValue:chessman forKey:key];      self.lastKey = key;      //檢查遊戲結果      [self checkResult:col andRow:row andColor:self.isBlack];      self.isBlack = !self.isBlack;    }  }

3.檢測遊戲結果

每落一個棋子就要多遊戲結果進行一次檢查,判斷四個方向上是否有大於等於5個同色的棋子連成一線,有則提示遊戲輸贏結果,無則遊戲繼續.演算法為,從當前棋子位置向前遍曆,直到遇到與自己不同色的棋子,累加同色棋子的個數,再往後遍曆,直到遇到與自己不同色的棋子,累加同色棋子的個數.得到該方向相連同色棋子的總個數

代碼如下

//判斷是否大於等於五個同色相連  - (BOOL)checkResult:(NSInteger)col andRow:(NSInteger)row andColor:(BOOL)isBlack andDirection:(GmkDirection)direction{       if (self.sameChessmanArray.count >= 5) {      return YES;    }    UIColor * currentChessmanColor = [self.chessmanDict[[NSString stringWithFormat:@"%ld-%ld",col,row]] backgroundColor];    [self.sameChessmanArray addObject:self.chessmanDict[self.lastKey]];    switch (direction) {      //水平方向檢查結果      case GmkHorizontal:{        //向前遍曆        for (NSInteger i = col - 1; i > 0; i --) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",i,row];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        //向後遍曆        for (NSInteger i = col + 1; i < kGridCount; i ++) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",i,row];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        if (self.sameChessmanArray.count >= 5) {          [self alertResult];          return YES;        }        [self.sameChessmanArray removeAllObjects];               }        break;      case GmkVertical:{        //向前遍曆        for (NSInteger i = row - 1; i > 0; i --) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",col,i];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        //向後遍曆        for (NSInteger i = row + 1; i < kGridCount; i ++) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",col,i];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        if (self.sameChessmanArray.count >= 5) {          [self alertResult];          return YES;        }        [self.sameChessmanArray removeAllObjects];               }        break;      case GmkObliqueDown:{                 //向前遍曆        NSInteger j = col - 1;        for (NSInteger i = row - 1; i >= 0; i--,j--) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",j,i];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor || j < 0) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        //向後遍曆        j = col + 1;        for (NSInteger i = row + 1 ; i < kGridCount; i++,j++) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",j,i];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor || j > kGridCount) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        if (self.sameChessmanArray.count >= 5) {          [self alertResult];          return YES;        }        [self.sameChessmanArray removeAllObjects];                      }        break;      case GmkObliqueUp:{        //向前遍曆        NSInteger j = col + 1;        for (NSInteger i = row - 1; i >= 0; i--,j++) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",j,i];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor || j > kGridCount) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        //向後遍曆        j = col - 1;        for (NSInteger i = row + 1 ; i < kGridCount; i++,j--) {          NSString * key = [NSString stringWithFormat:@"%ld-%ld",j,i];          if (![self.chessmanDict.allKeys containsObject:key] || [self.chessmanDict[key] backgroundColor] != currentChessmanColor || j < 0) break;          [self.sameChessmanArray addObject:self.chessmanDict[key]];        }        if (self.sameChessmanArray.count >= 5) {          [self alertResult];          return YES;        }        [self.sameChessmanArray removeAllObjects];               }        break;    }    return NO;  }

對外提供,重新開始,悔棋,切換初進階棋盤的三個介面

重新開始

- (void)newGame{         self.isOver = NO;    self.lastKey = nil;    [self.sameChessmanArray removeAllObjects];    self.userInteractionEnabled = YES;    [self.chessmanDict removeAllObjects];    for (UIView * view in self.subviews) {      if ([view isKindOfClass:[UIImageView class]]) {        continue;      }      [view removeFromSuperview];    }    self.isBlack = NO;  }

悔棋

//撤回至上一步棋  - (void)backOneStep:(UIButton *)sender{       if(self.isOver) return;         if (self.lastKey == nil) {      sender.enabled = NO;      CGFloat width = SCREEN_WIDTH * 0.4 * SCREEN_WIDTH_RATIO;      UIView * tip = [[UIView alloc]initWithFrame:CGRectMake(0, 0, width, 0.6 * width)];      tip.backgroundColor = [UIColor colorWithWhite:1 alpha:0.8];      tip.layer.cornerRadius = 8.0f;      [self addSubview:tip];      tip.center = CGPointMake(self.width * 0.5, self.height * 0.5);      UILabel * label = [[UILabel alloc]init];      label.text = self.chessmanDict.count > 0 ? @"只能悔一步棋!!!" : @"請先落子!!!";      label.font = [UIFont systemFontOfSize:15];      [label sizeToFit];      label.center = CGPointMake(tip.width * 0.5, tip.height * 0.5);      [tip addSubview:label];             self.userInteractionEnabled = NO;      dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(2.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{        self.userInteractionEnabled = YES;        sender.enabled = YES;        [tip removeFromSuperview];               });      return;    }    [self.chessmanDict removeObjectForKey:self.lastKey];    [self.subviews.lastObject removeFromSuperview];    self.isBlack = !self.isBlack;    self.lastKey = nil;  }

切換初進階鍵盤

//改變鍵盤層級  - (void)changeBoardLevel{         for (UIView * view in self.subviews) {      [view removeFromSuperview];    }    [self newGame];    self.isHighLevel = !self.isHighLevel;    [self drawBackground:self.bounds.size];  }

Demo中的一個小技巧

用字典存放棋子,以棋子的列號和行號組合起來的字串為key值,value值為棋子view.這樣處理,在判斷某行某列是否有棋子就非常簡單了。

總結

以上就是iOS遊戲開發之五子棋OC版的全部內容,希望本文對大家開發IOS有所協助,如果本文有不足之處,歡迎大家提供建議和指點!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.