33 KiB
स्पेस गेम बनाउनुहोस् भाग ६: अन्त्य र पुनः सुरु
प्रत्येक उत्कृष्ट खेलमा स्पष्ट अन्त्य अवस्था र सहज पुनः सुरु गर्ने प्रणाली आवश्यक हुन्छ। तपाईंले आन्दोलन, युद्ध, र स्कोरिङसहितको प्रभावशाली स्पेस गेम बनाइसक्नुभएको छ - अब यसलाई पूर्ण महसुस गराउने अन्तिम टुक्राहरू थप्ने समय हो।
तपाईंको खेल हाल अनिश्चितकालसम्म चल्छ, जस्तै नासाले १९७७ मा प्रक्षेपण गरेका Voyager प्रोबहरू - दशकौंसम्म स्पेसमा यात्रा गरिरहेका छन्। यद्यपि यो स्पेस अन्वेषणका लागि ठीक छ, खेलहरूलाई सन्तोषजनक अनुभव सिर्जना गर्न परिभाषित अन्त्य बिन्दुहरू आवश्यक हुन्छ।
आज, हामी सही जित/हार अवस्था र पुनः सुरु गर्ने प्रणाली कार्यान्वयन गर्नेछौं। यस पाठको अन्त्यसम्ममा, तपाईंले एक परिष्कृत खेल बनाइसक्नुभएको हुनेछ जसलाई खेलाडीहरूले पूरा गर्न र पुनः खेल्न सक्नेछन्, जस्तै क्लासिक आर्केड खेलहरूले माध्यमलाई परिभाषित गरे।
प्रि-लेक्चर क्विज
खेलको अन्त्य अवस्था बुझ्दै
तपाईंको खेल कहिले अन्त्य हुनुपर्छ? यो आधारभूत प्रश्नले प्रारम्भिक आर्केड युगदेखि खेल डिजाइनलाई आकार दिएको छ। Pac-Man तब अन्त्य हुन्छ जब तपाईं भूतहरूद्वारा समातिनुहुन्छ वा सबै डटहरू सफा गर्नुहुन्छ, जबकि Space Invaders तब अन्त्य हुन्छ जब एलियनहरू तल पुग्छन् वा तपाईंले तिनीहरूलाई सबै नष्ट गर्नुहुन्छ।
खेल सिर्जनाकर्ताको रूपमा, तपाईंले जित र हारको अवस्था परिभाषित गर्नुहुन्छ। हाम्रो स्पेस गेमका लागि, यहाँ प्रमाणित दृष्टिकोणहरू छन् जसले आकर्षक गेमप्ले सिर्जना गर्छ:
Nशत्रु जहाजहरू नष्ट भएका छन्: यदि तपाईंले खेललाई विभिन्न स्तरहरूमा विभाजन गर्नुभएको छ भने, स्तर पूरा गर्नNशत्रु जहाजहरू नष्ट गर्न आवश्यक हुन्छ।- तपाईंको जहाज नष्ट भएको छ: केही खेलहरूमा तपाईंको जहाज नष्ट भएमा खेल हारिन्छ। अर्को सामान्य दृष्टिकोण भनेको जीवनको अवधारणा हो। प्रत्येक पटक तपाईंको जहाज नष्ट हुँदा एक जीवन घट्छ। सबै जीवन समाप्त भएपछि खेल हारिन्छ।
- तपाईंले
Nअंक सङ्कलन गर्नुभएको छ: अर्को सामान्य अन्त्य अवस्था भनेको अंक सङ्कलन गर्नु हो। तपाईंले कसरी अंक प्राप्त गर्नुहुन्छ भन्ने कुरा तपाईंको निर्णयमा निर्भर हुन्छ, तर शत्रु जहाज नष्ट गर्दा वा नष्ट हुँदा वस्तुहरू सङ्कलन गर्दा अंक प्रदान गर्नु सामान्य हो। - स्तर पूरा गर्नुहोस्: यसमा
Xशत्रु जहाजहरू नष्ट गर्नु,Yअंक सङ्कलन गर्नु वा विशेष वस्तु सङ्कलन गर्नु जस्ता विभिन्न अवस्थाहरू समावेश हुन सक्छ।
खेल पुनः सुरु गर्ने कार्यक्षमता कार्यान्वयन गर्दै
राम्रो खेलहरूले सहज पुनः सुरु गर्ने प्रणालीमार्फत पुनः खेल्न प्रोत्साहन दिन्छ। जब खेलाडीहरूले खेल पूरा गर्छन् (वा हार्छन्), तिनीहरू प्रायः तुरुन्तै पुनः प्रयास गर्न चाहन्छन् - चाहे आफ्नो स्कोर हराउन वा आफ्नो प्रदर्शन सुधार गर्न।
Tetris यसलाई पूर्ण रूपमा उदाहरण दिन्छ: जब तपाईंको ब्लकहरू माथि पुग्छन्, तपाईंले जटिल मेनुहरू नेभिगेट नगरी तुरुन्तै नयाँ खेल सुरु गर्न सक्नुहुन्छ। हामी यस्तै पुनः सुरु गर्ने प्रणाली निर्माण गर्नेछौं जसले खेलको अवस्था सफा रूपमा रिसेट गर्छ र खेलाडीहरूलाई छिटो पुनः खेलमा फर्काउँछ।
✅ प्रतिबिम्ब: तपाईंले खेलेका खेलहरूको बारेमा सोच्नुहोस्। ती खेलहरू कुन अवस्थामा अन्त्य हुन्छन्, र तपाईंलाई कसरी पुनः सुरु गर्न प्रेरित गरिन्छ? पुनः सुरु गर्ने अनुभवलाई सहज बनाउने के हो र निराशाजनक बनाउने के हो?
तपाईंले के निर्माण गर्नुहुनेछ
तपाईंले आफ्नो परियोजनालाई पूर्ण खेल अनुभवमा रूपान्तरण गर्ने अन्तिम सुविधाहरू कार्यान्वयन गर्नुहुनेछ। यी तत्वहरूले परिष्कृत खेलहरूलाई आधारभूत प्रोटोटाइपहरूबाट अलग गर्छ।
आज हामीले थप्ने कुरा:
- जितको अवस्था: सबै शत्रुहरूलाई नष्ट गर्नुहोस् र उचित उत्सव पाउनुहोस् (तपाईंले यसलाई कमाउनुभएको छ!)
- हारको अवस्था: जीवन समाप्त गर्नुहोस् र हारको स्क्रिनको सामना गर्नुहोस्
- पुनः सुरु गर्ने प्रणाली: Enter थिचेर तुरुन्तै पुनः खेलमा फर्कनुहोस् - किनकि एक खेल कहिल्यै पर्याप्त हुँदैन
- राज्य व्यवस्थापन: प्रत्येक पटक सफा सुरुवात - कुनै बाँकी शत्रुहरू वा अघिल्लो खेलबाट अजीब गडबडीहरू छैनन्
सुरु गर्दै
आफ्नो विकास वातावरण तयार गरौं। तपाईंले अघिल्लो पाठहरूबाट आफ्नो स्पेस गेम फाइलहरू तयार राख्नुपर्छ।
तपाईंको परियोजना यस्तो देखिनुपर्छ:
-| assets
-| enemyShip.png
-| player.png
-| laserRed.png
-| life.png
-| index.html
-| app.js
-| package.json
आफ्नो विकास सर्भर सुरु गर्नुहोस्:
cd your-work
npm start
यो आदेश:
http://localhost:5000मा स्थानीय सर्भर चलाउँछ- तपाईंको फाइलहरू ठीकसँग सेवा दिन्छ
- परिवर्तन गर्दा स्वतः ताजा हुन्छ
http://localhost:5000 आफ्नो ब्राउजरमा खोल्नुहोस् र तपाईंको खेल चलिरहेको छ भनी पुष्टि गर्नुहोस्। तपाईंले चलाउन, गोली हान्न, र शत्रुहरूसँग अन्तरक्रिया गर्न सक्षम हुनुहुनेछ। एकपटक पुष्टि भएपछि, हामी कार्यान्वयनको प्रक्रियामा अगाडि बढ्न सक्छौं।
💡 प्रो टिप: Visual Studio Code मा चेतावनीहरूबाट बच्नको लागि,
gameLoopIdलाई आफ्नो फाइलको माथिlet gameLoopId;को रूपमा घोषणा गर्नुहोस्, यसको सट्टाwindow.onloadफङ्सन भित्र घोषणा गर्ने। यसले आधुनिक JavaScript भेरिएबल घोषणा गर्ने उत्तम अभ्यासलाई पछ्याउँछ।
कार्यान्वयन चरणहरू
चरण १: अन्त्य अवस्था ट्र्याक गर्ने फङ्सनहरू सिर्जना गर्नुहोस्
हामीलाई खेल कहिले अन्त्य हुनुपर्छ भनेर अनुगमन गर्ने फङ्सनहरू आवश्यक छ। जस्तै अन्तर्राष्ट्रिय स्पेस स्टेशनमा सेन्सरहरूले महत्त्वपूर्ण प्रणालीहरू निरन्तर अनुगमन गर्छन्, यी फङ्सनहरूले खेलको अवस्था निरन्तर जाँच गर्नेछन्।
function isHeroDead() {
return hero.life <= 0;
}
function isEnemiesDead() {
const enemies = gameObjects.filter((go) => go.type === "Enemy" && !go.dead);
return enemies.length === 0;
}
भित्र के भइरहेको छ:
- जाँच्छ कि हाम्रो हिरोको जीवन समाप्त भएको छ कि छैन (दु:खद!)
- गणना गर्छ कि कति शत्रुहरू अझै जीवित छन्
trueफर्काउँछ जब युद्धक्षेत्र शत्रुहरूबाट खाली हुन्छ- साधारण true/false तर्क प्रयोग गर्छ ताकि सबै कुरा सरल रहोस्
- फिल्टर गर्छ सबै खेल वस्तुहरूबाट जीवितहरू पत्ता लगाउन
चरण २: अन्त्य अवस्थाका लागि इभेन्ट ह्यान्डलरहरू अपडेट गर्नुहोस्
अब हामी यी अवस्था जाँचलाई खेलको इभेन्ट प्रणालीसँग जोड्नेछौं। प्रत्येक पटक टक्कर हुँदा, खेलले मूल्याङ्कन गर्नेछ कि यसले अन्त्य अवस्था ट्रिगर गर्छ कि गर्दैन। यसले महत्त्वपूर्ण खेल घटनाहरूका लागि तत्काल प्रतिक्रिया सिर्जना गर्छ।
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);
});
यहाँ के भइरहेको छ:
- लेजरले शत्रुलाई हान्छ: दुबै गायब हुन्छन्, तपाईंले अंक प्राप्त गर्नुहुन्छ, र हामी जाँच गर्छौं कि तपाईंले जित्नुभएको छ कि छैन
- शत्रुले तपाईंलाई हान्छ: तपाईंले जीवन गुमाउनुहुन्छ, र हामी जाँच गर्छौं कि तपाईं अझै जीवित हुनुहुन्छ कि छैन
- स्मार्ट क्रम: हामी पहिले हारको जाँच गर्छौं (कसैले पनि एकै समयमा जित्न र हार्न चाहँदैन!)
- तत्काल प्रतिक्रिया: केही महत्त्वपूर्ण घटना भएलगत्तै खेललाई थाहा हुन्छ
चरण ३: नयाँ सन्देश स्थिरांकहरू थप्नुहोस्
तपाईंले आफ्नो Messages स्थिर वस्तुमा नयाँ सन्देश प्रकारहरू थप्न आवश्यक छ। यी स्थिरांकहरूले स्थिरता कायम राख्न र तपाईंको इभेन्ट प्रणालीमा टाइपोहरू रोक्न मद्दत गर्छ।
GAME_END_LOSS: "GAME_END_LOSS",
GAME_END_WIN: "GAME_END_WIN",
माथिकोमा, हामीले:
- खेल अन्त्य घटनाहरूका लागि स्थिरांकहरू थपेका छौं ताकि स्थिरता कायम रहोस्
- वर्णनात्मक नामहरू प्रयोग गरेका छौं जसले स्पष्ट रूपमा घटनाको उद्देश्य संकेत गर्छ
- सन्देश प्रकारहरूको विद्यमान नामकरण परम्परा पछ्याएका छौं
चरण ४: पुनः सुरु गर्ने नियन्त्रणहरू कार्यान्वयन गर्नुहोस्
अब तपाईंले खेलाडीहरूलाई खेल पुनः सुरु गर्न अनुमति दिने किबोर्ड नियन्त्रणहरू थप्नुहुनेछ। Enter कुञ्जी प्राकृतिक विकल्प हो किनभने यो सामान्यत: कार्यहरू पुष्टि गर्ने र नयाँ खेल सुरु गर्नेसँग सम्बन्धित छ।
तपाईंको विद्यमान keydown इभेन्ट लिस्नरमा Enter कुञ्जी पत्ता लगाउने कुरा थप्नुहोस्:
else if(evt.key === "Enter") {
eventEmitter.emit(Messages.KEY_EVENT_ENTER);
}
नयाँ सन्देश स्थिरांक थप्नुहोस्:
KEY_EVENT_ENTER: "KEY_EVENT_ENTER",
तपाईंलाई थाहा हुनुपर्ने कुरा:
- तपाईंको विद्यमान किबोर्ड इभेन्ट ह्यान्डलिङ प्रणालीलाई विस्तार गर्छ
- 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);
}
चरणबद्ध रूपमा, यहाँ के भइरहेको छ:
- फन्ट साइज र परिवार सेट गर्छ ताकि पाठ स्पष्ट र पढ्न योग्य होस्
- रंग प्यारामिटर लागू गर्छ जहाँ "रातो" चेतावनीको लागि डिफल्ट हो
- क्यानभासमा पाठलाई क्षैतिज र ठाडो रूपमा केन्द्रित गर्छ
- आधुनिक JavaScript डिफल्ट प्यारामिटर प्रयोग गर्छ ताकि रंग विकल्प लचिलो होस्
- क्यानभास 2D सन्दर्भ प्रयोग गर्छ ताकि पाठ प्रत्यक्ष रूपमा रेंडर होस्
endGame() फङ्सन सिर्जना गर्नुहोस्:
function endGame(win) {
clearInterval(gameLoopId);
// Set a delay to ensure any pending renders complete
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)
}
यो फङ्सनले के गर्छ:
- सबै कुरा स्थिर बनाउँछ - अब कुनै जहाज वा लेजरहरू चल्दैनन्
- सानो ब्रेक लिन्छ (२००ms) ताकि अन्तिम फ्रेम पूरा गर्न सकियोस्
- स्क्रिन सफा गर्छ र नाटकीय प्रभावका लागि कालो रंग लगाउँछ
- विजेता र हार्नेहरूका लागि फरक सन्देश देखाउँछ
- रंग कोड गर्छ - राम्रोको लागि हरियो, नराम्रोको लागि रातो
- **खेलाडीहरूलाई स्पष्ट रूपमा बताउँछ कि कसरी पुनः खेलमा फर्कन सकिन्छ
चरण ६: खेल रिसेट कार्यक्षमता कार्यान्वयन गर्नुहोस्
रिसेट प्रणालीले हालको खेलको अवस्था पूर्ण रूपमा सफा गर्न र नयाँ खेल सत्र सुरु गर्न आवश्यक छ। यसले खेलाडीहरूलाई अघिल्लो खेलबाट कुनै बाँकी डाटाबिना सफा सुरुवात सुनिश्चित गर्छ।
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);
}
}
प्रत्येक भाग बुझौं:
- जाँच्छ कि खेल लूप हाल चलिरहेको छ कि छैन रिसेट गर्नु अघि
- विद्यमान खेल लूप सफा गर्छ ताकि सबै हालको खेल गतिविधि रोकियोस्
- सबै इभेन्ट लिस्नरहरू हटाउँछ ताकि मेमोरी लीक रोकियोस्
- ताजा वस्तुहरू र भेरिएबलहरूसँग खेलको अवस्था पुनः आरम्भ गर्छ
- सबै आवश्यक खेल फङ्सनहरूसँग नयाँ खेल लूप सुरु गर्छ
- समान १००ms अन्तराल कायम राख्छ ताकि खेल प्रदर्शन स्थिर रहोस्
Enter कुञ्जी इभेन्ट ह्यान्डलरलाई तपाईंको initGame() फङ्सनमा थप्नुहोस्:
eventEmitter.on(Messages.KEY_EVENT_ENTER, () => {
resetGame();
});
तपाईंको EventEmitter क्लासमा clear() मेथड थप्नुहोस्:
clear() {
this.listeners = {};
}
महत्त्वपूर्ण बिन्दुहरू सम्झनुहोस्:
- Enter कुञ्जी प्रेसलाई खेल रिसेट कार्यक्षमतासँग जोड्छ
- खेल आरम्भ गर्दा यो इभेन्ट लिस्नर दर्ता गर्छ
- खेलहरू बीच इभेन्ट ह्यान्डलरहरू सफा गरेर मेमोरी लीक रोक्छ
- लिस्नर वस्तुलाई ताजा आरम्भका लागि खाली अवस्थामा रिसेट गर्छ
बधाई छ! 🎉
👽 💥 🚀 तपाईंले जमिनदेखि पूर्ण खेल सफलतापूर्वक निर्माण गर्नुभएको छ। जस्तै १९७० को दशकमा पहिलो भिडियो खेल बनाउने प्रोग्रामरहरूले कोडका लाइनहरूलाई अन्तरक्रियात्मक अनुभवमा रूपान्तरण गरे, तपाईंले उचित खेल यान्त्रिकी र प्रयोगकर्ता प्रतिक्रिया सहित खेल निर्माण गर्नुभएको छ। 🚀 💥 👽
तपाईंले हासिल गर्नुभएको छ:
- जित र हारको अवस्था कार्यान्वयन गर्नुभएको छ प्रयोगकर्ता प्रतिक्रियासहित
- सहज पुनः सुरु गर्ने प्रणाली सिर्जना गर्नुभएको छ निरन्तर गेमप्लेका लागि
- खेल अवस्थाहरूका लागि स्पष्ट दृश्य सञ्चार डिजाइन गर्नुभएको छ
- जटिल खेल अवस्था संक्रमण र सफाइ व्यवस्थापन गर्नुभएको छ
- सबै घटकहरूलाई एक सुसंगत, खेल्न योग्य खेलमा संयोजन गर्नुभएको छ
GitHub Copilot Agent Challenge 🚀
निम्न चुनौती पूरा गर्न Agent मोड प्रयोग गर्नुहोस्:
विवरण: स्तर प्रगति प्रणाली कार्यान्वयन गरेर स्पेस गेमलाई सुधार गर्नुहोस् जसमा बढ्दो कठिनाइ र बोनस सुविधाहरू समावेश छन्।
प्रेरणा: बहु-स्तरीय स्पेस गेम प्रणाली सिर्जना गर्नुहोस् जहाँ प्रत्येक स्तरमा बढी शत्रु जहाजहरू उच्च गति र स्वास्थ्यका साथ हुन्छन्। प्रत्येक स्तरसँग बढ्ने स्कोरिङ गुणक थप्नुहोस्, र पावर-अपहरू (जस्तै, द्रुत फायर वा शील्ड) कार्यान्वयन गर्नुहोस् जुन शत्रुहरू नष्ट हुँदा अनियमित रूपमा देखा पर्छ। स्तर पूरा गर्ने बोनस समावेश गर्नुहोस् र विद्यमान स्कोर र जीवनसँगै स्क्रिनमा हालको स्तर देखाउनुहोस्।
Agent मोड को बारेमा थप जान्नुहोस्।
🚀 वैकल्पिक सुधार चुनौती
तपाईंको खेलमा अडियो थप्नुहोस्: आफ्नो गेमप्ले अनुभवलाई सुधार गर्न ध्वनि प्रभाव कार्यान्वयन गर्नुहोस्! निम्नका लागि अडियो थप्ने विचार गर्नुहोस्:
- लेजर शटहरू जब खेलाडीले फायर गर्छ
- शत्रु विनाश जब जहाजहरू हानिन्छन्
- हिरो क्षति जब खेलाडीले हान्छ
- जितको संगीत जब खेल जितिन्छ
- हारको ध्वनि जब खेल हारिन्छ
अडियो कार्यान्वयन उदाहरण:
// Create audio objects
const laserSound = new Audio('assets/laser.wav');
const explosionSound = new Audio('assets/explosion.wav');
// Play sounds during game events
function playLaserSound() {
laserSound.currentTime = 0; // Reset to beginning
laserSound.play();
}
तपाईंलाई थाहा हुनुपर्ने कुरा:
- विभिन्न ध्वनि प्रभावहरूको लागि अडियो वस्तुहरू सिर्जना गर्छ
currentTimeरिसेट गर्छ ताकि द्रुत फायर ध्वनि प्रभावहरू सम्भव होस्- ब्राउजरको स्वतःप्ले नीतिहरू ह्यान्डल गर्छ प्रयोगकर्ता अन्तरक्रियाबाट ध्वनि ट्रिगर गरेर
- अडियो भोल्युम र टाइमिङ व्यवस्थापन गर्छ ताकि खेल अनुभव राम्रो होस्
💡 शिक्षण स्रोत: अडियो स्यान्डबक्स अन्वेषण गर्नुहोस् ताकि JavaScript खेलहरूमा अडियो कार्यान्वयनको बारेमा थप जान्न सकियोस्।
पोस्ट-लेक्चर क्विज
समीक्षा र आत्म अध्ययन
तपाईंको असाइनमेन्ट भनेको नयाँ नमूना खेल सिर्जना गर्नु हो, त्यसैले बाहिरका केही रोचक खेलहरू अन्वेषण गर्नुहोस् ताकि तपाईंले कुन प्रकारको खेल निर्माण गर्न सक्नुहुन्छ भन्ने थाहा पाउन सकियोस्।
असाइनमेन्ट
अस्वीकरण:
यो दस्तावेज़ AI अनुवाद सेवा Co-op Translator प्रयोग गरेर अनुवाद गरिएको छ। हामी शुद्धताको लागि प्रयास गर्छौं, तर कृपया ध्यान दिनुहोस् कि स्वचालित अनुवादमा त्रुटिहरू वा अशुद्धताहरू हुन सक्छ। यसको मूल भाषा मा रहेको दस्तावेज़लाई आधिकारिक स्रोत मानिनुपर्छ। महत्वपूर्ण जानकारीको लागि, व्यावसायिक मानव अनुवाद सिफारिस गरिन्छ। यस अनुवादको प्रयोगबाट उत्पन्न हुने कुनै पनि गलतफहमी वा गलत व्याख्याको लागि हामी जिम्मेवार हुने छैनौं।