JavaScript實(shí)現(xiàn)斗地主游戲的思路
本文知識(shí)給大家分享一下使用js寫(xiě)斗地主的思路,代碼寫(xiě)的不好,還請(qǐng)見(jiàn)諒。
這里說(shuō)說(shuō)斗地主主要包含的功能:洗牌,發(fā)牌,玩家出牌、電腦出牌,出牌規(guī)則的驗(yàn)證,輸贏啥的沒(méi)有判斷,只是實(shí)現(xiàn)了這幾個(gè)主要功能,下面依次說(shuō)說(shuō)幾個(gè)功能的實(shí)現(xiàn):
1.洗牌:
var pukes=this.manage.pukes;//存放撲克牌的數(shù)組 //洗牌 for(var i=;i<pukes.length;i++){ var tmp=pukes[i]; var index=util.random(i,pukes.length);//隨機(jī)交換兩張牌 pukes[i]=pukes[index]; pukes[index]=tmp; }
2.發(fā)牌(簡(jiǎn)版默認(rèn)是玩家自己為地主,電腦為農(nóng)民),由于前面洗牌時(shí)已經(jīng)將牌的順序打亂,所以發(fā)牌只是簡(jiǎn)單的循環(huán)把pukes中的元素添加到每個(gè)玩家實(shí)例中的pukes字段中。
//發(fā)牌 var start=; for(var i=;i<this.manage.pukes.length-;i++) { if(start==this.manage.players.length){ start=; } this.manage.pukes[i].status=true; this.manage.players[start].pukesLen++; this.manage.players[start++].pukes.push(this.manage.pukes[i]); } for(var i=this.manage.pukes.length-;i<this.manage.pukes.length;i++){ //地主多三張 this.manage.pukes[i].status=true; this.manage.players[this.manage.curPlayerIndex].pukesLen++; this.manage.players[this.manage.curPlayerIndex].pukes.push(this.manage.pukes[i]); }
3.玩家出牌,玩家出牌分為電腦和玩家自己兩個(gè)步驟,電腦出牌是非常傻瓜的出牌方式(有牌就出):
//出牌 if(this.options.playerIndex==this.manage.curPlayerIndex) { var spks = [],gz=false; if (this.manage.curMaxPlayerIndex == this.options.playerIndex) { this.manage.deskPukes = []; } if (this.isCompute) { //電腦自動(dòng)出牌 var start = ; var len=this.manage.deskPukes.length||; while (start < this.pukes.length) { spks = []; for (var i = ,j=start; i <len&&j<this.pukes.length; i++) { //隨便選一張 可以出就行 if(this.pukes[j].status) { spks.push(this.pukes[j++]); } } if(spks.length) { if (rules.valids(spks, this.manage.deskPukes)) { gz = true; break; } } start++; } } else { //玩家選擇出牌 for (var i = ; i < this.pukes.length; i++) { if (this.pukes[i].selected && this.pukes[i].status) { spks.push(this.pukes[i]); } } if (rules.valids(spks, this.manage.deskPukes)) { gz=true; } else{ alert("出牌不符合規(guī)則!"); } } if(gz){ this.manage.curMaxPlayerIndex=this.options.playerIndex; this.manage.deskPukes = []; for (var i = ; i < spks.length; i++) { this.pukesLen--; this.manage.deskPukes.push(spks[i]); spks[i].status = false; } } this.manage.renderPukes(); this.manage.renderCurDiscard(); if(this.isCompute||gz) { this.manage.nextPlayer(); } } else{ alert("沒(méi)輪到你出牌!"); }
4.出牌規(guī)則的驗(yàn)證,是很多函數(shù)組合起來(lái),然后循環(huán)調(diào)用,如果遇到返回ture的即為出牌符合規(guī)則:
//以下為出牌規(guī)則 var rules={ _rules:[ new danzRule(), new duiRule(), new sandRule(), new zandRule(), new shunzRule(), new liandRule() ], valids:function(_pukes,_curPukes){ for(var i=;i<this._rules.length;i++){ if(this._rules[i].valid(_pukes,_curPukes)){ return true; } } return false; } }; function danzRule(){ //單張規(guī)則 } danzRule.prototype.valid=function(_pukes,_curPukes){ //校驗(yàn) var pukes=_pukes;//玩家的牌 var curPukes=_curPukes;//左面的牌 if(pukes&&pukes.length==){ //比較牌面值 if(!curPukes||!curPukes.length){ return true; } if(curPukes[].dians==&&pukes[].dians<){ //特殊處理 return false; } if(pukes[].dians==&&curPukes[].dians<){ //特殊處理 return true; } return pukes[].dians>curPukes[].dians; } return false; } function duiRule(_pukes,_curPukes){ //兩張規(guī)則 } duiRule.prototype.valid=function(_pukes,_curPukes){ //校驗(yàn) var pukes=_pukes;//玩家的牌 var curPukes=_curPukes;//左面的牌 if(pukes&&pukes.length==){ //比較牌面值 if(pukes[].dians>&&pukes[].dians>){ return true; } if(pukes[].dians!=pukes[].dians){ return false; } if(!curPukes||!curPukes.length){ return true; }else { if(curPukes.length!=){ return false; } if (curPukes[].dians > && curPukes[].dians > ) { return false; } if (curPukes[].dians != curPukes[].dians) { return false; } if (curPukes[].dians == ) { return false; } } if(pukes[].dians==){ return true; } return pukes[].dians>curPukes[].dians; } return false; } function sandRule(){ //三帶 } sandRule.prototype.valid=function(_pukes,_curPukes){ //校驗(yàn) var pukes=_pukes;//玩家的牌 var curPukes=_curPukes;//左面的牌 if(pukes&&(pukes.length>=)){ //比較牌面值 var books=getBooks(pukes); if(!valid(books))return false; if(!curPukes||!curPukes.length)return true; if(curPukes.length!=books.length)return false; var books=getBooks(curPukes); if(!valid(books))return false; return getSum(books)>getSum(books); } return false; function getSum(books){ var sum=; for(var i=;i<books.length;i++) { if(books[i]==){ if(i==)return ; sum+=i; } } return sum; } function valid(books){ //驗(yàn)證三帶是否有效 var counts= ,countsd= ,d=true,start=false,startIndex=-; for(var i=;i<books.length;i++) { if(start&&books[i]==&&startIndex!=(i-)){ return false; }else{ startIndex=i; } if(books[i]==){ if(!start) { start = true; startIndex = i; } counts++; } if(books[i]==){ d=false; } } for(var i=;i<books.length;i++) { if(d&&books[i]==){ countsd++; } else if(!d&&books[i]==){ countsd++; } } return counts>&&counts==countsd; } function getBooks(pukes){ //返回三帶的每個(gè)點(diǎn)數(shù)的個(gè)數(shù) var books=[]; for(var i=;i<pukes.length;i++){ if(!books[pukes[i].dians]){ books[pukes[i].dians]=; }else{ books[pukes[i].dians]++; } } return books; } } function zandRule(){ //炸彈 } zandRule.prototype.valid=function(_pukes,_curPukes){ var pukes=_pukes;//玩家的牌 var curPukes=_curPukes;//左面的牌 if(pukes&&pukes.length==) { if(!allEqual(pukes)){ return false; } if(!curPukes||(curPukes.length>&&curPukes.length!=)||!allEqual(curPukes)){ return true; } else{ if(pukes[].dians==){ return true; } if(curPukes[].dians==){ return false; } return pukes[].dians>curPukes[].dians; } } return false; function allEqual(pukes){ if(!pukes||!pukes.length)return false; var base=pukes[].dians; for(var i=;i<pukes.length;i++){ if(base!=pukes[i].dians){ return false; } } return true; } } function liandRule(){ //連對(duì) } liandRule.prototype.valid=function(_pukes,_curPukes) { var pukes=_pukes;//玩家的牌 var curPukes=_curPukes;//左面的牌 if(pukes&&pukes.length>=) { if(!verificationCoherence(pukes)){ return false; } if(!curPukes||curPukes.length<=){ return true; } if(!verificationCoherence(curPukes)){ return false; } if(pukes.length!=curPukes.length){ return false; } return getSumDians(pukes)>getSumDians(curPukes); } return false; function getSumDians(pukes){ var sum=; for(var i=;i<pukes.length;i++) { sum+=pukes[i].dians; } return sum; } function verificationCoherence(pukes){ //驗(yàn)證連貫性 if(!pukes||!pukes.length)return false; var books=[]; for(var i=;i<pukes.length;i++){ if(pukes[i].dians==||pukes[i].dians>){ return false; } if(!books[pukes[i].dians]){ books[pukes[i].dians]=; }else{ books[pukes[i].dians]++; } if(books[pukes[i].dians]>){ return false; } } var start=false; for(var i=;i<books.length;i++) { if(books[i]&&books[i]!=){ return false; } if(books[i]==&&!start){ start=true; } if(start&&books[i]!=){ return false; } } return true; } } function shunzRule(){ //順子 } shunzRule.prototype.valid=function(_pukes,_curPukes){ var pukes=_pukes;//玩家的牌 var curPukes=_curPukes;//左面的牌 if(pukes&&pukes.length>=) { if(!verificationCoherence(pukes)){ return false; } if(!curPukes||curPukes.length<=){ return true; } if(!verificationCoherence(curPukes)){ return false; } if(pukes.length!=curPukes.length){ return false; } return getSumDians(pukes)>getSumDians(curPukes); } return false; function getSumDians(pukes){ var sum=; for(var i=;i<pukes.length;i++) { sum+=pukes[i].dians; } return sum; } function verificationCoherence(pukes){ //驗(yàn)證連貫性 if(!pukes||!pukes.length)return false; var books=[]; for(var i=;i<pukes.length;i++){ if(pukes[i].dians==||pukes[i].dians>){ return false; } if(!books[pukes[i].dians]){ books[pukes[i].dians]=; }else{ return false; } } var start=false; for(var i=;i<books.length;i++) { if(books[i]==&&!start){ start=true; } if(start&&!books[i]){ return false; } } return true; } }
以上4步,是我認(rèn)為的主要的4個(gè)函數(shù),其他的函數(shù),如初始化,事件注冊(cè)等,在源碼已有注釋?zhuān)瑢?xiě)的不好勿噴。
JavaScript實(shí)現(xiàn)斗地主游戲的思路就給大家介紹這么多,希望對(duì)大家有所幫助!
- js仿3366小游戲選字游戲
- js貪吃蛇游戲?qū)崿F(xiàn)思路和源碼
- 基于javascript實(shí)現(xiàn)泡泡大冒險(xiǎn)網(wǎng)頁(yè)版小游戲
- 基于javascript實(shí)現(xiàn)句子翻牌網(wǎng)頁(yè)版小游戲
- 基于javascript制作經(jīng)典傳統(tǒng)的拼圖游戲
- javascript結(jié)合Flexbox簡(jiǎn)單實(shí)現(xiàn)滑動(dòng)拼圖游戲
- 分享自己用JS做的掃雷小游戲
- js編寫(xiě)貪吃蛇的小游戲
- 使用Javascript寫(xiě)的2048小游戲
- javascript實(shí)現(xiàn)的猜數(shù)小游戲完整實(shí)例代碼
相關(guān)文章
不依賴(lài)Flash和任何JS庫(kù)實(shí)現(xiàn)文本復(fù)制與剪切附源碼下載
本篇文章給大家分享的文本復(fù)制與剪切板功能,實(shí)現(xiàn)此功能不依賴(lài)falsh插件和任何js庫(kù)實(shí)現(xiàn)的,感興趣的朋友一起看看吧2015-10-10JS中appendChild追加子節(jié)點(diǎn)無(wú)效的解決方法
這篇文章主要給大家介紹了關(guān)于JS中appendChild追加子節(jié)點(diǎn)無(wú)效的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)2018-10-10js實(shí)現(xiàn)購(gòu)物車(chē)計(jì)算的方法
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)購(gòu)物車(chē)的計(jì)算方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08js實(shí)現(xiàn)點(diǎn)擊左右按鈕輪播圖片效果實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)點(diǎn)擊左右按鈕輪播圖片效果的方法,涉及click事件相應(yīng)、animate方法等使用技巧,需要的朋友可以參考下2015-01-01JS+CSS實(shí)現(xiàn)簡(jiǎn)單的二級(jí)下拉導(dǎo)航菜單效果
這篇文章主要介紹了JS+CSS實(shí)現(xiàn)簡(jiǎn)單的二級(jí)下拉導(dǎo)航菜單效果,通過(guò)簡(jiǎn)單的JavaScript頁(yè)面元素遍歷及樣式操作實(shí)現(xiàn)下拉菜單效果,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-09-09layui的數(shù)據(jù)表格+springmvc實(shí)現(xiàn)搜索功能的例子
今天小編就為大家分享一篇layui的數(shù)據(jù)表格+springmvc實(shí)現(xiàn)搜索功能的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09JavaScript中的單引號(hào)和雙引號(hào)報(bào)錯(cuò)的解決方法
數(shù)據(jù)中夾雜單引號(hào)(')或者雙引號(hào)("),這種語(yǔ)句往往會(huì)造成JavaScript報(bào)錯(cuò)。對(duì)此一般采用/'或者/"的解決2014-09-09使用 js 簡(jiǎn)單的實(shí)現(xiàn) bind、call 、aplly代碼實(shí)例
這篇文章主要介紹了使用 js 簡(jiǎn)單的實(shí)現(xiàn) bind、call 、aplly代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09利用用JS實(shí)現(xiàn)一個(gè)實(shí)時(shí)小鬧鐘
天我們來(lái)聊聊如何使用JS來(lái)創(chuàng)建一個(gè)實(shí)時(shí)的小鬧鐘,這個(gè)小鬧鐘十分的有趣,小伙伴們可以運(yùn)行一下,看看跟你電腦上的時(shí)間是否對(duì)的上呢,文章通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下2023-11-11