android遊戲開發之我的小小遊戲2——連連看遊戲3連連看演算法1

來源:互聯網
上載者:User

對於連連看重判斷能否串連的問題主要考慮三種情況

1、串連時沒有拐點,此時又分為橫向和縱向

2、串連時有一個拐點的情況

3、串連時有兩個拐點的情況,這也是本遊戲中最難的部分了

首先我們來看看沒有拐點的情況

//判斷水平方向上public boolean isHorizontal(){//用來記錄那個數大,那個數小int bigNumX = 0;int smallNumX = 0;//首先判斷水平線上的if(lastClick[1] == curClick[1]){if(lastClick[0] > curClick[0]){bigNumX=lastClick[0];smallNumX=curClick[0];}else if(lastClick[0] < curClick[0]){bigNumX=curClick[0];smallNumX=lastClick[0];}//相鄰的情況if(smallNumX+1 == bigNumX){return true;}else//不是相鄰的情況{for(int i=smallNumX+1;i<=bigNumX;i++){if(pieces[i][lastClick[1]] == 1)//如果兩個方塊之間有方塊return false;else return true;}}}return false;}//判斷豎直方向上public boolean isVertical(){int bigNumY = 0;int smallNumY = 0;if(lastClick[1] > curClick[1]){bigNumY=lastClick[1];smallNumY=curClick[1];}else if(lastClick[1] < curClick[1]){bigNumY=curClick[1];smallNumY=lastClick[1];}//相鄰的情況if(smallNumY+1 == bigNumY){return true;}else{for(int i=smallNumY+1;i<bigNumY;i++){if(pieces[lastClick[0]][i] == 1)//如果兩個方塊之間有方塊return false;else return true;}}return false;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.