JavaScript+HTML5 實現打地鼠小遊戲

一.遊戲簡介

打地鼠這個遊戲相信大家都不陌生也是童年時候一款經典的遊戲本次遊戲的編寫是以html文件形式完成的並且使用HBulider軟件進行編寫,使用谷歌瀏覽器展示效果,遊戲將會採用JavaScript實現整體的邏輯流程,最終使用谷歌瀏覽器來實現遊戲的展示和操作。本次遊戲需要有一定的HTML5+JavaScript基礎

 

二.遊戲最終的效果如下:

 

三.遊戲實現的流程

a) 遊戲界面的切換和背景音樂的實現

b) 設置按鈕的點擊效果

c) 地鼠的隱藏與出現

d) 地鼠的隨機出現

e) 設置小錘跟隨鼠標移動

f) 小錘和地鼠的碰撞

 

1

首先是遊戲界面的切換在我們點擊開始遊戲或者遊戲說明時都會進行頁面的切換頁面切換效果我們可以使用隱藏屬性display:none。在遊戲主菜單界面時,將內容content設置爲出現:

document.getElementById("content").style.display="block";

在進入遊戲或者遊戲說明時content內容設置爲隱藏從而實現界面的切換效果

document.getElementById("content").style.display="none";

 

2

 接下來是音頻的實現,HTML5新特性中的<audio>標籤提供音樂播放的功能,在進入遊戲時,音樂自動播放,我們在body中自定義一個按鈕,通過按鈕來控制音頻的播放和暫停,代碼如下:

按鈕樣式:

//src中存放音頻地址,設置autoplay加載完成自動播放,button按鈕控制播放暫停
<audio id="audio" src="audio/game_music.ogg" autoplay="autoplay" loop="loop"  ></audio>
<input type="button" onclick="playOrPause()" id="playbtn"></input>
然後再js中自定義按鈕的功能,代碼如下:

然後再js中自定義按鈕的功能代碼如下

//音頻播放與暫停
function playOrPause(){
            var audio  =    document.getElementById("audio");
            if(audio.paused){
            audio.play();
document.getElementById("playbtn").style.backgroundImage = "url(img/musicplaying.png)";
                }else if(audio.played){
                    audio.pause();
    document.getElementById("playbtn").style.backgroundImage = "url(img/musicpause.png)";
                }
            }

 

3

之後是設置按鈕的點擊效果,這個比較簡單,實際上就是兩個圖片之間的切換,給按鈕一個hover,通過鼠標移上來實現背景圖片的切換

//開始按鈕被鼠標指向時觸發
#start:hover{
                background-image: url(../img/start2.png);
            }

 

4

 接下來是地鼠的出現功能在地鼠出現的區域設置一個div用來顯示地鼠在地鼠未出現之前將地鼠隱藏在洞下使用定時器setInterval()設定地鼠出現的時間使用延時器setTimeout(),設定地鼠待在地面上的時間

首先是div(地鼠顯示的區域)和地鼠的隱藏div

展示效果

//d0爲地鼠出現的區域,m0設置地鼠隱藏的區域
<div id="d0" >
    <div id="m0" ></div>                
</div>

其次是地鼠的出現和消失,

例:

//老鼠顯示和消失動畫
intervalid= setInterval(function(){
                $("#m"+num).animate({"marginTop":0+"px"},function(){

                    timeId2=  setTimeout(function(){
                        $("#m"+num).animate({"marginTop":100+"px"});
                    },1000);
                    
                });        
                //老鼠被打進洞後,恢復原圖
                    document.getElementById("m"+num).style.backgroundImage = "url(img/mouse1.png)";
                    
                },3000);

 

5

 地鼠的隨機出現我們可以設定一個隨機數

//隨機產生0-8之間的隨機數,包括0和8
var  num = Math.floor(Math.random()*9);

產生0-8之間的隨機數指定九個洞中哪個洞出現地鼠然後將num傳遞給定時器和延時器中的id指定的地鼠實現地鼠隨機的選取

隨機出現地鼠展示

 

 

6

 設置錘子的移動需要與鼠標移動同步使用到JavaScript中的鼠標移動事件首先註冊鼠標移動事件,代碼如下:

var ele=document.getElementById("all");
ele.onmousemove=function(){GetMouse(event);}
function GetMouse(oEvent,snum)
{
             x=oEvent.clientX;
             y=oEvent.clientY;            document.getElementById('Img').style.left=(parseInt(x))+10+"px";
            document.getElementById('Img').style.top=y-30+"px";        
             var oEvent=oEvent||event;  

 

7

 檢測碰撞:

檢測錘子是否與出現的地鼠相碰撞,使用offsetTop、offsetWidth、offsetHeightoffsetLeft計算出地鼠和錘子的位置根據距離的計算判斷地鼠與錘子是否重合碰撞

效果

 

代碼如下

var l1=document.getElementById('Img').offsetLeft;  
var r1=document.getElementById('Img')
.offsetLeft+document.getElementById('Img').offsetWidth;  
var t1=document.getElementById('Img').offsetTop;  
var b1=document.getElementById('Img')
.offsetTop+document.getElementById('Img').offsetHeight;  
var l2=document.getElementById('m'+num).offsetLeft;  
var r2=document.getElementById('m'+num)
.offsetLeft+document.getElementById('m'+num).offsetWidth;  
var t2=document.getElementById('m'+num).offsetTop;  
var b2=document.getElementById('m'+num)
.offsetTop+document.getElementById('m'+num).offsetHeight;  
//錘子與老鼠碰撞計算
if(r1<l2 || l1>r2 || b1<t2 || t1>b2)  
      {  
         var ele = document.getElementById("m"+num);
         //實現錘子點擊動畫
         ele.onmousedown = function(){
         ChangeBg("Img","img/hammer2.png");
         //打中老鼠老鼠切換圖片
        
         document.form1.score.value = beat;
         console.log("總得分爲:"+beat);                                          document.getElementById('m'+num)
.style.backgroundImage='url(img/mouse2.png)';  
              } 
beat+=1;     
        }  
else  
        {  
           var ele = document.getElementById("m"+num);
           //實現錘子點擊動畫
           ele.onmousedown = function(){
           ChangeBg("Img","img/hammer2.png");        document.getElementById('m'+num).style.background='url(img/mouse1.png);  
}
                   
          }

以上是主要功能的代碼展示需要完整的遊戲代碼可自行下載

下載地址:

http://www.jredu100.com/index.php?m=content&c=index&a=show&catid=65&id=37

 

作者:傑瑞教育
出處:http://www.cnblogs.com/jerehedu/ 
版權聲明:本文版權歸傑瑞教育技有限公司和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。
技術諮詢:JRedu技術交流
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章