自己寫的HTML5 Canvas + Javascript五子棋

来源:http://www.cnblogs.com/hhelibeb/archive/2016/10/30/6013188.html
-Advertisement-
Play Games

看到一些曾經只會灌水的網友,在學習了前端之後,已經能寫出下載量幾千幾萬的腳本、樣式,幫助大眾,成為受歡迎的人,感覺滿羡慕的。我也想學會前端技術,變得受歡迎呀。於是心血來潮,開始學習前端知識,並寫下了這個小練習。 基本思路是這樣的: 效果圖: 代碼如下: 點我進入線上版 這算是自己學習Javascri ...


看到一些曾經只會灌水的網友,在學習了前端之後,已經能寫出下載量幾千幾萬的腳本、樣式,幫助大眾,成為受歡迎的人,感覺滿羡慕的。我也想學會前端技術,變得受歡迎呀。於是心血來潮,開始學習前端知識,並寫下了這個小練習。

基本思路是這樣的:

  1. 使用Canvas繪製棋盤、棋子。
  2. 用二維數組保存棋盤狀態。
  3. 設置一個flag,用以標識落子順序。
  4. 點擊時,在數組中檢測當前點擊位置是否存在棋子,若存在,則不落子;如游戲已結束,亦不落子。
  5. 落子時,更新數組,並將當前落子所在的行、列、左上-右下列、左下-右上列四個方向的棋盤狀態寫入到一維數組中,用以判斷新落子是否形成了五子連珠。
  6. 若形成了五子連珠,提示勝利,並結束游戲;反之,則交換順序,繼續進行游戲。

  效果圖:

  

 

代碼如下:

  1 <!DOCTYPE html>
  2 <html lang="zh-CN">
  3 <meta charset="utf-8">
  4 <head><title>五子棋</title></head>
  5 <body>
  6 <canvas id="myCanvas" width="560" height="560" style="border:3px solid black;">
  7 您的瀏覽器不支持 HTML5 canvas 標簽。</canvas>  <br/>
  8 <button id="reset" onclick="controller.init(ctx)">重置</button>
  9 </body>
 10 <script>
 11 var controller = {
 12     round:true,
 13     color:"black",
 14     whiteTable:new Array(),
 15     blackTable:new Array(),
 16     row:0,
 17     col:0,
 18     over:false,
 19     trans:function(){        
 20         this.round = !this.round;
 21         if (!this.round){
 22             this.blackTable[this.row][this.col] = 1;
 23             this.ifWin(this.blackTable)
 24             this.color = "white";
 25         }
 26         else{
 27             this.whiteTable[this.row][this.col] = 1;
 28             this.ifWin(this.whiteTable)            
 29             this.color = "black";
 30         }
 31     },
 32     ifWin:function(table){    
 33         var arr1 = new Array();
 34         var arr2 = new Array();
 35         var arr3 = new Array();
 36         var arr4 = new Array();
 37         var n = 0;    
 38         for(x = 0; x<= lineNums; x++) {         
 39             for(y = 0; y <= lineNums; y++) 
 40             { 
 41                 var x1 = this.row - n;
 42                 var x2 = this.row + n;
 43                 var y1 = this.col - n;
 44                 var y2 = this.col + n;
 45                 if(y == this.col){
 46                     arr1[x] = table[x][y];
 47                 }
 48                 if(x == this.row){
 49                     arr2[y] = table[x][y];
 50                 }
 51             }
 52             if(this.inBounds(x1) && this.inBounds(y2)){
 53                 arr3[x1] = table[x1][y2];
 54             }
 55             if(this.inBounds(x1) && this.inBounds(y1)){
 56                 arr4[x1] = table[x1][y1];                
 57             }
 58             if(this.inBounds(x2) && this.inBounds(y1)){
 59                 arr3[x2] = table[x2][y1];
 60             }
 61             if(this.inBounds(x2) && this.inBounds(y2)){
 62                 arr4[x2] = table[x2][y2];                
 63             }
 64             n = n + 1;
 65         } 
 66         this.getSum(arr1, this.row);
 67         this.getSum(arr2, this.col);
 68         this.getSum(arr3, this.row);
 69         this.getSum(arr4, this.row);
 70     },
 71     inBounds:function(i){
 72         if(i>=0 && i<=15){
 73             return true;
 74         }
 75         else{
 76             return false;    
 77         }    
 78     },
 79     getSum:function(array, pos){
 80         num = 5;
 81         posr = pos + 1;
 82         while(num > 0){
 83             if(array[pos]>0  && this.inBounds(pos)){
 84                 num = num - 1;
 85                 pos = pos - 1;
 86             }
 87             else{
 88                 break;
 89             }
 90         }
 91         while(num > 0){
 92             if(array[posr]>0 && this.inBounds(pos)){
 93                 num  = num - 1;
 94                 posr = posr + 1;
 95             }
 96             else{
 97                 break;
 98             }        
 99         }
100         if(num == 0){
101             this.over = true;
102             this.gameOver();
103         }    
104     },
105     ifExsit:function(x, y){
106         this.row = x / ratio;
107         this.col = y / ratio;
108         var nums = this.whiteTable[this.row][this.col] + this.blackTable[this.row][this.col];
109         if( nums > 0){
110             return true;
111         }
112         else{
113             return false;
114         }
115     },
116     gameOver:function(){
117         ctx.font="30px Arial";
118         ctx.fillStyle = "#FF0000";
119         if(this.round){
120             ctx.fillText("白棋勝利",240,240);
121         }
122         else{
123             ctx.fillText("黑棋勝利",240,240);
124         }
125     },
126     init:function(){
127         this.round = true;
128         this.color = "black";
129         this.over = false;
130         this.drawBoard();
131         for(i = 0; i<= lineNums; i++) { 
132             this.whiteTable[i]=new Array();
133             this.blackTable[i]=new Array();
134             for(n = 0; n <= lineNums; n++) { 
135                 this.whiteTable[i][n]=0;  
136                 this.blackTable[i][n]=0;
137             } 
138         } 
139     },
140     drawBoard:function(){
141         ctx.beginPath();
142         ctx.clearRect(0,0,width,width);
143         ctx.fillStyle = "#FFBB00";
144         ctx.fillRect(0,0,width,width);
145         for(var i = 1; i < (lineNums - 1); i++){
146             ctx.moveTo(i * ratio, 0);
147             ctx.lineTo(i * ratio, width);
148             ctx.stroke();
149             ctx.moveTo(0, i * ratio);
150             ctx.lineTo(width, i * ratio);
151             ctx.stroke();
152         }
153     },
154     drawPiece:function(posX, posY){
155         ctx.beginPath();
156         ctx.arc(posX, posY, ratio/2, 0, 2*Math.PI);
157         ctx.fillStyle = this.color;
158         ctx.fill();
159         ctx.stroke();                    
160     }
161 }; 
162 //獲取點擊位置
163 function getMousePos(canvas, evt) { 
164    var rect = canvas.getBoundingClientRect(); 
165    return { 
166      x: evt.clientX - rect.left * (canvas.width / rect.width),
167      y: evt.clientY - rect.top * (canvas.height / rect.height)
168    }
169  }
170     
171 function getNode(pos){
172     return ((pos / ratio).toFixed()) * ratio;
173 }
174 
175 var canvas = document.getElementById("myCanvas");
176 var ctx = canvas.getContext("2d");
177 var lineNums = 15;
178 var ratio = 40;
179 var width = (lineNums - 1) * ratio;
180 
181 controller.init();     
182 
183  canvas.addEventListener("click", function (evt) { 
184     var mousePos = getMousePos(canvas, evt); 
185     mousePos.x = getNode(mousePos.x);
186     mousePos.y = getNode(mousePos.y);
187       var exsit = controller.ifExsit(mousePos.x, mousePos.y);
188     if (!exsit && !controller.over){
189       controller.drawPiece(mousePos.x, mousePos.y); 
190       controller.trans();
191     } 
192  }, false);     
193 </script>
194 </html>

 

點我進入線上版

 

這算是自己學習Javascript的一個開端,未來的話,可能也要以這個例子為基礎,利用學到的知識,進一步增加其它功能,優化代碼。

 

本文鏈接:http://www.cnblogs.com/hhelibeb/p/6013188.html 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • JavaScripting 生成文本 如何在頁面中寫文本 <script type="text/javascript"> document.write("Hello World!") </script> 生成普通文本和標簽 如何使用 JavaScript 在頁面中寫入普通文本和標簽。 <script ...
  • JS的數組去重也是前端面試經常問到的問題,之前有一次面試就遇到讓我寫數組去重,而且一般這個問題都伴隨著多寫一種多加分的情況,所以掌握的方法自然多多益善。 網上可以找到很多數組去重的方法,我自己整理了一下以供今後自己複習。 利用indexOf: 最簡單的方法就是利用indexOf方法來實現數組去重,但 ...
  • 簡單的實現了 灰度,黑白,底片,模糊,馬賽克(代碼比較簡單,通過canvas實現的) 感覺挺有意思的,上面解釋很詳細,直接看代碼 ...
  • 第7章 jQuery插件的使用和寫法 插件又稱擴展,是一種遵循一定規範的應用程式介面寫出來的程式。 插件的編寫思想基於面向對象。 獲取最新的插件可以查看jquery官網: 本章將從幾個基本的例子來介紹jquery插件的使用。 一\. 表單驗證插件Validation jquery最常用的場合就是表單 ...
  • 一.綁定Class屬性。 綁定數據用v-bind:命令,簡寫成: 語法:<div v-bind:class="{ active: isActive }"></div>。class後面的雙引號里接受一個對象字面量/對象引用/數組作為參數, 這裡,{active: isActive}是對象參數,acti ...
  • 偽元素是一個好東西,但是很多人都沒怎麼用,因為他們覺得偽元素太詭異了。其實使用偽元素有很多好處,最大的好處是它可以簡化頁面的html標簽,同時用起來也很方便,善於使用偽元素可以讓你的頁面更加地簡潔優雅。 更好的閱讀體驗移步:http://yincheng.site/using-before-afte ...
  • 項目 (移動的廣告牌) 要求: 1,實現圖片一次以移動的方式出現,到最後一張完全出現時,回彈到第一張 2,滑鼠放在圖片上面圖片移動,滑鼠離開,圖片停止移動 *{ padding: 0; margin: 0;}/*添加背景圖片,個人愛好*/body{ background: url(../img/qu ...
  • 引言 webix.js被壓縮後很多字母不清楚是什麼用處,看源碼整理了部分出來,以button為例 1、button代碼 效果 2、以下代碼在F12的console中測試 define:方法(可以定義對象屬性的值) refresh:方法(刷新控制項) 效果 D 和 C:兩個都是定義屬性值的,define ...
一周排行
    -Advertisement-
    Play Games
  • 基於.NET Framework 4.8 開發的深度學習模型部署測試平臺,提供了YOLO框架的主流系列模型,包括YOLOv8~v9,以及其系列下的Det、Seg、Pose、Obb、Cls等應用場景,同時支持圖像與視頻檢測。模型部署引擎使用的是OpenVINO™、TensorRT、ONNX runti... ...
  • 十年沉澱,重啟開發之路 十年前,我沉浸在開發的海洋中,每日與代碼為伍,與演算法共舞。那時的我,滿懷激情,對技術的追求近乎狂熱。然而,隨著歲月的流逝,生活的忙碌逐漸占據了我的大部分時間,讓我無暇顧及技術的沉澱與積累。 十年間,我經歷了職業生涯的起伏和變遷。從初出茅廬的菜鳥到逐漸嶄露頭角的開發者,我見證了 ...
  • C# 是一種簡單、現代、面向對象和類型安全的編程語言。.NET 是由 Microsoft 創建的開發平臺,平臺包含了語言規範、工具、運行,支持開發各種應用,如Web、移動、桌面等。.NET框架有多個實現,如.NET Framework、.NET Core(及後續的.NET 5+版本),以及社區版本M... ...
  • 前言 本文介紹瞭如何使用三菱提供的MX Component插件實現對三菱PLC軟元件數據的讀寫,記錄了使用電腦模擬,模擬PLC,直至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1. PLC開發編程環境GX Works2,GX Works2下載鏈接 https:// ...
  • 前言 整理這個官方翻譯的系列,原因是網上大部分的 tomcat 版本比較舊,此版本為 v11 最新的版本。 開源項目 從零手寫實現 tomcat minicat 別稱【嗅虎】心有猛虎,輕嗅薔薇。 系列文章 web server apache tomcat11-01-官方文檔入門介紹 web serv ...
  • 1、jQuery介紹 jQuery是什麼 jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之後又一個優秀的JavaScript代碼庫(或JavaScript框架)。jQuery設計的宗旨是“write Less,Do More”,即倡導寫更少的代碼,做更多的事情。它封裝 ...
  • 前言 之前的文章把js引擎(aardio封裝庫) 微軟開源的js引擎(ChakraCore))寫好了,這篇文章整點js代碼來測一下bug。測試網站:https://fanyi.youdao.com/index.html#/ 逆向思路 逆向思路可以看有道翻譯js逆向(MD5加密,AES加密)附完整源碼 ...
  • 引言 現代的操作系統(Windows,Linux,Mac OS)等都可以同時打開多個軟體(任務),這些軟體在我們的感知上是同時運行的,例如我們可以一邊瀏覽網頁,一邊聽音樂。而CPU執行代碼同一時間只能執行一條,但即使我們的電腦是單核CPU也可以同時運行多個任務,如下圖所示,這是因為我們的 CPU 的 ...
  • 掌握使用Python進行文本英文統計的基本方法,並瞭解如何進一步優化和擴展這些方法,以應對更複雜的文本分析任務。 ...
  • 背景 Redis多數據源常見的場景: 分區數據處理:當數據量增長時,單個Redis實例可能無法處理所有的數據。通過使用多個Redis數據源,可以將數據分區存儲在不同的實例中,使得數據處理更加高效。 多租戶應用程式:對於多租戶應用程式,每個租戶可以擁有自己的Redis數據源,以確保數據隔離和安全性。 ...