av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

js實現(xiàn)簡單五子棋游戲

瀏覽:102日期:2024-05-06 18:14:50

本文實例為大家分享了js實現(xiàn)五子棋游戲的具體代碼,供大家參考,具體內容如下

html

<!DOCTYPE html><html> <head> <meta charset='utf-8' /> <title>五子棋</title> <link rel='stylesheet' href='http://www.4tl426be.cn/bcjs/css/style.css' /> </head> <body> <canvas height='450px'></canvas> <script type='text/javascript' src='http://www.4tl426be.cn/bcjs/js/script.js' ></script> </body></html>

css

canvas{ display: block; margin: 50px auto; box-shadow: -2px -2px 2px #EFEFEF,5px 5px 5px #B9B9B9;}

js

var me = true;var over = false;var chessBox = [];var wins = []; //定義三維數組//贏法統(tǒng)計數組var myWin = [];var computerWin = [];for(i=0;i<15;i++){ chessBox[i]=[]; for(j=0;j<15;j++){ chessBox[i][j]=0; } }for(var i=0;i<15;i++){ wins[i]=[]; for(var j=0;j<15;j++){ wins[i][j]=[]; }}var count =0;//所有橫線for(var i=0;i<15;i++){ for(var j=0;j<11;j++){ //執(zhí)行1次 // wins[0][0][0]=true; // wins[0][1][0]=true; // wins[0][2][0]=true; // wins[0][3][0]=true; // wins[0][4][0]=true; //執(zhí)行2次 // wins[0][1][1]=true; // wins[0][2][1]=true; // wins[0][3][1]=true; // wins[0][4][1]=true; // wins[0][5][1]=true; for(var k=0; k<5;k++){ wins[i][j+k][count] = true; } count++; }}//所有豎線for(var i=0;i<15;i++){ for(var j=0;j<11;j++){ for(var k=0; k<5;k++){ wins[j+k][i][count] = true; } count++; }}//所有斜線for(var i=0;i<11;i++){ for(var j=0;j<11;j++){ for(var k=0; k<5;k++){ wins[i+k][j+k][count] = true; } count++; }}//所有反斜線for(var i=0;i<11;i++){ for(var j=14;j>3;j--){ for(var k=0; k<5;k++){ wins[i+k][j-k][count] = true; } count++; }} console.log(count);for (var i=0;i<count;i++) { myWin[i] = 0; computerWin[i] = 0;} var chess = document.getElementById(’chess’);var context = chess.getContext(’2d’);context.strokeStyle = '#BFBFBF';var logo= new Image();logo.src = 'http://www.4tl426be.cn/bcjs/img/木頭.jpg';logo.onload = function(){ context.drawImage(logo,0,0,450,450); drawChessBoard();// oneStep(0,0,true);// oneStep(1,1,false);}function drawChessBoard(){ for(var i=0;i<15;i++){ context.moveTo(15+i*30,15); context.lineTo(15+i*30,435); context.moveTo(15,15+i*30); context.lineTo(435,15+i*30); context.stroke(); } }var oneStep = function(i,j,me){ context.beginPath(); context.arc(15+i*30,15+j*30,13,0,2*Math.PI); context.closePath(); var gradient = context.createRadialGradient(15+i*30,15+j*30,13,15+i*30,15+j*30,0); if(me){ gradient.addColorStop(0,'#0A0A0A'); gradient.addColorStop(1,'#636766'); }else{ gradient.addColorStop(0,'#D1D1D1'); gradient.addColorStop(1,'#F9F9F9'); } context.fillStyle = gradient; context.fill();} chess.onclick = function(e){ if(over){ return; } if(!me){ return; } var x = e.offsetX; var y = e.offsetY; var i = Math.floor(x/30); //i,j為索引序列號 var j = Math.floor(y/30); if(chessBox[i][j]==0){ oneStep(i,j,me); chessBox[i][j]=1; for(var k=0;k < count; k++){ if(wins[i][j][k]) { myWin[k]++; computerWin[k] = 6; //設置異常值 if(myWin[k] == 5) { window.alert('你贏了'); over = true; } } } if(!over){ me=!me; computerAI(); } } }var computerAI = function(){ var myScore = []; var computerScore = []; var max = 0; //保存最高分數; var u = 0, v =0; //保存坐標 for(var i=0;i<15;i++){ myScore[i] = []; computerScore [i] = []; for(var j=0;j<15;j++){ myScore[i][j] = 0; computerScore[i][j] = 0; } } for (var i=0; i<15;i++) { for (var j=0;j<15;j++) { if(chessBox[i][j] == 0){ for(var k =0 ;k<count;k++){ if(wins[i][j][k]){ if(myWin[k]==1){ myScore[i][j]+= 200; }else if(myWin[k]==2){ myScore[i][j]+= 400; }else if(myWin[k]==3){ myScore[i][j]+= 2000; }else if(myWin[k]==4){ myScore[i][j]+= 10000; } if(computerWin[k]==1){ computerScore[i][j]+= 220; }else if(computerWin[k]==2){ computerScore[i][j]+= 420; }else if(computerWin[k]==3){ computerScore[i][j]+= 2020; }else if(computerWin[k]==4){ computerScore[i][j]+= 10020; } } } if(myScore[i][j]>max){ max = myScore[i][j]; u = i; v = j; }else if(myScore[i][j] == max){ if(computerScore[i][j] > computerScore[u][v]){ u = i; v = j; } } if(computerScore[i][j]>max){ max = computerScore[i][j]; u = i; v = j; }else if(computerScore[i][j] == max){ if(myScore[i][j] > myScore[u][v]){ u = i; v = j; } } } } } oneStep(u,v,false); chessBox[u][v] = 2; for(var k=0;k < count; k++){ if(wins[u][v][k]) { computerWin[k]++; myWin[k] = 6; //設置異常值 if(computerWin[k] == 5) { window.alert('計算機贏了'); over = true; } } } if(!over){ me=!me; }}

js實現(xiàn)簡單五子棋游戲

更多有趣的經典小游戲實現(xiàn)專題,分享給大家:

C++經典小游戲匯總

python經典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經典游戲 玩不停

javascript經典小游戲匯總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 午夜黄色大片 | 丝袜美腿亚洲综合 | 国产午夜免费视频 | 国产一区二区三区在线看 | 人人超碰在线 | 综合久久久 | 亚洲aaaaaa | 国产精品久久久久久中文字 | 老司机精品福利视频 | 久久最新| 亚洲福利片 | 国产又粗又大又长 | 中文字幕日韩一区 | 中文字字幕码一二三区 | 午夜在线观看免费视频 | 亚洲精品免费在线 | 国产一级片免费 | 欧美精品二区三区四区免费看视频 | 欧美美女性生活 | 免费看大片a | 99精品久久久久久中文字幕 | 日日夜夜精品 | 伊人2222 | 中文字幕一区二区三区在线观看 | 亚洲国产成人精品女人 | 久草资源在线观看 | 九九精品视频在线观看 | 欧美日韩免费看 | 亚洲一区中文 | 奇米影视亚洲春色 | 在线观看日韩欧美 | av黄色在线| 一区二区三区视频在线 | 免费看一级黄色片 | 攵女(高h)欢欲 | 91看片在线观看 | 成人影| 亚洲另类色综合网站 | av在线一区二区三区 | 国产午夜三级 | 日日舔|