斗地主游戲文檔

斗地主游戲文檔

1.體系結(jié)構

體系結(jié)構 ![Uploading 邏輯流程圖1_561587.png . . .].png

2.邏輯流程圖

邏輯流程圖1.png
邏輯流程圖2.png

3.服務器-客戶端通訊圖

服務器-客戶端通訊圖.png

4.數(shù)據(jù)結(jié)構

4.1牌型

pokes.png

每一張撲克都有對應的index,根據(jù)圖中撲克的順序,設置每張撲克對應的index為從左到右以及從上到下遞增.(即左上角的紅桃A為0,右上角的紅桃K為12,方塊A為13,以此類推)

4.2比較大小

撲克大小由其對應的value表示,從3到K對應的value為2到12,A對應13,2對應14,大小王對應16與15,根據(jù)value比較大小

4.3出牌數(shù)組

由int數(shù)組保存出牌的數(shù)據(jù),即一組index

5.系統(tǒng)模塊

5.2消息模型
var socket = io.connect('http://localhost:3000');
var X = window.scriptData;                          //截取服務器發(fā)送過來的數(shù)據(jù)
    //收到服務器發(fā)送的不同的消息類型,調(diào)用對應的出牌模型中的函數(shù)
    socket.on("connect",function () {
        socket.emit("addUser",X._id);                   //添加用戶
    })
    socket.on("playerSit",function (obj) {
        MODAL.insertImg($(".seat").eq(obj.index).children(),obj);
    })
    socket.on("leave",function (index) {
        MODAL.removeImg($(".seat").eq(index).children());
    })
    socket.on("seatsInfo",function (obj) {
        console.log("seatsInfo"+obj);
        for(var key in obj){
            console.log(key);
            MODAL.insertImg($(".seat").eq(obj[key].index).children(),obj[key]);
        }
    })
    socket.on("gameStart",function (obj,turn) {
        MODAL.startGame(obj,turn);
    })
    socket.on("postCards",function (obj) {
        MODAL.justifyWhich(obj);
    })
    socket.on("reStart",function (array,turn) {
        MODAL.reStart(array,turn);
    })
    socket.on("giveup",function (giupCount) {
        MODAL.giveUpReply(giupCount);
    })
    socket.on("renshu",function (seats) {
        MODAL.someOneTouXiang(seats);
    })
var socketFun = {
    //出牌對象通過socketFun調(diào)用相關函數(shù)與服務器通信
    sit:function ($this) {
        var obj = {
            id:X._id,
            index:$this.parent().index()
        }
        socket.emit("sitSeat",obj);
    },
    sendCards:function (array) {
        var sendOut;
        if(($(".cardsLine .cards").children().length-array.length)==0){
            sendOut = true;
        }else{
            sendOut = false;
        }
        var obj = {
            array:array,
            posterIndex:MODAL.default.myIndex,
            sendOut:sendOut
        }
        socket.emit("postCards",obj);
    },
    readyMsg:function (obj) {
        socket.emit("readyMsg",obj);
    },
    giveUp:function () {
        socket.emit("giveup");
    },
    touxiang:function (index) {
        socket.emit("touxiang",index)
    }
    
}
5.3壓牌邏輯

邏輯框圖的array[i].value(下面為了簡化改為arr[i].val)表示撲克牌數(shù)組中的第i張撲克牌(從0計數(shù))的實際value,array已經(jīng)被排過序,以下的狀態(tài)機邏輯圖省略對length的判斷

狀態(tài)機.png

function compCards(array) {
    //ptr指向array的下標
    var ptr;
    //end標志狀態(tài)機是否結(jié)束
    var end = false;
    //data存儲著每一張撲克的value,避免多次運算value
    var box = {
        cardsType:{
            count:array.length,
            type:"ONE",
            value:data[array[0]].value
        },
        setType:function (type) {
            this.cardsType.type = type;
        },
        statusOne:function () {
            if(this.cardsType.count==1){
                end = true;
                return ;
            }
            if(data[array[0]].value==data[array[1]].value){          //如果第一個和第二個數(shù)字相同
                this.setType("TWO");
                return ;
            }
            if(data[array[0]].value==data[array[1]].value+1){
                this.setType("STRAIGHT");
            }else{
                this.setType("ERR");
            }
            return ;
        },
        statusTwo:function () {
            if(this.cardsType.count==2){
                end = true;
                return ;
            }
            if(data[array[1]].value==data[array[2]].value){
                this.setType("THREE");
                return ;
            }
            if(data[array[1]].value==data[array[2]].value+1){
                this.setType("TWO-ONE");
            }else{
                this.setType("ERR");
            }

        },
        statusThree:function () {
            if(this.cardsType.count==3){
                end = true;
                return ;
            }
            if(data[array[2]].value==data[array[3]].value){
                this.setType("BOMB");
                return ;
            }
            if(data[array[2]].value==data[array[3]].value+1){
                this.setType("THREE-ONE");
            }else{
                this.setType("ERR");
            }
            return ;
        },
        statusStraight:function () {
            if(this.cardsType.count< 5){
                this.setType("ERR");
                end = true;
                return ;
            }
            if(ptr< this.cardsType.count-1){
                if(data[array[ptr]].value!=data[array[ptr+1]].value+1){
                    this.setType("ERR");
                    end = true;
                    return ;
                }
            }else{
                end = true;
                return ;
            }
        },
        statusTwoOne:function () {
            if(ptr==this.cardsType.count-1){                //TwoOne處于中間狀態(tài),結(jié)束則出錯
                this.setType("ERR");
                return ;
            }
            if(data[array[ptr]].value==data[array[ptr+1]].value){
                this.setType("TWO-TWO");
            }else{
                this.setType("ERR");
            }
            return ;
        },
        statusTwoTwo:function () {
            if(ptr==this.cardsType.count-1){
                end = true;
                return ;
            }
            if(data[array[ptr]].value==data[array[ptr]].value+1){
                this.setType("TWO-ONE");
            }else{
                this.setType("ERR");
            }
            return ;
        },
        statusThreeOne:function () {
            if(ptr==this.cardsType.count-1){
                this.setType("ERR");
                return ;
            }
            if(data[array[ptr]].value==data[array[ptr+1]].value){
                this.setType("THREE-TWO");
            }else{
                this.setType("ERR");
            }
            return ;
        },
        statusThreeTwo:function () {
            if(ptr==this.cardsType.count-1){
                this.setType("ERR");
                return ;
            }
            if(data[array[ptr]].value==data[array[ptr+1]].value){
                this.setType("THREE-THREE");
            }else{
                this.setType("ERR");
            }
            return ;
        },
        statusThreeThree:function () {
            if(ptr==this.cardsType.count-1){
                end = true;
                return ;
            }
            if(data[array[ptr]].value==data[array[ptr+1]].value+1){
                this.setType("THREE-ONE");
            }else{
                this.setType("ERR");
            }
            return ;
        },
        statusBomb:function () {
            if(ptr==this.cardsType.count-1){
                end = true;
                return ;
            }
            if(data[array[ptr]].value!=data[array[ptr+1]].value){
                this.setType("ERR");
            }
        },
        ERR:function () {
            end = true;
            return ;
        }
    };
    for(ptr = 0;ptr< box.cardsType.count;++ptr){
        console.log("END:"+end);
        console.log(box.cardsType);
        if(end){

            break;
        }

        switch(box.cardsType.type){
            //ONE表示單張牌,這個ONE狀態(tài)結(jié)束有效
            case "ONE":
                box.statusOne();
                break;
            //TWO表示一對,結(jié)束有效
            case "TWO":
                box.statusTwo();
                break;
            //THREE表示三張一樣的牌,結(jié)束有效
            case "THREE":
                box.statusThree();
                break;
            //STRAIGHT表示順子,根據(jù)array長度判斷是否有效
            case "STRAIGHT":
                box.statusStraight();
                break;
            //TWO-ONE表示形如xx(x+1)(x+1)(x+2)的牌型,結(jié)束無效,返回類型ERR
            case "TWO-ONE":
                box.statusTwoOne();
                break;
            case "TWO-TWO":
            //TWO-TWO表示形如xx(x+1)(x+1)(x+2)(x+2)的牌型,結(jié)束有效
                box.statusTwoTwo();
                break;
            //THREE-ONE表示形如xxx(x+1)(x+1)(x+1)(x+2)的牌型,結(jié)束無效,返回類型ERR
            case "THREE-ONE":
                box.statusThreeOne();
                break;
            //THREE-TWO表示形如xxx(x+1)(x+1)(x+1)(x+2)(x+2)的牌型,結(jié)束無效,返回類型ERR
            case "THREE-TWO":
                box.statusThreeTwo();
                break;
            //THREE-THREE表示形如xxx(x+1)(x+1)(x+1)(x+2)(x+2)(x+2)的牌型,結(jié)束有效
            case "THREE-THREE":
                box.statusThreeThree();
                break;
            //BOMB表示炸彈,返回有效
            case "BOMB":
                box.statusBomb();
                break;
            //ERR表示牌型不合邏輯,無效
            case "ERR":
                box.ERR();
                break;
        }
    }
    return box.cardsType;

}
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市肌幽,隨后出現(xiàn)的幾起案子门岔,更是在濱河造成了極大的恐慌痒玩,老刑警劉巖劲腿,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件俏险,死亡現(xiàn)場離奇詭異肴楷,居然都是意外死亡水由,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門赛蔫,熙熙樓的掌柜王于貴愁眉苦臉地迎上來砂客,“玉大人泥张,你說我怎么就攤上這事【现担” “怎么了媚创?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長彤恶。 經(jīng)常有香客問我钞钙,道長,這世上最難降的妖魔是什么声离? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任芒炼,我火速辦了婚禮,結(jié)果婚禮上术徊,老公的妹妹穿的比我還像新娘本刽。我一直安慰自己,他們只是感情好赠涮,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布子寓。 她就那樣靜靜地躺著,像睡著了一般笋除。 火紅的嫁衣襯著肌膚如雪斜友。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天株憾,我揣著相機與錄音蝙寨,去河邊找鬼。 笑死嗤瞎,一個胖子當著我的面吹牛墙歪,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播贝奇,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼虹菲,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了掉瞳?” 一聲冷哼從身側(cè)響起毕源,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎陕习,沒想到半個月后霎褐,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡该镣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年冻璃,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡省艳,死狀恐怖娘纷,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情跋炕,我是刑警寧澤赖晶,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站辐烂,受9級特大地震影響遏插,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜纠修,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一涩堤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧分瘾,春花似錦、人聲如沸吁系。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽汽纤。三九已至上岗,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蕴坪,已是汗流浹背肴掷。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留背传,地道東北人呆瞻。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓,卻偏偏與公主長得像径玖,于是被迫代替她去往敵國和親痴脾。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

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