前端飛機大戰小游戲

来源:https://www.cnblogs.com/mochenxiya/archive/2022/09/15/16696780.html
-Advertisement-
Play Games

一、案例效果 點擊打開視頻講解更加詳細 二、實現思路 創建游戲背景板; 創建我方戰機,滑鼠進入游戲面板後其隨滑鼠軌跡運動; onmousemove 創建子彈,讓子彈周期性的在戰機處發出並讓其向 top 值減小的方向(向上)移動,top 小於 0 也就是子彈走出游戲面板時刪除自身; 創建敵機,讓敵機周 ...


一、案例效果

點擊打開視頻講解更加詳細

在這裡插入圖片描述

二、實現思路

  • 創建游戲背景板;
  • 創建我方戰機,滑鼠進入游戲面板後其隨滑鼠軌跡運動; onmousemove
  • 創建子彈,讓子彈周期性的在戰機處發出並讓其向 top 值減小的方向(向上)移動,top 小於 0 也就是子彈走出游戲面板時刪除自身;
  • 創建敵機,讓敵機周期性的在游戲背景板左側的隨機距離的位置產生,並讓其向 top 增加的方向(向下)移動;
  • 定義函數,子彈和敵機相遇時消失。

條件:所有的元素都只在滑鼠進入游戲背景區域時才觸發運動。

三、完整代碼+詳細註釋

<!DOCTYPE html>
<html>
 
<head>
  <meta charset="UTF-8">
  <title>飛機大戰</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }
 
    /* 背景 */
    #background {
      width: 320px;
      height: 580px;
      background-image: url(./img/bg.jpg);
      margin: auto;
    }
 
    /* 我方飛機 */
    #my_fly {
      width: 30px;
      height: 30px;
      position: absolute;
      cursor: pointer;
    }
  </style>
</head>
 
<body>
  <!-- 游戲面板 -->
  <div id="background"></div>
</body>
<script>
  //創建我方戰機
  var fly = document.createElement('div'); //創建一個div
  fly.id = 'my_fly'; //為div添加id名
  fly.innerHTML = '<img src ="./img/my_fly.png" width=30px height=30px>'; //在div中插入飛機的圖片
  document.body.appendChild(fly); //將剛創建的div追加到body中
 
  //使飛機滑鼠跟隨
  document.onmousemove = function (e) { //onmousemove 當滑鼠移動時觸發事件
    var fly = document.getElementById('my_fly'); //獲取我方戰機
    var bg = document.getElementById('background'); //獲取背景
    var fly_X = e.clientX - 20; //獲取滑鼠的坐標 -20是減去飛機寬高的一半,以達到飛機中心與滑鼠對應
    var fly_Y = e.clientY - 20;
    //游戲背景的區域
    var bgX = fly_X > bg.offsetLeft && fly_X < bg.offsetLeft + bg.offsetWidth - 30;
    var bgY = fly_Y > bg.offsetTop && fly_Y < bg.offsetTop + bg.offsetHeight - 30;
    if (bgX && bgY) { //只有在游戲背景區域內飛機才跟隨滑鼠移動
      fly.style.top = fly_Y + 'px'; //將滑鼠此時的坐標賦值給我方飛機
      fly.style.left = fly_X + 'px';
      //此時飛機跟隨滑鼠移動,我們為該行為定義一個屬性
      fly.follow = true; //今後follow為true則代表飛機可跟隨滑鼠移動,false則相反
    }
  }
 
  //創建子彈
  var objB = { //子彈相關變數
    name: 'bullet', //名稱
    num: 1, //數量
    arr: [], //子彈的屬性['id|top|left']
    width: 5, //子彈寬
    height: 10, //子彈高
    path: './img/bullet.png'
  }
  creatBullet(objB);
 
  function creatBullet(obj) {
    setInterval(function () {
      var fly = document.getElementById('my_fly');
      if (fly.follow) { //當飛機可跟隨滑鼠移動時可以發射子彈
        var bull = document.createElement('div'); //創建div元素作為子彈
        bull.id = obj.name + obj.num; //子彈的id名隨創建數量不斷變化(因為id值唯一)
        var length = obj.arr.length;
        if (length < 40) {
          obj.arr[length] = bull.id + '|';
          obj.num++;
          bull.style.width = obj.width + 'px'; //子彈的相關屬性
          bull.style.height = obj.height + 'px';
          bull.style.position = 'absolute';
          bull.style.background = 'url(' + obj.path + ')';
 
          bull.style.top = parseInt(fly.style.top) + 'px'; //子彈發出的位置
          obj.arr[length] = obj.arr[length] + bull.style.top + '|';
          bull.style.left = parseInt(fly.style.left) + 12 + 'px';
          obj.arr[length] = obj.arr[length] + bull.style.left;
        }
        document.body.appendChild(bull); //將子彈添加到body
      }
    }, 700)
  }
 
  //讓子彈運動起來
  function moveBullet() {
    var fly = document.getElementById('my_fly');
    if (fly.follow) {
      for (var i = 0; i < objB.arr.length; i++) { //遍歷子彈的對象
        var newArr = objB.arr[i].split('|'); //將數組arr中的元素切割出來放入新數組
        var eleB = document.getElementById(newArr[0]);
        //切割後第0項為id 第一項為top 第二項為left  
        newArr[1] = parseInt(newArr[1]) - 1; //數組第一項為top,不斷減1則子彈便會向上運動
        eleB.style.top = newArr[1] + 'px';
        objB.arr[i] = newArr[0] + '|' + newArr[1] + '|' + newArr[2];
        if (newArr[1] < 0) { //第一項為top,當top小於0 也就是子彈走出游戲面板時刪除該子彈
          objB.arr.splice(i, 1);
          var delEle = document.getElementById(newArr[0]); //獲取走出面板的子彈
          delEle.parentNode.removeChild(delEle); //刪除自身
        }
      }
    }
  }
 
 
  //創建敵機(與創建子彈類似)
  var objF = { //敵機相關變數
    name: 'foe', //名稱
    num: 1, //數量
    arr: [], //敵機的屬性['id|top|left']
    width: 34, //敵機寬
    height: 24, //敵機高
    path: './img/he_fly.png'
  }
  creatFoe(objF);
 
  function creatFoe(obj) {
    setInterval(function () {
      var fly = document.getElementById('my_fly');
      var bg = document.getElementById('background'); //獲取背景
      if (fly.follow) { //當飛機可跟隨滑鼠移動時出現敵機
        var bull = document.createElement('div'); //創建div元素作為敵機
        bull.id = obj.name + obj.num; //子彈的id名隨創建數量不斷變化(因為id值唯一)
        var length = obj.arr.length;
        if (length < 40) {
          obj.arr[length] = bull.id + '|';
          obj.num++;
          bull.style.width = obj.width + 'px';
          bull.style.height = obj.height + 'px';
          bull.style.position = 'absolute';
          bull.style.background = 'url(' + obj.path + ')';
 
          bull.style.top = 0; //敵機的頂部初始位置為0
          obj.arr[length] = obj.arr[length] + bull.style.top + '|';
          bull.style.left = bg.offsetLeft + 290 * Math.random() + 'px'; //敵機的左側初始位置為隨機
          obj.arr[length] = obj.arr[length] + bull.style.left;
        }
        document.body.appendChild(bull); //將敵機添加到body
      }
    }, 1000)
  }
 
  //讓敵機運動起來
  function moveFoe() {
    var fly = document.getElementById('my_fly');
    var bg = document.getElementById('background'); //獲取背景
    if (fly.follow) {
      for (var i = 0; i < objF.arr.length; i++) { //遍歷敵機的對象
        var newArr = objF.arr[i].split('|'); //將數組arr中的元素切割出來放入新數組
        var eleB = document.getElementById(newArr[0]);
        //切割後第0項為id 第一項為top 第二項為left  
        newArr[1] = parseInt(newArr[1]) + 1; //數組第一項為top,不斷加1則飛機便會向下運動
        eleB.style.top = newArr[1] + 'px';
        objF.arr[i] = newArr[0] + '|' + newArr[1] + '|' + newArr[2];
        if (newArr[1] > bg.offsetLeft - 30) {
          objF.arr.splice(i, 1);
          var delEle = document.getElementById(newArr[0]);
          delEle.parentNode.removeChild(delEle);
        }
      }
    }
  }
 
  //調用運動函數
  setInterval(function () {
    moveBullet(); //子彈運動
    moveFoe(); //敵機運動
 
    //子彈和敵機相遇時消失
    for (var i = 0; i < objF.arr.length; i++) {
      var newArr = objF.arr[i].split('|');
      var eleF = document.getElementById(newArr[0]);
      var xFS = parseInt(newArr[2]);
      var xFE = parseInt(newArr[2]) + 34;
      var yFS = parseInt(newArr[1]);
      var yFE = parseInt(newArr[1]) + 24;
      for (var j = 0; j < objB.arr.length; j++) {
        var newArr1 = objB.arr[j].split('|');
        var eleB = document.getElementById(newArr1[0]);
        var xB = parseInt(newArr1[2]);
        var yB = parseInt(newArr1[1]);
        var xCheck = xB > xFS && xB < xFE;
        var yCheck = yB > yFS && yB < yFE;
 
        if (xCheck && yCheck) {
          objF.arr.splice(i, 1);
          eleF.parentNode.removeChild(eleF);
          objB.arr.splice(j, 1);
          eleB.parentNode.removeChild(eleB);
        }
      }
    }
  }, 10)
</script>
 
</html>

若對您有幫助,請點擊跳轉到B站一鍵三連哦!感謝支持!!!


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

-Advertisement-
Play Games
更多相關文章
  • IOS開發工具官網地址 http://www.applicationloader.net/ 最新版本已經優化了沒支付688給apple的賬號登錄流程,無需再安裝其他軟體。 立即下載最新版本 在appuploader官網首頁下載,如果您是windows電腦,則選擇點擊 windows版,如果是mac ...
  • 最近,“你這背景太假了”席卷全網。由於身後風景太優美,被網友質疑背景太假,某主播為了自證,直接把手裡的桶扔進了背後的水裡。短短幾天時間播放量幾十億,引發了全網P圖狂潮,網友在短視頻App里將其人像摳出來,替換了不同的背景,各類創意視頻很快衝上熱搜。 現如今,視頻人像摳圖有著廣泛應用。在直播App里可 ...
  • 自適應佈局和響應式佈局的區別? 1.響應式的概念覆蓋了自適應,但響應式包含的東西更多,響應式的佈局可以根據屏幕的大小自動調整頁面的展示方式 2.自適應有一個致命缺點:如果屏幕尺寸太小,即使網頁能夠根據屏幕大小進行適配,也會感覺在小屏幕上查看,內容過於擁擠 3.響應式解決了自適應佈局的問題,響應式能自 ...
  • 一、this指向 點擊打開視頻講解更加詳細 this隨處可見,一般誰調用,this就指向誰。this在不同環境下,不同作用下,表現的也不同。 以下幾種情況,this都是指向window 1、全局作用下,this指向的是window console.log(window); console.log(t ...
  • SSO介紹 背景 隨著企業的發展,一個大型系統里可能包含 n 多子系統, 用戶在操作不同的系統時,需要多次登錄,很麻煩,我們需要一種全新的登錄方式來實現多系統應用群的登錄,這就是單點登錄。 web 系統 由單系統發展成多系統組成的應用群,複雜性應該由系統內部承擔,而不是用戶。無論 web 系統內部多 ...
  • 隨著項目的日漸迭代,項目整體的代碼量也會越來越多,從而導致項目體積越來越大;在Webpack時代,很多人會對歷史項目(巨型項目)感到頭疼,因為往往巨型項目在本地開發調試的時候會因為本地代碼的修改觸發HMR熱更新重載頁面,然而這一過程在Webpack的運行機制中顯得很慢,並且是隨著項目越大,熱更新的速 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 最近每天學習的時候,發現了一道很有趣的面試題 1.const [a, b] = { a: 100, b: 200 } 2.console.log(a) 3.console.log(b) 如何在不改變1的情況下,讓代碼不報錯 這個時候,我突 ...
  • 前端像素鳥小游戲 點擊打開視頻講解更加詳細 一、案例效果 二、實現思路 創建游戲背景板和小鳥,並分別設置相對定位與絕對定位; 初始化背景圖的位置; 初始化小鳥的位置; 設置游戲狀態,游戲開始時背景和管道全部向左運動,游戲結束全部停止運動; 使小鳥飛行,其實就是背景圖在 X 軸方向的位置不斷減小,實現 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...