17 KiB
स्पेस गेम बनाउनुहोस् भाग ६: अन्त्य र पुनः सुरु गर्नुहोस्
प्रि-लेक्चर क्विज
खेलमा अन्त्यको अवस्था व्यक्त गर्ने विभिन्न तरिकाहरू छन्। खेलको सृष्टिकर्ताको रूपमा, खेल किन समाप्त भएको हो भन्ने निर्णय गर्नु तपाईंको हातमा हुन्छ। यहाँ केही कारणहरू छन्, यदि हामीले तपाईंले अहिलेसम्म बनाउँदै आएको स्पेस गेमको बारेमा कुरा गरिरहेको छौं भने:
Nशत्रु जहाजहरू नष्ट भएका छन्: यदि तपाईंले खेललाई विभिन्न स्तरहरूमा विभाजन गर्नुभएको छ भने,Nशत्रु जहाजहरू नष्ट गर्नुपर्ने सामान्य कुरा हो।- तपाईंको जहाज नष्ट भएको छ: तपाईंको जहाज नष्ट भएमा खेल हार्ने खेलहरू पनि पक्कै छन्। अर्को सामान्य तरिका भनेको जीवनको अवधारणा हो। तपाईंको जहाज प्रत्येक पटक नष्ट हुँदा एक जीवन घट्छ। जब सबै जीवन समाप्त हुन्छ, तब तपाईं खेल हार्नुहुन्छ।
- तपाईंले
Nअंक संकलन गर्नुभएको छ: अर्को सामान्य अन्त्यको अवस्था भनेको तपाईंले अंक संकलन गर्नु हो। कसरी अंक प्राप्त गर्ने भन्ने कुरा तपाईंको हातमा हुन्छ, तर शत्रु जहाज नष्ट गर्दा वा नष्ट हुँदा वस्तुहरू संकलन गर्दा अंक दिनु सामान्य कुरा हो। - स्तर पूरा गर्नुहोस्: यसले
Xशत्रु जहाजहरू नष्ट गर्नु,Yअंक संकलन गर्नु वा विशेष वस्तु संकलन गर्नु जस्ता विभिन्न अवस्थाहरू समावेश गर्न सक्छ।
पुनः सुरु गर्नु
यदि मानिसहरूले तपाईंको खेल मन पराउँछन् भने, उनीहरूले यसलाई पुनः खेल्न चाहन सक्छन्। खेल कुनै पनि कारणले समाप्त भएपछि, तपाईंले पुनः सुरु गर्ने विकल्प दिनुपर्छ।
✅ सोच्नुहोस् कि कुन अवस्थाहरूमा खेल समाप्त हुन्छ, र त्यसपछि कसरी तपाईंलाई पुनः सुरु गर्न प्रेरित गरिन्छ।
के निर्माण गर्ने
तपाईंले यी नियमहरू आफ्नो खेलमा थप्नु पर्नेछ:
- खेल जित्नुहोस्। सबै शत्रु जहाजहरू नष्ट भएपछि, तपाईं खेल जित्नुहुन्छ। साथै, कुनै प्रकारको विजय सन्देश देखाउनुहोस्।
- पुनः सुरु गर्नुहोस्। जब सबै जीवन समाप्त हुन्छ वा खेल जितिन्छ, तपाईंले खेल पुनः सुरु गर्ने तरिका दिनुपर्छ। सम्झनुहोस्! तपाईंले खेललाई पुनः आरम्भ गर्नुपर्नेछ र अघिल्लो खेलको अवस्था हटाउनु पर्नेछ।
सिफारिस गरिएका चरणहरू
your-work उप फोल्डरमा तपाईंको लागि सिर्जना गरिएका फाइलहरू पत्ता लगाउनुहोस्। यसले निम्न समावेश गर्नुपर्छ:
-| assets
-| enemyShip.png
-| player.png
-| laserRed.png
-| life.png
-| index.html
-| app.js
-| package.json
तपाईं आफ्नो परियोजना your_work फोल्डरमा निम्न टाइप गरेर सुरु गर्नुहोस्:
cd your-work
npm start
माथिको कमाण्डले http://localhost:5000 ठेगानामा HTTP सर्भर सुरु गर्नेछ। ब्राउजर खोल्नुहोस् र उक्त ठेगाना इनपुट गर्नुहोस्। तपाईंको खेल खेल्न योग्य अवस्थामा हुनुपर्छ।
टिप: Visual Studio Code मा चेतावनीहरू रोक्नको लागि,
window.onloadफङ्सनलाईgameLoopIdकल गर्न सम्पादन गर्नुहोस् (बिनाlet), र फाइलको माथिlet gameLoopId;स्वतन्त्र रूपमा घोषणा गर्नुहोस्।
कोड थप्नुहोस्
-
अन्त्यको अवस्था ट्र्याक गर्नुहोस्। शत्रुहरूको संख्या ट्र्याक गर्ने वा नायक जहाज नष्ट भएको छ कि छैन भनेर ट्र्याक गर्ने कोड थप्नुहोस्। यी दुई फङ्सनहरू थप्नुहोस्:
function isHeroDead() { return hero.life <= 0; } function isEnemiesDead() { const enemies = gameObjects.filter((go) => go.type === "Enemy" && !go.dead); return enemies.length === 0; } -
सन्देश ह्यान्डलरहरूमा तर्क थप्नुहोस्।
eventEmitterसम्पादन गरेर यी अवस्थाहरू ह्यान्डल गर्नुहोस्:eventEmitter.on(Messages.COLLISION_ENEMY_LASER, (_, { first, second }) => { first.dead = true; second.dead = true; hero.incrementPoints(); if (isEnemiesDead()) { eventEmitter.emit(Messages.GAME_END_WIN); } }); eventEmitter.on(Messages.COLLISION_ENEMY_HERO, (_, { enemy }) => { enemy.dead = true; hero.decrementLife(); if (isHeroDead()) { eventEmitter.emit(Messages.GAME_END_LOSS); return; // loss before victory } if (isEnemiesDead()) { eventEmitter.emit(Messages.GAME_END_WIN); } }); eventEmitter.on(Messages.GAME_END_WIN, () => { endGame(true); }); eventEmitter.on(Messages.GAME_END_LOSS, () => { endGame(false); }); -
नयाँ सन्देश प्रकारहरू थप्नुहोस्। यी सन्देशहरू constants वस्तुमा थप्नुहोस्:
GAME_END_LOSS: "GAME_END_LOSS", GAME_END_WIN: "GAME_END_WIN", -
पुनः सुरु गर्ने कोड थप्नुहोस्। चयन गरिएको बटन थिच्दा खेल पुनः सुरु गर्ने कोड थप्नुहोस्।
- कुञ्जी थिच्ने सुन्नुहोस्
Enter। तपाईंको विन्डोको eventListener सम्पादन गरेर यो थिच्ने सुन्नुहोस्:
else if(evt.key === "Enter") { eventEmitter.emit(Messages.KEY_EVENT_ENTER); }-
पुनः सुरु सन्देश थप्नुहोस्। यो सन्देश तपाईंको Messages constant मा थप्नुहोस्:
KEY_EVENT_ENTER: "KEY_EVENT_ENTER",
- कुञ्जी थिच्ने सुन्नुहोस्
-
खेलका नियमहरू कार्यान्वयन गर्नुहोस्। निम्न खेलका नियमहरू कार्यान्वयन गर्नुहोस्:
-
खेल जित्ने अवस्था। सबै शत्रु जहाजहरू नष्ट भएपछि, विजय सन्देश देखाउनुहोस्।
- पहिलो,
displayMessage()फङ्सन सिर्जना गर्नुहोस्:
function displayMessage(message, color = "red") { ctx.font = "30px Arial"; ctx.fillStyle = color; ctx.textAlign = "center"; ctx.fillText(message, canvas.width / 2, canvas.height / 2); }endGame()फङ्सन सिर्जना गर्नुहोस्:
function endGame(win) { clearInterval(gameLoopId); // set a delay so we are sure any paints have finished setTimeout(() => { ctx.clearRect(0, 0, canvas.width, canvas.height); ctx.fillStyle = "black"; ctx.fillRect(0, 0, canvas.width, canvas.height); if (win) { displayMessage( "Victory!!! Pew Pew... - Press [Enter] to start a new game Captain Pew Pew", "green" ); } else { displayMessage( "You died !!! Press [Enter] to start a new game Captain Pew Pew" ); } }, 200) } - पहिलो,
-
पुनः सुरु गर्ने तर्क। जब सबै जीवन समाप्त हुन्छ वा खेल जितिन्छ, खेल पुनः सुरु गर्न सकिने सन्देश देखाउनुहोस्। साथै, पुनः सुरु कुञ्जी थिच्दा खेल पुनः सुरु गर्नुहोस् (तपाईंले कुन कुञ्जी पुनः सुरु गर्न म्याप गर्नुपर्छ भन्ने निर्णय गर्न सक्नुहुन्छ)।
resetGame()फङ्सन सिर्जना गर्नुहोस्:
function resetGame() { if (gameLoopId) { clearInterval(gameLoopId); eventEmitter.clear(); initGame(); gameLoopId = setInterval(() => { ctx.clearRect(0, 0, canvas.width, canvas.height); ctx.fillStyle = "black"; ctx.fillRect(0, 0, canvas.width, canvas.height); drawPoints(); drawLife(); updateGameObjects(); drawGameObjects(ctx); }, 100); } } -
initGame()मा खेल पुनः सेट गर्नeventEmitterमा कल थप्नुहोस्:eventEmitter.on(Messages.KEY_EVENT_ENTER, () => { resetGame(); }); -
EventEmitter मा
clear()फङ्सन थप्नुहोस्:clear() { this.listeners = {}; }
-
👽 💥 🚀 बधाई छ, कप्तान! तपाईंको खेल पूरा भयो! राम्रो काम! 🚀 💥 👽
GitHub Copilot Agent Challenge 🚀
Agent मोड प्रयोग गरेर निम्न चुनौती पूरा गर्नुहोस्:
विवरण: स्तर प्रगति प्रणाली लागू गरेर स्पेस गेमलाई सुधार गर्नुहोस् जसमा बढ्दो कठिनाइ र बोनस सुविधाहरू समावेश छन्।
प्रेरणा: बहु-स्तरीय स्पेस गेम प्रणाली सिर्जना गर्नुहोस् जहाँ प्रत्येक स्तरमा बढी शत्रु जहाजहरू हुन्छन् जसको गति र स्वास्थ्य बढ्दो हुन्छ। प्रत्येक स्तरसँग स्कोरिङ गुणक थप्नुहोस्, र पावर-अपहरू (जस्तै, द्रुत फायर वा शिल्ड) लागू गर्नुहोस् जुन शत्रुहरू नष्ट हुँदा अनियमित रूपमा देखा पर्छ। स्तर पूरा गर्ने बोनस समावेश गर्नुहोस् र हालको स्तर स्कोर र जीवनसँगै स्क्रिनमा देखाउनुहोस्।
🚀 चुनौती
ध्वनि थप्नुहोस्! के तपाईं आफ्नो खेल खेललाई सुधार गर्न ध्वनि थप्न सक्नुहुन्छ, जस्तै लेजर हिट हुँदा, वा नायक मर्दा वा जित्दा? sandbox हेरेर JavaScript प्रयोग गरेर ध्वनि कसरी बजाउने सिक्नुहोस्।
पोस्ट-लेक्चर क्विज
समीक्षा र आत्म अध्ययन
तपाईंको असाइनमेन्ट भनेको नयाँ नमूना खेल सिर्जना गर्नु हो, त्यसैले तपाईंले निर्माण गर्न सक्ने खेलको प्रकार हेर्न केही रोचक खेलहरू अन्वेषण गर्नुहोस्।
असाइनमेन्ट
अस्वीकरण:
यो दस्तावेज़ AI अनुवाद सेवा Co-op Translator प्रयोग गरेर अनुवाद गरिएको छ। हामी शुद्धताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादहरूमा त्रुटिहरू वा अशुद्धताहरू हुन सक्छ। यसको मूल भाषा मा रहेको मूल दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।