You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Web-Dev-For-Beginners/translations/ta/6-space-game/6-end-condition
leestott 5f3450ce13
🌐 Update translations via Co-op Translator
2 months ago
..
solution 🌐 Update translations via Co-op Translator 2 months ago
your-work 🌐 Update translations via Co-op Translator 2 months ago
README.md 🌐 Update translations via Co-op Translator 2 months ago
assignment.md 🌐 Update translations via Co-op Translator 2 months ago

README.md

விண்வெளி விளையாட்டு உருவாக்கம் பகுதி 6: முடிவு மற்றும் மீண்டும் தொடக்கம்

முன்-வகுப்பு வினாடி வினா

முன்-வகுப்பு வினாடி வினா

ஒரு விளையாட்டில் முடிவு நிலை (end condition) என்பதை வெளிப்படுத்த பல வழிகள் உள்ளன. விளையாட்டின் உருவாக்குனராக நீங்கள் விளையாட்டின் முடிவை எதற்காக முடிவடைகிறது என்று தீர்மானிக்க வேண்டும். இதோ சில காரணங்கள், நீங்கள் இதுவரை உருவாக்கிய விண்வெளி விளையாட்டைப் பொருத்து:

  • N எதிரி கப்பல்கள் அழிக்கப்பட்டுள்ளன: ஒரு விளையாட்டை பல நிலைகளாகப் பிரிக்கும்போது, ஒரு நிலையை முடிக்க N எதிரி கப்பல்களை அழிக்க வேண்டும் என்பது பொதுவானது.
  • உங்கள் கப்பல் அழிக்கப்பட்டுள்ளது: உங்கள் கப்பல் அழிக்கப்பட்டால் நீங்கள் விளையாட்டை இழக்கிறீர்கள் என்ற விளையாட்டுகள் உள்ளன. மற்றொரு பொதுவான அணுகுமுறை, "வாழ்க்கைகள்" என்ற கருத்தை கொண்டிருப்பது. உங்கள் கப்பல் அழிக்கப்படும் ஒவ்வொரு முறையும் ஒரு வாழ்க்கை குறைக்கப்படும். அனைத்து வாழ்க்கைகளும் இழக்கப்பட்ட பிறகு நீங்கள் விளையாட்டை இழக்கிறீர்கள்.
  • நீங்கள் N புள்ளிகளைச் சேகரித்துள்ளீர்கள்: மற்றொரு பொதுவான முடிவு நிலை, நீங்கள் புள்ளிகளைச் சேகரிக்க வேண்டும் என்பதாகும். புள்ளிகளை எவ்வாறு பெறுவது என்பது உங்கள் விருப்பத்திற்கு உட்பட்டது, ஆனால் எதிரி கப்பலை அழிப்பது அல்லது அழிக்கப்பட்ட பொருட்களைச் சேகரிப்பது போன்ற செயல்பாடுகளுக்கு புள்ளிகளை வழங்குவது பொதுவானது.
  • ஒரு நிலையை முடிக்கவும்: இது பல நிலைகளைக் கொண்டிருக்கலாம், உதாரணமாக X எதிரி கப்பல்கள் அழிக்கப்பட்டுள்ளன, Y புள்ளிகள் சேகரிக்கப்பட்டுள்ளன அல்லது ஒரு குறிப்பிட்ட பொருள் சேகரிக்கப்பட்டுள்ளது.

மீண்டும் தொடக்கம்

மக்கள் உங்கள் விளையாட்டை விரும்பினால், அவர்கள் அதை மீண்டும் விளையாட விரும்புவார்கள். விளையாட்டு எந்த காரணத்திற்காக முடிவடைந்தாலும், மீண்டும் தொடங்கும் விருப்பத்தை வழங்க வேண்டும்.

ஒரு விளையாட்டின் முடிவு நிலைகள் என்னென்ன, மற்றும் அதை மீண்டும் தொடங்க எவ்வாறு உங்களைத் தூண்டுகிறது என்பதைப் பற்றி சிந்திக்கவும்.

என்ன உருவாக்க வேண்டும்

இந்த விதிகளை உங்கள் விளையாட்டில் சேர்க்க வேண்டும்:

  1. விளையாட்டை வெல்லுதல்: அனைத்து எதிரி கப்பல்களும் அழிக்கப்பட்ட பிறகு, நீங்கள் விளையாட்டை வெல்லுகிறீர்கள். மேலும், ஒரு வெற்றி செய்தியை காட்டவும்.
  2. மீண்டும் தொடக்கம்: உங்கள் அனைத்து வாழ்க்கைகளும் இழக்கப்பட்ட பிறகு அல்லது விளையாட்டை வென்ற பிறகு, விளையாட்டை மீண்டும் தொடங்கும் வழியை வழங்க வேண்டும். நினைவில் கொள்ளுங்கள்! விளையாட்டை மீண்டும் தொடங்க நீங்கள் அதை மீண்டும் ஆரம்பிக்க வேண்டும், மற்றும் முந்தைய விளையாட்டு நிலை அழிக்கப்பட வேண்டும்.

பரிந்துரைக்கப்பட்ட படிகள்

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 சர்வரை தொடங்கும். ஒரு உலாவியில் அந்த முகவரியை உள்ளிடவும். உங்கள் விளையாட்டு விளையாடக்கூடிய நிலையில் இருக்க வேண்டும்.

tip: Visual Studio Code-இல் எச்சரிக்கைகளை தவிர்க்க, window.onload செயல்பாட்டை gameLoopId ஐ (இல்லாமல் let) அழைக்க மாற்றவும், மற்றும் gameLoopId ஐ கோப்பின் மேல் பகுதியில் தனியாக அறிவிக்கவும்: let gameLoopId;

குறியீடு சேர்க்கவும்

  1. முடிவு நிலையை கண்காணிக்கவும். எதிரிகளின் எண்ணிக்கையை அல்லது ஹீரோ கப்பல் அழிக்கப்பட்டதா என்பதை கண்காணிக்க இந்த இரண்டு செயல்பாடுகளைச் சேர்க்கவும்:

    function isHeroDead() {
      return hero.life <= 0;
    }
    
    function isEnemiesDead() {
      const enemies = gameObjects.filter((go) => go.type === "Enemy" && !go.dead);
      return enemies.length === 0;
    }
    
  2. செய்தி கையாளுநர்களுக்கு தர்க்கத்தைச் சேர்க்கவும். இந்த நிலைகளை கையாள 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);
    });
    
  3. புதிய செய்தி வகைகளைச் சேர்க்கவும். இந்த Messages-ஐ constants பொருளில் சேர்க்கவும்:

    GAME_END_LOSS: "GAME_END_LOSS",
    GAME_END_WIN: "GAME_END_WIN",
    
  4. மீண்டும் தொடங்கும் குறியீடு. தேர்ந்தெடுக்கப்பட்ட பொத்தானை அழுத்தும்போது விளையாட்டை மீண்டும் தொடங்கும் குறியீட்டைச் சேர்க்கவும்.

    1. கீபோர்டு அழுத்தம் Enter ஐ கேட்கவும். உங்கள் window-இன் eventListener ஐ இந்த அழுத்தத்தை கேட்க திருத்தவும்:
     else if(evt.key === "Enter") {
        eventEmitter.emit(Messages.KEY_EVENT_ENTER);
      }
    
    1. மீண்டும் தொடங்கும் செய்தி சேர்க்கவும். இந்த Message-ஐ உங்கள் Messages constant-இல் சேர்க்கவும்:

      KEY_EVENT_ENTER: "KEY_EVENT_ENTER",
      
  5. விளையாட்டு விதிகளை செயல்படுத்தவும். பின்வரும் விளையாட்டு விதிகளை செயல்படுத்தவும்:

    1. விளையாட்டு வெற்றி நிலை. அனைத்து எதிரி கப்பல்களும் அழிக்கப்பட்ட பிறகு, வெற்றி செய்தியை காட்டவும்.

      1. முதலில், ஒரு 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);
      }
      
      1. ஒரு 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)  
      }
      
    2. மீண்டும் தொடங்கும் தர்க்கம். அனைத்து வாழ்க்கைகளும் இழக்கப்பட்ட பிறகு அல்லது வீரர் விளையாட்டை வென்ற பிறகு, விளையாட்டை மீண்டும் தொடங்க முடியும் என்பதை காட்டவும். மேலும், மீண்டும் தொடங்கும் விசை அழுத்தப்பட்டால் விளையாட்டை மீண்டும் தொடங்கவும் (எந்த விசை மீண்டும் தொடங்க வேண்டும் என்பதை நீங்கள் தீர்மானிக்கலாம்).

      1. 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);
        }
      }
      
    3. initGame()-இல் விளையாட்டை மீண்டும் தொடங்க eventEmitter ஐ அழைக்க ஒரு அழைப்பு சேர்க்கவும்:

      eventEmitter.on(Messages.KEY_EVENT_ENTER, () => {
        resetGame();
      });
      
    4. EventEmitter-இல் ஒரு clear() செயல்பாட்டைச் சேர்க்கவும்:

      clear() {
        this.listeners = {};
      }
      

👽 💥 🚀 வாழ்த்துக்கள், கேப்டன்! உங்கள் விளையாட்டு முடிந்தது! நன்றாக செய்தீர்கள்! 🚀 💥 👽


🚀 சவால்

ஒலி சேர்க்கவும்! உங்கள் விளையாட்டை மேம்படுத்த ஒரு ஒலியைச் சேர்க்க முடியுமா? உதாரணமாக, லேசர் தாக்கம், ஹீரோ இறந்தது அல்லது வென்றது போன்ற சமயங்களில் ஒலி சேர்க்கவும். JavaScript-ஐப் பயன்படுத்தி ஒலியை விளையாட எப்படி என்பதை அறிய இந்த sandbox ஐ பாருங்கள்.

வகுப்புக்குப் பின் வினாடி வினா

வகுப்புக்குப் பின் வினாடி வினா

மதிப்பீடு மற்றும் சுயபயிற்சி

உங்கள் பணியாக ஒரு புதிய மாதிரி விளையாட்டை உருவாக்க வேண்டும், எனவே நீங்கள் உருவாக்கக்கூடிய விளையாட்டின் வகையைப் பார்க்க சில சுவாரஸ்யமான விளையாட்டுகளை ஆராயவும்.

பணிக்கூற்று

ஒரு மாதிரி விளையாட்டை உருவாக்கவும்


குறிப்பு:
இந்த ஆவணம் Co-op Translator என்ற AI மொழிபெயர்ப்பு சேவையைப் பயன்படுத்தி மொழிபெயர்க்கப்பட்டுள்ளது. நாங்கள் துல்லியத்திற்காக முயற்சிக்கின்றோம், ஆனால் தானியக்க மொழிபெயர்ப்புகளில் பிழைகள் அல்லது தவறான தகவல்கள் இருக்கக்கூடும் என்பதை கவனத்தில் கொள்ளவும். அதன் தாய்மொழியில் உள்ள மூல ஆவணம் அதிகாரப்பூர்வ ஆதாரமாக கருதப்பட வேண்டும். முக்கியமான தகவல்களுக்கு, தொழில்முறை மனித மொழிபெயர்ப்பு பரிந்துரைக்கப்படுகிறது. இந்த மொழிபெயர்ப்பைப் பயன்படுத்துவதால் ஏற்படும் எந்த தவறான புரிதல்கள் அல்லது தவறான விளக்கங்களுக்கு நாங்கள் பொறுப்பல்ல.