本文知識跟大家分享一下使用js寫斗地主的思路,程式碼寫的不好,還請見諒。
這裡說說斗地主主要包含的功能:洗牌,發牌,玩家出牌、電腦出牌,出牌規則的驗證,輸贏啥的沒有判斷,只是實現了這幾個主要功能,下面依次說說幾個功能的實現:
1.洗牌:
var pukes=this.manage.pukes;//存放扑克牌的数组 //洗牌 for(var i=;i<pukes.length;i++){ var tmp=pukes[i]; var index=util.random(i,pukes.length);//随机交换两张牌 pukes[i]=pukes[index]; pukes[index]=tmp; }
2.發牌(簡版預設是玩家自己為地主,電腦為農民),由於前面洗牌時已經將牌的順序打亂,所以發牌只是簡單的循環把pukes中的元素加入到每個玩家實例中的pukes欄位中。
//发牌 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.玩家出牌,玩家出牌分為電腦和玩家自己兩個步驟,電腦出牌是非常傻瓜的出牌方式(有牌就出):
//出牌 if(this.options.playerIndex==this.manage.curPlayerIndex) { var spks = [],gz=false; if (this.manage.curMaxPlayerIndex == this.options.playerIndex) { this.manage.deskPukes = []; } if (this.isCompute) { //电脑自动出牌 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("出牌不符合规则!"); } } 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("没轮到你出牌!"); }
4.出牌規則的驗證,是很多函數組合起來,然後循環調用,如果遇到返回ture的即為出牌符合規則:
//以下为出牌规则 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(){ //单张规则 } danzRule.prototype.valid=function(_pukes,_curPukes){ //校验 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){ //两张规则 } duiRule.prototype.valid=function(_pukes,_curPukes){ //校验 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){ //校验 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){ //验证三带是否有效 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){ //返回三带的每个点数的个数 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(){ //连对 } 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){ //验证连贯性 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){ //验证连贯性 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步,是我認為的主要的4個函數,其他的函數,如初始化,事件註冊等,在源碼已有註釋,寫的不好勿噴。
JavaScript實現斗地主遊戲的想法就給大家介紹這麼多,希望對大家有幫助!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

10款趣味橫生的jQuery遊戲插件,讓您的網站更具吸引力,提升用戶粘性!雖然Flash仍然是開發休閒網頁遊戲的最佳軟件,但jQuery也能創造出令人驚喜的效果,雖然無法與純動作Flash遊戲媲美,但在某些情況下,您也能在瀏覽器中獲得意想不到的樂趣。 jQuery井字棋遊戲 遊戲編程的“Hello world”,現在有了jQuery版本。 源碼 jQuery瘋狂填詞遊戲 這是一個填空遊戲,由於不知道單詞的上下文,可能會產生一些古怪的結果。 源碼 jQuery掃雷遊戲

本教程演示瞭如何使用jQuery創建迷人的視差背景效果。 我們將構建一個帶有分層圖像的標題橫幅,從而創造出令人驚嘆的視覺深度。 更新的插件可與JQuery 1.6.4及更高版本一起使用。 下載

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

Matter.js是一個用JavaScript編寫的2D剛體物理引擎。此庫可以幫助您輕鬆地在瀏覽器中模擬2D物理。它提供了許多功能,例如創建剛體並為其分配質量、面積或密度等物理屬性的能力。您還可以模擬不同類型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流瀏覽器。此外,它也適用於移動設備,因為它可以檢測觸摸並具有響應能力。所有這些功能都使其值得您投入時間學習如何使用該引擎,因為這樣您就可以輕鬆創建基於物理的2D遊戲或模擬。在本教程中,我將介紹此庫的基礎知識,包括其安裝和用法,並提供一

本文演示瞭如何使用jQuery和ajax自動每5秒自動刷新DIV的內容。 該示例從RSS提要中獲取並顯示了最新的博客文章以及最後的刷新時間戳。 加載圖像是選擇


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境

SublimeText3 Linux新版
SublimeText3 Linux最新版

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),