面向?qū)ο蟮脑O(shè)計(jì)

<small>

圖形下落

本案例要求完成 CellGame,用戶可以在控制臺(tái)上操作格子的下落、左移和右移。
游戲剛開始,將在界面上顯示一個(gè)格子,界面效果如圖-2上左圖中的藍(lán)色圈內(nèi)所示,用戶可以在控制臺(tái)選擇輸入各種操作:1表示下落一行,2表示左移一列,3表示右移一列,0表示退出。如果用戶錄入1,則格子下落一行,并重新打印顯示,界面效果如圖-2上右圖中的藍(lán)色圈內(nèi)所示:


如果用戶錄入2,則格子左移一列,并重新打印顯示,界面效果如圖-3上左圖中藍(lán)色圈內(nèi)所示;如果用戶錄入3,則格子右移一列,并重新打印顯示,界面如圖-3上右圖中藍(lán)色圈內(nèi)所示:

星星圖形的對(duì)象
package com.ksxx.oop.day03.am.exercise;

/**
 * *類:
 *  屬性:
 *  int x,y;//坐標(biāo)
    String CHARACTER = "*";//組成元素
    
    方法:
    printCell()//打印
    moveLeft()//左移
    moveRight()//右移
    drop()//下落
 * @author chengcheng
 *
 */
public class Cell {
    //屬性:
    int row,col;//坐標(biāo)
    String CHARACTER = "* ";//組成元素
    
    //無參構(gòu)造
    public Cell(){
        //默認(rèn)位置(第一行,第五列)
//      this.x = 0;
//      this.y = 4;
        this(0,4);
    }
    //有參構(gòu)造
    public Cell(int row,int col){
        //默認(rèn)位置(第一行,第五列)
        this.row = row;
        this.col = col;
    }
    
    //方法:
    //打印
    public void printCell(){
        System.out.print(this.CHARACTER);
    }
    
    //右移:row行不變,col列每移動(dòng)一次,++一次
    public void moveRight(){
        col++;
    }
}
墻對(duì)象:
package com.ksxx.oop.day03.am.exercise;

/**
 * Wall墻面:
 *  由 200個(gè)-號(hào)對(duì)象 組成 無意義
 * 
 *  屬性:
 *      多少行、多少列
 *      組成元素
 * 
 *  方法:
 *      打印墻體
 * @author chengcheng
 *
 */
public class Wall {
    //如下設(shè)計(jì)無意義
    /*Line[][] lines;
    public Wall(){
        lines = new Line[20][10];
        for(int i=0; i<lines.length; i++){//行:y
            for(int j=0; j<lines[i].length; j++){//列:x
                //矩陣中每個(gè) - 從出現(xiàn)開始,坐標(biāo)就已經(jīng)確定。
                lines[i][j] = new Line(i,j);
            }
        }
    }*/
    
    //屬性:
    int rows;//行數(shù)
    int cols;//列數(shù)
    String CHARACTER = "- ";//組成元素
    Cell cell;//另一個(gè)組成元素
    
    //無參構(gòu)造,默認(rèn)大小墻體
    public Wall(){
//      this.rows = 20;//20行
//      this.cols = 10;//10列
        this(20,10);
    }
    //有參構(gòu)造,自定義大小墻體,默認(rèn)cell位置
    public Wall(int rows, int cols){
        this.rows = rows;
        this.cols = cols;
        //默認(rèn)cell在墻體的位置
        cell = new Cell();
    }
    //有參構(gòu)造,默認(rèn)大小墻體,自定義cell位置
    public Wall(Cell cell){
        this(20,10);
        //自定義cell位置
        this.cell = cell;
    }
    //有參構(gòu)造,自定義大小墻體,自定義cell位置
    public Wall(int rows, int cols, Cell cell){
        this.rows = rows;
        this.cols = cols;
        //自定義cell位置
        this.cell = cell;
    }
    
    //方法:
    //墻體的打印。
    public void printWall(){
        for(int i=0; i<rows; i++){//行:rows
            for(int j=0; j<cols; j++){//列:cols
                if(i == this.cell.row && 
                        j == this.cell.col){
                    System.out.print(this.cell.CHARACTER);
                    continue;
                }
                System.out.print(this.CHARACTER);
            }
            System.out.println();//換行
        }
    }
    
}
測試方法
package com.ksxx.oop.day03.am.exercise;

import java.util.Scanner;

public class GameStart_V2 {

    public static void main(String[] args) {
        
        //創(chuàng)建墻體對(duì)象
        Wall wall = new Wall(new Cell(9,0));
        wall.printWall();
        Scanner sc = new Scanner(System.in);
        
        while(true){
            System.out.println("3 - 向右,0 - 退出");
            int number = sc.nextInt();
            if(number == 0){
                //退出
                break;
            }else if(number == 3){
                //右移:
                //定位墻體中的cell元素,向右移:
                wall.cell.moveRight();
            }
            //重繪
            wall.printWall();
        }
        

    }
}

如果圖形由※號(hào)改為 T 形圖,可以將代碼修改如下

package com.ksxx.oop.day05.am.exercise;

/**
 * Wall墻面:
 *  由 200個(gè)-號(hào)對(duì)象 組成 無意義
 * 
 *  屬性:
 *      多少行、多少列
 *      組成元素
 * 
 *  方法:
 *      打印墻體
 * @author chengcheng
 *
 */
public class Wall {
    
    //屬性:
    int rows;//行數(shù)
    int cols;//列數(shù)
    String CHARACTER = "- ";//組成元素
//  Cell cell;//另一個(gè)組成元素
    T t;//組成元素由1個(gè)Cell變成4個(gè)Cell組成的T型。
    
    //無參構(gòu)造,默認(rèn)大小墻體
    public Wall(){
//      this.rows = 20;//20行
//      this.cols = 10;//10列
        this(20,10);
    }
    //有參構(gòu)造,自定義大小墻體,默認(rèn)cell位置
    public Wall(int rows, int cols){
        this.rows = rows;
        this.cols = cols;
        //默認(rèn)T在墻體的位置
        t = new T();
    }
    //有參構(gòu)造,默認(rèn)大小墻體,自定義T位置
    public Wall(Cell cell){
        this(20,10);
        //自定義cell位置
        this.t = new T(cell);
    }
    //有參構(gòu)造,自定義大小墻體,自定義t位置
    public Wall(int rows, int cols, Cell cell){
        this.rows = rows;
        this.cols = cols;
        //自定義t位置
        this.t = new T(cell);
    }
    
    
    //方法:
    //墻體的打印。
    public void printWall(){
        //開關(guān)
        /*boolean flag;
        for(int i=0; i<rows; i++){//行:rows
            for(int j=0; j<cols; j++){//列:cols
                flag = true;//開關(guān)開啟
                //對(duì)T型進(jìn)行打印
                for(int k=0; k<t.cells.length; k++){
                    if(i == t.cells[k].row && 
                            j == t.cells[k].col){
                        System.out.print(t.cells[k].CHARACTER);
                        flag = false;//開關(guān)關(guān)閉
                        break;
                    }
                }
                if(flag){
                    System.out.print(this.CHARACTER);
                }
            }
            System.out.println();//換行
        }*/
        
        for(int i=0; i<rows; i++){//行:rows
            second:for(int j=0; j<cols; j++){//列:cols
                //對(duì)T型進(jìn)行打印
                for(int k=0; k<t.cells.length; k++){
                    if(i == t.cells[k].row && 
                            j == t.cells[k].col){
                        System.out.print(t.cells[k].CHARACTER);
                        continue second;
                    }
                }
                System.out.print(this.CHARACTER);
            }
            System.out.println();//換行
        }
    }
    
}

若要求發(fā)生改變?yōu)椋阂褕D形從 T 改變?yōu)?O、L、J、S、Z、I 等圖形的的隨機(jī)出現(xiàn)可以將代碼改為:

package com.ksxx.oop.day05.am.exercise;

import java.util.Random;

/**
 * Wall墻面:
 *  由 200個(gè)-號(hào)對(duì)象 組成 無意義
 * 
 *  屬性:
 *      多少行、多少列
 *      組成元素
 * 
 *  方法:
 *      打印墻體
 * @author chengcheng
 *
 */
public class Wall {
    
    //屬性:
    int rows;//行數(shù)
    int cols;//列數(shù)
    String CHARACTER = "- ";//組成元素
    Tetramino newTetramino;//抽象的俄羅斯方塊
    
    //無參構(gòu)造,默認(rèn)大小墻體
    public Wall(){
//      this.rows = 20;//20行
//      this.cols = 10;//10列
        this(20,10);
    }
    //有參構(gòu)造,自定義大小墻體,默認(rèn)cell位置
    public Wall(int rows, int cols){
        this.rows = rows;
        this.cols = cols;
        newTetramino = randomTetramino();
    }
    //有參構(gòu)造,默認(rèn)大小墻體,自定義T位置
    public Wall(Cell cell){
        this(20,10);
        this.newTetramino = randomTetramino(cell);
    }
    //有參構(gòu)造,自定義大小墻體,自定義t位置
    public Wall(int rows, int cols, Cell cell){
        this.rows = rows;
        this.cols = cols;
        this.newTetramino = randomTetramino(cell);
    }
    
    
    //方法:
    //墻體的打印。
    public void printWall(){
        //開關(guān)
        /*boolean flag;
        for(int i=0; i<rows; i++){//行:rows
            for(int j=0; j<cols; j++){//列:cols
                flag = true;//開關(guān)開啟
                //對(duì)T型進(jìn)行打印
                for(int k=0; k<t.cells.length; k++){
                    if(i == t.cells[k].row && 
                            j == t.cells[k].col){
                        System.out.print(t.cells[k].CHARACTER);
                        flag = false;//開關(guān)關(guān)閉
                        break;
                    }
                }
                if(flag){
                    System.out.print(this.CHARACTER);
                }
            }
            System.out.println();//換行
        }*/
        
        for(int i=0; i<rows; i++){//行:rows
            second:for(int j=0; j<cols; j++){//列:cols
                //對(duì)T型進(jìn)行打印
                for(int k=0; k<newTetramino.cells.length; k++){
                    if(i == newTetramino.cells[k].row && 
                            j == newTetramino.cells[k].col){
                        System.out.print(newTetramino.cells[k].CHARACTER);
                        continue second;
                    }
                }
                System.out.print(this.CHARACTER);
            }
            System.out.println();//換行
        }
    }
    
    /**
     * 隨機(jī)產(chǎn)生具體俄羅斯方塊
     */
    private Tetramino randomTetramino(){
        Random ran = new Random();
        int number = ran.nextInt(3);
        //返回隨機(jī)的俄羅斯方塊
        //方式一:
//      Tetramino[] tetris = {new T(),new J(),new L()};
//      return tetris[number];
        Tetramino tetramino = null;
        //方式二
        /*if(number == 0){
            tetramino = new T();
        }else if(number == 1){
            tetramino = new J();
        }else if(number == 2){
            tetramino = new L();
        }else{
            tetramino = new L();
        }*/
        //方式三
        switch(number){
            case 0:
                tetramino = new T();break;
            case 1:
                tetramino = new L();break;
            case 2:
                tetramino = new J();break;
            default:
                tetramino = new T();break;
        }
        return tetramino;
    }
    private Tetramino randomTetramino(Cell cell){
        Random ran = new Random();
        int number = ran.nextInt(3);
        
        Tetramino tetramino = null;
        switch(number){
        case 0:
            tetramino = new T(cell);break;
        case 1:
            tetramino = new L(cell);break;
        case 2:
            tetramino = new J(cell);break;
        default:
            tetramino = new T(cell);break;
    }
        return tetramino;
    }
    
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,885評(píng)論 6 541
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,312評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,993評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,667評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,410評(píng)論 6 411
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,778評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,775評(píng)論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,955評(píng)論 0 289
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,521評(píng)論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,266評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,468評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,998評(píng)論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,696評(píng)論 3 348
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,385評(píng)論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,193評(píng)論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,431評(píng)論 2 378

推薦閱讀更多精彩內(nèi)容

  • 創(chuàng)建型模式 1、FACTORY—追MM少不了請(qǐng)吃飯了,麥當(dāng)勞的雞翅和肯德基的雞翅都是MM愛吃的東西,雖然口味有所不...
    珈誼閱讀 353評(píng)論 0 0
  • 設(shè)計(jì)原則就是在設(shè)計(jì)模式背后更為深層的、更具有普遍性的、共同的思想原則,是提高軟件系統(tǒng)的可維護(hù)性和可復(fù)用性的指導(dǎo)原則...
    蘇先生Tongson閱讀 1,189評(píng)論 0 0
  • 優(yōu)先考慮組合/聚合,而不是繼承 代碼的演進(jìn)過程 針對(duì)《設(shè)置》和《發(fā)現(xiàn)》中table view的代碼邏輯起初我是這樣...
    liyc_dev閱讀 209評(píng)論 0 1
  • 面向?qū)ο蟠嬖谄邆€(gè)設(shè)計(jì)原則 1,單一職責(zé)原則: 一個(gè)類只負(fù)責(zé)一個(gè)功能領(lǐng)域中的相應(yīng)職責(zé),或者可以定義為:就一個(gè)類而...
    猿日記閱讀 233評(píng)論 0 0
  • 片段1 每次來簡書,習(xí)慣去關(guān)注里找簡安,有段時(shí)間了,看到她的名字右邊的依然是畫一條龍......又期盼又有點(diǎn)小失落...
    簡安胡同閱讀 142評(píng)論 0 1