欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實(shí)現(xiàn)兩人五子棋游戲(六) 行棋方變換

 更新時(shí)間:2018年03月27日 08:34:52   作者:v_xchen_v  
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)一個(gè)簡(jiǎn)單的兩人五子棋游戲,行棋方變換,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

之前的兩篇文章:Java實(shí)現(xiàn)兩人五子棋游戲(二) 畫(huà)出棋盤(pán);Java實(shí)現(xiàn)兩人五子棋游戲(三) 畫(huà)出棋子;Java實(shí)現(xiàn)兩人五子棋游戲(四) 落子動(dòng)作的實(shí)現(xiàn),可以點(diǎn)擊查看。

前面我們已經(jīng)畫(huà)好棋盤(pán)和棋子,并可以自由落子,且可以判斷棋盤(pán)中是否有五連珠。接下來(lái)的工作是,每次落子后交換行棋方(即將下一棋子顏色由白->黑或黑->白),并將勝出判斷增加顏色判斷條件(棋盤(pán)上存在五連珠->棋盤(pán)上存在同色的五連珠)。

主模塊Main.java和棋子類(lèi)Chessman.java不變,我們要對(duì)DrawChessBoard.java中的落子函數(shù)mousePressed和五連珠判斷函數(shù)isWin做一下調(diào)整。

Main.java

package xchen.test.simpleGobang; 
 
import java.awt.Container; 
import javax.swing.JFrame; 
 
import xchen.test.simpleGobang.DrawChessBoard; 
 
public class Main extends JFrame{ 
  private DrawChessBoard drawChessBoard; 
  public Main() {    
    drawChessBoard = new DrawChessBoard(); 
     
    //Frame標(biāo)題 
    setTitle("單機(jī)五子棋"); 
     
    Container containerPane =getContentPane(); 
    containerPane.add(drawChessBoard);    
  } 
  public static void main(String[] args) { 
    Main m = new Main(); 
    m.setSize(800, 800); 
    m.setVisible(true); 
  } 
} 

Chessman.java

package xchen.test.simpleGobang; 
 
public class Chessman { 
  private int color;//1-white,0-black 
  private boolean placed = false; 
  int matchCount = 1; 
   
  public Chessman(int color,boolean placed){ 
    this.color=color; 
    this.placed=placed; 
  } 
   
  public boolean getPlaced() { 
    return placed; 
  } 
 
  public void setPlaced(boolean placed) { 
    this.placed = placed; 
  } 
 
  public int getColor() { 
    return color; 
  } 
 
  public void setColor(int color) { 
    this.color = color; 
  } 
} 

第一步,修改mousePressed函數(shù),使得每次落子后,都將行棋方讓給對(duì)家(即每次落子都改變棋子顏色)

DrawChessBoard.java中的mousePressed函數(shù)部分,只要每次都修改chessColor的值即可。

@Override 
//當(dāng)用戶(hù)按下鼠標(biāo)按鈕時(shí)發(fā)生 
public void mousePressed(MouseEvent e) { 
  int point_x=e.getX(); 
  int point_y=e.getY(); 
 
  int imgWidth = boardImg.getHeight(this); 
  int imgHeight = boardImg.getWidth(this); 
  int FWidth = getWidth(); 
  int FHeight= getHeight(); 
 
  int x=(FWidth-imgWidth)/2; 
  int y=(FHeight-imgHeight)/2; 
 
  int span_x=imgWidth/ROWS; 
  int span_y=imgHeight/ROWS; 
 
  //System.out.println("press"); 
  int status_x = 0; 
  int status_y = 0; 
  if(point_x>=x && point_x<=x+imgWidth && point_y>=y && point_y <= y+imgHeight) 
  { 
    //System.out.println("合法"); 
    for(int i=0;i<ROWS+1;i++) 
    { 
      if(point_x>=x-chessman_width/2+1+i*span_x) 
      { 
        if(point_x<=x+chessman_width/2-1+i*span_x)//如果是width/2會(huì)在中間點(diǎn)出現(xiàn)兩個(gè)匹配值 
        { 
          //System.out.println("point x "+i+" "+point_x+" "+(x-chessman_width/2+i*span_x)+" "+(x+chessman_width/2+i*span_x)); 
          status_x = i; 
        } 
      } 
    } 
    for(int i=0;i<ROWS+1;i++) 
    { 
      if(point_y>=y-chessman_width/2+1+i*span_y) 
      { 
        if(point_y <= y+chessman_width/2-1+i*span_y) 
        { 
          //System.out.println("point y "+i+" "+point_y+" "+(y-chessman_width/2+1+i*span_y)+" "+(y+chessman_width/2-1+i*span_y)); 
          status_y = i; 
        } 
      } 
    } 
     
    Chessman chessman = new Chessman(chessColor, true); 
    chessStatus[status_x][status_y]=chessman; 
    System.out.println("chess color:"+chessColor); 
    if(chessColor==BLACK) 
    { 
      chessColor = WHITE; 
    }else { 
      chessColor = BLACK; 
    } 
    repaint(); 
    if(isWin(status_x, status_y, chessStatus)) 
    { 
      System.out.println("WIN!!!!!"); 
    } 
  } 
} 

運(yùn)行一下

第二步,將勝出判斷增加顏色判斷條件(棋盤(pán)上存在五連珠->棋盤(pán)上存在同色的五連珠)

在isWin函數(shù)的判斷條件上,加上對(duì)Chessman.getColor的顏色判斷

isWin函數(shù)代碼

boolean isWin(int point_x,int point_y,Chessman[][] cm) 
{   
  for(int i=0;i<ROWS+1;i++) 
  { 
    for(int j=0;j<ROWS+1;j++) 
    { 
      //橫向查找 
      if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
      { 
        int matchColor = chessStatus[i][j].getColor(); 
        //向右側(cè)查找 
        for(int n=1;n<=4;n++) 
        { 
          if((i+n>=0)&&(i+n)<=ROWS) 
          { 
            if(chessStatus[i+n][j]!=null&&chessStatus[i+n][j].getPlaced()==true&&chessStatus[i+n][j].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" right count++:"+(i+n)+" "+j+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              break; 
            }   
          } 
        } 
        //向左側(cè)查找 
        for(int n=1;n<=4;n++) 
        { 
          if((i-n>=0)&&(i-n)<=ROWS) 
          { 
            if(chessStatus[i-n][j]!=null&&chessStatus[i-n][j].getPlaced()==true&&chessStatus[i-n][j].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i-n)+" "+j+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              if(chessStatus[i-n][j]!=null) 
              { 
                chessStatus[i][j].matchCount = 1; 
              } 
              break; 
            } 
          } 
        } 
        chessStatus[i][j].matchCount=1;//refresh count 
      } 
    } 
  } 
 
  for(int i=0;i<ROWS+1;i++) 
  { 
    for(int j=0;j<ROWS+1;j++) 
    { 
      //縱向 
      if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
      { 
        int matchColor = chessStatus[i][j].getColor(); 
        //向下查找,左上角為坐標(biāo)原點(diǎn),y軸正方向向下 
        for(int n=1;n<=4;n++) 
        { 
          if((j+n>=0)&&(j+n)<=ROWS) 
          { 
            if(chessStatus[i][j+n]!=null&&chessStatus[i][j+n].getPlaced()==true&&chessStatus[i][j+n].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" up count++:"+(i)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              break; 
            }   
          } 
        } 
        //向上查找 
        for(int n=1;n<=4;n++) 
        { 
          if((j-n>=0)&&(j-n)<=ROWS) 
          { 
            if(chessStatus[i][j-n]!=null&&chessStatus[i][j-n].getPlaced()==true&&chessStatus[i][j-n].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              if(chessStatus[i][j-n]!=null) 
              { 
                chessStatus[i][j].matchCount = 1; 
              } 
              break; 
            } 
          } 
        } 
        chessStatus[i][j].matchCount=1;//refresh count 
      } 
    } 
  } 
 
  //方向:左上右下 
  for(int i=0;i<ROWS+1;i++) 
  { 
    for(int j=0;j<ROWS+1;j++) 
    { 
      //左上 
      if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
      { 
        int matchColor = chessStatus[i][j].getColor(); 
        //向下查找,左上角為坐標(biāo)原點(diǎn),y軸正方向向下 
        for(int n=1;n<=4;n++) 
        { 
          if((j-n>=0)&&(j-n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS) 
          { 
            if(chessStatus[i-n][j-n]!=null&&chessStatus[i-n][j-n].getPlaced()==true&&chessStatus[i-n][j-n].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              break; 
            }   
          } 
        } 
        //右下 
        for(int n=1;n<=4;n++) 
        { 
          if((j+n>=0)&&(j+n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS) 
          { 
            if(chessStatus[i+n][j+n]!=null&&chessStatus[i+n][j+n].getPlaced()==true&&chessStatus[i+n][j+n].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              if(chessStatus[i+n][j+n]!=null) 
              { 
                chessStatus[i][j].matchCount = 1; 
              } 
              break; 
            } 
          } 
        } 
        chessStatus[i][j].matchCount=1;//refresh count 
      } 
    } 
  } 
 
  //方向:左下右上 
  for(int i=0;i<ROWS+1;i++) 
  { 
    for(int j=0;j<ROWS+1;j++) 
    { 
      //左下 
      if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
      { 
        int matchColor = chessStatus[i][j].getColor(); 
        //向下查找,左上角為坐標(biāo)原點(diǎn),y軸正方向向下 
        for(int n=1;n<=4;n++) 
        { 
          if((j+n>=0)&&(j+n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS) 
          { 
            if(chessStatus[i-n][j+n]!=null&&chessStatus[i-n][j+n].getPlaced()==true&&chessStatus[i-n][j+n].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              break; 
            }   
          } 
        } 
        //右上 
        for(int n=1;n<=4;n++) 
        { 
          if((j-n>=0)&&(j-n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS) 
          { 
            if(chessStatus[i+n][j-n]!=null&&chessStatus[i+n][j-n].getPlaced()==true&&chessStatus[i+n][j-n].getColor()==matchColor) 
            { 
              chessStatus[i][j].matchCount++; 
              System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount); 
              if(chessStatus[i][j].matchCount==5) 
              { 
                return true; 
              } 
            }else 
            { 
              if(chessStatus[i+n][j-n]!=null) 
              { 
                chessStatus[i][j].matchCount = 1; 
              } 
              break; 
            } 
          } 
        } 
        chessStatus[i][j].matchCount=1;//refresh count 
      } 
    } 
  }     
 
  return false;   
} 

運(yùn)行一下!


完整的DrawChessBoard.java

package xchen.test.simpleGobang; 
 
import java.awt.Color; 
import java.awt.Graphics; 
import java.awt.Graphics2D; 
import java.awt.Image; 
import java.awt.RadialGradientPaint; 
import java.awt.Toolkit; 
import java.awt.event.MouseEvent; 
import java.awt.event.MouseListener; 
 
import javax.swing.JPanel; 
 
public class DrawChessBoard extends JPanel implements MouseListener{ 
  final static int BLACK=0; 
  final static int WHITE=1; 
  public int chessColor = BLACK; 
  int chessman_width=30; 
   
  public Image boardImg; 
  final private int ROWS = 19; 
  Chessman[][] chessStatus=new Chessman[ROWS+1][ROWS+1];  
 
  public DrawChessBoard() { 
    boardImg = Toolkit.getDefaultToolkit().getImage("res/drawable/chessboard2.png"); 
    if(boardImg == null) 
      System.err.println("png do not exist"); 
 
    addMouseListener(this); 
  }   
  @Override 
  protected void paintComponent(Graphics g) { 
    // TODO Auto-generated method stub 
    super.paintComponent(g); 
 
    int imgWidth = boardImg.getHeight(this); 
    int imgHeight = boardImg.getWidth(this); 
    int FWidth = getWidth(); 
    int FHeight= getHeight(); 
 
    int x=(FWidth-imgWidth)/2; 
    int y=(FHeight-imgHeight)/2; 
 
    int span_x=imgWidth/ROWS; 
    int span_y=imgHeight/ROWS; 
 
    g.drawImage(boardImg, x, y, null); 
 
    //畫(huà)橫線 
    for(int i=0;i<ROWS;i++) 
    { 
      g.drawLine(x, y+i*span_y, FWidth-x,y+i*span_y); 
    } 
    //畫(huà)豎線 
    for(int i=0;i<ROWS;i++) 
    { 
      g.drawLine(x+i*span_x, y, x+i*span_x,FHeight-y); 
    } 
 
    //畫(huà)棋子 
    for(int i=0;i<ROWS+1;i++) 
    { 
      for(int j=0;j<ROWS+1;j++) 
      { 
        if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
        { 
          //System.out.println("draw chessman "+i+" "+j); 
          int pos_x=x+i*span_x; 
          int pos_y=y+j*span_y; 
          float radius_b=40; 
          float radius_w=80; 
          float[] fractions = new float[]{0f,1f}; 
          java.awt.Color[] colors_b = new java.awt.Color[]{Color.BLACK,Color.WHITE}; 
          Color[] colors_w = new Color[]{Color.WHITE,Color.BLACK}; 
          RadialGradientPaint paint; 
          if(chessStatus[i][j].getColor()==1) 
          { 
            //System.out.println("draw white chess"); 
            paint = new RadialGradientPaint(pos_x-chessman_width/2f, pos_y-chessman_width/2f, radius_w*2, fractions, colors_w); 
          }else{ 
            //System.out.println("draw black chess"); 
            paint = new RadialGradientPaint(pos_x-chessman_width/2f, pos_y-chessman_width/2f, radius_b*2, fractions, colors_b); 
          } 
          ((Graphics2D)g).setPaint(paint); 
 
          ((Graphics2D)g).fillOval(pos_x-chessman_width/2,pos_y-chessman_width/2,chessman_width,chessman_width); 
        } 
      } 
    } 
  } 
 
  @Override 
  //當(dāng)用戶(hù)按下鼠標(biāo)按鈕時(shí)發(fā)生 
  public void mousePressed(MouseEvent e) { 
    int point_x=e.getX(); 
    int point_y=e.getY(); 
 
    int imgWidth = boardImg.getHeight(this); 
    int imgHeight = boardImg.getWidth(this); 
    int FWidth = getWidth(); 
    int FHeight= getHeight(); 
 
    int x=(FWidth-imgWidth)/2; 
    int y=(FHeight-imgHeight)/2; 
 
    int span_x=imgWidth/ROWS; 
    int span_y=imgHeight/ROWS; 
 
    //System.out.println("press"); 
    int status_x = 0; 
    int status_y = 0; 
    if(point_x>=x && point_x<=x+imgWidth && point_y>=y && point_y <= y+imgHeight) 
    { 
      //System.out.println("合法"); 
      for(int i=0;i<ROWS+1;i++) 
      { 
        if(point_x>=x-chessman_width/2+1+i*span_x) 
        { 
          if(point_x<=x+chessman_width/2-1+i*span_x)//如果是width/2會(huì)在中間點(diǎn)出現(xiàn)兩個(gè)匹配值 
          { 
            //System.out.println("point x "+i+" "+point_x+" "+(x-chessman_width/2+i*span_x)+" "+(x+chessman_width/2+i*span_x)); 
            status_x = i; 
          } 
        } 
      } 
      for(int i=0;i<ROWS+1;i++) 
      { 
        if(point_y>=y-chessman_width/2+1+i*span_y) 
        { 
          if(point_y <= y+chessman_width/2-1+i*span_y) 
          { 
            //System.out.println("point y "+i+" "+point_y+" "+(y-chessman_width/2+1+i*span_y)+" "+(y+chessman_width/2-1+i*span_y)); 
            status_y = i; 
          } 
        } 
      } 
       
      if(chessStatus[status_x][status_y]==null||chessStatus[status_x][status_y].getPlaced()==false) 
      { 
        Chessman chessman = new Chessman(chessColor, true); 
        chessStatus[status_x][status_y]=chessman; 
        System.out.println("chess color:"+chessColor); 
        if(chessColor==BLACK) 
        { 
          chessColor = WHITE; 
        }else { 
          chessColor = BLACK; 
        } 
        repaint(); 
        if(isWin(status_x, status_y, chessStatus)) 
        { 
          System.out.println("WIN!!!!!"); 
        } 
      } 
    } 
  } 
  @Override 
  //當(dāng)用戶(hù)按下并松開(kāi)鼠標(biāo)按鈕時(shí)發(fā)生 
  public void mouseClicked(MouseEvent e) { 
    // TODO Auto-generated method stub 
  } 
  @Override 
  public void mouseReleased(MouseEvent e) { 
    // TODO Auto-generated method stub 
 
  } 
  @Override 
  public void mouseEntered(MouseEvent e) { 
    // TODO Auto-generated method stub 
 
  } 
  @Override 
  public void mouseExited(MouseEvent e) { 
    // TODO Auto-generated method stub  
  } 
 
  boolean isWin(int point_x,int point_y,Chessman[][] cm) 
  {   
    for(int i=0;i<ROWS+1;i++) 
    { 
      for(int j=0;j<ROWS+1;j++) 
      { 
        //橫向查找 
        if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
        { 
          int matchColor = chessStatus[i][j].getColor(); 
          //向右側(cè)查找 
          for(int n=1;n<=4;n++) 
          { 
            if((i+n>=0)&&(i+n)<=ROWS) 
            { 
              if(chessStatus[i+n][j]!=null&&chessStatus[i+n][j].getPlaced()==true&&chessStatus[i+n][j].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" right count++:"+(i+n)+" "+j+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                break; 
              }   
            } 
          } 
          //向左側(cè)查找 
          for(int n=1;n<=4;n++) 
          { 
            if((i-n>=0)&&(i-n)<=ROWS) 
            { 
              if(chessStatus[i-n][j]!=null&&chessStatus[i-n][j].getPlaced()==true&&chessStatus[i-n][j].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i-n)+" "+j+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                if(chessStatus[i-n][j]!=null) 
                { 
                  chessStatus[i][j].matchCount = 1; 
                } 
                break; 
              } 
            } 
          } 
          chessStatus[i][j].matchCount=1;//refresh count 
        } 
      } 
    } 
 
    for(int i=0;i<ROWS+1;i++) 
    { 
      for(int j=0;j<ROWS+1;j++) 
      { 
        //縱向 
        if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
        { 
          int matchColor = chessStatus[i][j].getColor(); 
          //向下查找,左上角為坐標(biāo)原點(diǎn),y軸正方向向下 
          for(int n=1;n<=4;n++) 
          { 
            if((j+n>=0)&&(j+n)<=ROWS) 
            { 
              if(chessStatus[i][j+n]!=null&&chessStatus[i][j+n].getPlaced()==true&&chessStatus[i][j+n].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" up count++:"+(i)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                break; 
              }   
            } 
          } 
          //向上查找 
          for(int n=1;n<=4;n++) 
          { 
            if((j-n>=0)&&(j-n)<=ROWS) 
            { 
              if(chessStatus[i][j-n]!=null&&chessStatus[i][j-n].getPlaced()==true&&chessStatus[i][j-n].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                if(chessStatus[i][j-n]!=null) 
                { 
                  chessStatus[i][j].matchCount = 1; 
                } 
                break; 
              } 
            } 
          } 
          chessStatus[i][j].matchCount=1;//refresh count 
        } 
      } 
    } 
 
    //方向:左上右下 
    for(int i=0;i<ROWS+1;i++) 
    { 
      for(int j=0;j<ROWS+1;j++) 
      { 
        //左上 
        if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
        { 
          int matchColor = chessStatus[i][j].getColor(); 
          //向下查找,左上角為坐標(biāo)原點(diǎn),y軸正方向向下 
          for(int n=1;n<=4;n++) 
          { 
            if((j-n>=0)&&(j-n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS) 
            { 
              if(chessStatus[i-n][j-n]!=null&&chessStatus[i-n][j-n].getPlaced()==true&&chessStatus[i-n][j-n].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                break; 
              }   
            } 
          } 
          //右下 
          for(int n=1;n<=4;n++) 
          { 
            if((j+n>=0)&&(j+n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS) 
            { 
              if(chessStatus[i+n][j+n]!=null&&chessStatus[i+n][j+n].getPlaced()==true&&chessStatus[i+n][j+n].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                if(chessStatus[i+n][j+n]!=null) 
                { 
                  chessStatus[i][j].matchCount = 1; 
                } 
                break; 
              } 
            } 
          } 
          chessStatus[i][j].matchCount=1;//refresh count 
        } 
      } 
    } 
 
    //方向:左下右上 
    for(int i=0;i<ROWS+1;i++) 
    { 
      for(int j=0;j<ROWS+1;j++) 
      { 
        //左下 
        if(chessStatus[i][j]!=null&&chessStatus[i][j].getPlaced()==true) 
        { 
          int matchColor = chessStatus[i][j].getColor(); 
          //向下查找,左上角為坐標(biāo)原點(diǎn),y軸正方向向下 
          for(int n=1;n<=4;n++) 
          { 
            if((j+n>=0)&&(j+n)<=ROWS&&(i-n)>=0&&(i-n)<=ROWS) 
            { 
              if(chessStatus[i-n][j+n]!=null&&chessStatus[i-n][j+n].getPlaced()==true&&chessStatus[i-n][j+n].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" up count++:"+(i-n)+" "+(j+n)+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                break; 
              }   
            } 
          } 
          //右上 
          for(int n=1;n<=4;n++) 
          { 
            if((j-n>=0)&&(j-n)<=ROWS&&(i+n)>=0&&(i+n)<=ROWS) 
            { 
              if(chessStatus[i+n][j-n]!=null&&chessStatus[i+n][j-n].getPlaced()==true&&chessStatus[i+n][j-n].getColor()==matchColor) 
              { 
                chessStatus[i][j].matchCount++; 
                System.out.println("pos:"+i+" "+j+" "+"left count++:"+(i+n)+" "+(j-n)+" count:"+chessStatus[i][j].matchCount); 
                if(chessStatus[i][j].matchCount==5) 
                { 
                  return true; 
                } 
              }else 
              { 
                if(chessStatus[i+n][j-n]!=null) 
                { 
                  chessStatus[i][j].matchCount = 1; 
                } 
                break; 
              } 
            } 
          } 
          chessStatus[i][j].matchCount=1;//refresh count 
        } 
      } 
    }     
 
    return false;   
  } 
}

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java模擬QQ桌面截圖功能實(shí)現(xiàn)方法

    Java模擬QQ桌面截圖功能實(shí)現(xiàn)方法

    這篇文章主要介紹了Java模擬QQ桌面截圖功能實(shí)現(xiàn)方法,涉及java針對(duì)鼠標(biāo)事件及圖片操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-07-07
  • java觀察者模式的三種實(shí)現(xiàn)方式代碼實(shí)例

    java觀察者模式的三種實(shí)現(xiàn)方式代碼實(shí)例

    這篇文章主要介紹了java觀察者模式的三種實(shí)現(xiàn)方式代碼實(shí)例,觀察者模式(又被稱(chēng)為發(fā)布-訂閱(Publish/Subscribe)模式,屬于行為型模式的一種,它定義了一種一對(duì)多的依賴(lài)關(guān)系,讓多個(gè)觀察者對(duì)象同時(shí)監(jiān)聽(tīng)某一個(gè)主題對(duì)象,需要的朋友可以參考下
    2023-10-10
  • Java中的代理模式詳解及實(shí)例代碼

    Java中的代理模式詳解及實(shí)例代碼

    這篇文章主要介紹了Java中的代理模式詳解及實(shí)例代碼的相關(guān)資料,這里附有實(shí)例代碼,需要的朋友可以參考下
    2017-02-02
  • HttpServletRequest對(duì)象方法的用法小結(jié)

    HttpServletRequest對(duì)象方法的用法小結(jié)

    HttpServletRequest對(duì)象代表客戶(hù)端的請(qǐng)求,當(dāng)客戶(hù)端通過(guò)HTTP協(xié)議訪問(wèn)服務(wù)器時(shí),HTTP請(qǐng)求頭中的所有信息都封裝在這個(gè)對(duì)象中,開(kāi)發(fā)人員通過(guò)這個(gè)對(duì)象的相關(guān)方法,即可以獲得客戶(hù)的這些信息
    2017-03-03
  • 為何Java8需要引入新的日期與時(shí)間庫(kù)

    為何Java8需要引入新的日期與時(shí)間庫(kù)

    這篇文章主要給大家介紹了關(guān)于Java8為什么需要引入新的日期與時(shí)間庫(kù)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Spring?Boot?中的?@HystrixCommand?注解原理及使用方法

    Spring?Boot?中的?@HystrixCommand?注解原理及使用方法

    通過(guò)使用 @HystrixCommand 注解,我們可以輕松地實(shí)現(xiàn)對(duì)方法的隔離和監(jiān)控,從而提高系統(tǒng)的可靠性和穩(wěn)定性,本文介紹了Spring Boot 中的@HystrixCommand注解是什么,其原理以及如何使用,感興趣的朋友跟隨小編一起看看吧
    2023-07-07
  • java 中如何獲取字節(jié)碼文件的相關(guān)內(nèi)容

    java 中如何獲取字節(jié)碼文件的相關(guān)內(nèi)容

    這篇文章主要介紹了java 中如何獲取字節(jié)碼文件的相關(guān)內(nèi)容的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • Java中的阻塞隊(duì)列BlockingQueue使用詳解

    Java中的阻塞隊(duì)列BlockingQueue使用詳解

    這篇文章主要介紹了Java中的阻塞隊(duì)列BlockingQueue使用詳解,阻塞隊(duì)列是一種線程安全的數(shù)據(jù)結(jié)構(gòu),用于在多線程環(huán)境下進(jìn)行數(shù)據(jù)交換,它提供了一種阻塞的機(jī)制,當(dāng)隊(duì)列為空時(shí),消費(fèi)者線程將被阻塞,直到隊(duì)列中有數(shù)據(jù)可供消費(fèi),需要的朋友可以參考下
    2023-10-10
  • 深入了解Java包與訪問(wèn)控制權(quán)限

    深入了解Java包與訪問(wèn)控制權(quán)限

    這篇文章主要帶你掌握J(rèn)ava中包的定義及使用以及Java中的4種訪問(wèn)權(quán)限,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-09-09
  • SpringBoot中@GetMapping注解的使用

    SpringBoot中@GetMapping注解的使用

    @GetMapping注解是Spring Boot中最常用的注解之一,它可以幫助開(kāi)發(fā)者定義和處理HTTP GET請(qǐng)求,本文就來(lái)介紹一下SpringBoot中@GetMapping注解的使用,感興趣的可以了解一下
    2023-10-10

最新評(píng)論