diff --git a/CSS/style.css b/CSS/style.css index feb6730..2f760b1 100644 --- a/CSS/style.css +++ b/CSS/style.css @@ -1,2 +1,2 @@ /* Class for keeping divs hidden until JavaScript determines they should be shown. */ -.hidden { visibility: hidden; } \ No newline at end of file +.hidden { display: none; } diff --git a/JS/character.js b/JS/character.js index e6f4f98..d308e2e 100644 --- a/JS/character.js +++ b/JS/character.js @@ -1,33 +1,47 @@ -// Character related variables. -var gold = 0; -var HP = 10; -var lvl = 1; -var XP = 0; -var HP = 10; -var currentHP = 10; -var charname; +var character = { + // Character related variables. + charname: "", + level: 1, + xp: 0, + gold: 0, + maxHP: 10, + currentHP: 10, -// Weapon and hit related variables. -var weapon; -var hit = ["Critical Miss", "Miss", "Glancing Hit", "Hit", "Critical Hit"]; + // Weapon and hit related variables. + weapon: "", + // hit: ["Critical Miss", "Miss", "Glancing Hit", "Hit", "Critical Hit"], // This probably doesnt need to exist here since it's configured in encounter.js -// This function sets the variables charname and weapon with user input from the form on the index page, then starts the game. -function charFill(form) { - window.charname = form.charname.value; - window.weapon = form.weapon.value; - /* These next commands find the divs of the same id and modify their style (CSS) from visible to hidden, or vice versa. - In effect, it controls what the user sees on the page. */ - document.getElementById("charForm").style.visibility="hidden"; - document.getElementById("charInfo").style.visibility="visible"; - document.getElementById("monsterInfo").style.visibility="visible"; - document.getElementById("encounter").style.visibility="visible"; - document.getElementById("charActions").style.visibility="visible"; - // The next two lines call the charLoad and encounter functions. encounter() is in the encounter.js file. - charLoad(); - encounter(); -} + // This function sets the variables charname and weapon with user input from the form on the index page, then starts the game. + charFill: function(form) { + this.charname = form.charname.value; + this.weapon = form.weapon.value; -//This function outputs the starting character info to to the charInfo div. -function charLoad() { - document.getElementById("charInfo").innerHTML = "
Name: " + window.charname + "
" + "Weapon: " + window.weapon + "
" + "Hitpoints: " + currentHP + "/" + HP + "
" + "Level: " + lvl + "
" + "XP: " + XP + "
" + "Gold: " + gold + "
";
+ charInfo += "Name: " + this.charname + "
";
+ charInfo += "Weapon: " + this.weapon + "
";
+ charInfo += "Hitpoints: " + this.currentHP + "/" + this.maxHP + "
";
+ charInfo += "Level: " + this.level + "
";
+ charInfo += "XP: " + this.xp + "
";
+ charInfo += "Gold: " + this.gold;
+ charInfo += "
You have encountered a " + monster + "!
"; - } - else if (monster == "goblin") { - window.monsterHP = 20; - window.monsterDamage = 1; - document.getElementById("encounter").innerHTML = "You have encountered a " + monster + "!
"; - } - else if (monster == "werewolf") { - window.monsterHP = 40; - window.monsterDamage = 2; - document.getElementById("encounter").innerHTML = "You have encountered a " + monster + "!
"; - } - else if (monster == "vampire") { - window.monsterHP = 30; - window.monsterDamage = 3; - document.getElementById("encounter").innerHTML = "You have encountered a " + monster + "!
"; - } - else { - window.monsterHP = 20; - window.monsterDamage = 4; - document.getElementById("encounter").innerHTML = "You have encountered a " + monster + "!
"; - } -} + // This function determines what monster the player will be fighting when an encounter begins. + encounter: function() { + // This assigns a value from the monsters array by generating a random number between 0 and 5 (the length of the monsters array minus 1). + var monsterIndex = util.randomIntFromInterval(0, this.monsters.length-1); + this.monster = this.monsters[monsterIndex]; -//This function handles the mechanics of battling monsters. It is far from finished. -function attack() { - //This variable is assigned one of the values from the hit array. This is done by generating a random number between 0 and 5. - var attackRoll = hit[Math.floor(Math.random() * 5)]; - //This variable is used to work out damage, assigned a random number betwen 1 and 6. - var damage = Math.floor((Math.random() * 5) + 1); + if (this.monster == "rat") { + this.monsterHP = 10; + this.monsterDamage = 0; + } + else if (this.monster == "goblin") { + this.monsterHP = 20; + this.monsterDamage = 1; + } + else if (this.monster == "werewolf") { + this.monsterHP = 40; + this.monsterDamage = 2; + } + else if (this.monster == "vampire") { + this.monsterHP = 30; + this.monsterDamage = 3; + } + else { + this.monsterHP = 20; + this.monsterDamage = 4; + } - /* This if tree works out whether or not the attack was a success. - Damage is then assigned appropriately. Critical Miss deals half - damage to the player. Glancing Hit half damage to enemy. Hit is - normal damage to enemy, and Critical double. */ - - /* IMPORTANT TO DOS: - # Make it so that when the monster gets to 0 HP or below, it dies. - # Write a function for the monster's attack. - # Make it so that the player takes damage and can die. - # Assign XP and gold to the player upon killing a monster. - */ - if (attackRoll == "Critical Miss") { - var damage = damage/2; - window.currentHP = currentHP - damage; - document.getElementById("encounter").innerHTML = attackRoll + "! You swing wildly with your " + weapon + " and hit yourself, dealing " + damage + " damage to yourself!"+ "You have encountered a " + this.monster + "!
"; + }, + + //This function handles the mechanics of battling monsters. It is far from finished. + attack: function() { + //This variable is assigned one of the values from the hit array. This is done by generating a random number between 0 and 5. + var hitIndex = util.randomIntFromInterval(0, this.hit.length-1) + var attackRoll = this.hit[hitIndex]; + //This variable is used to work out damage, assigned a random number betwen 1 and 6. + var damage = util.randomIntFromInterval(1, 6); + + /* This if tree works out whether or not the attack was a success. + Damage is then assigned appropriately. Critical Miss deals half + damage to the player. Glancing Hit half damage to enemy. Hit is + normal damage to enemy, and Critical double. */ + + /* IMPORTANT TO DOS: + # Make it so that when the monster gets to 0 HP or below, it dies. + # Write a function for the monster's attack. + # Make it so that the player takes damage and can die. + # Assign XP and gold to the player upon killing a monster. + */ + if (attackRoll == "Critical Miss") { + damage = damage/2; + character.currentHP = character.currentHP - damage; + document.getElementById("encounter").innerHTML = attackRoll + "! You swing wildly with your " + character.weapon + " and hit yourself, dealing " + damage + " damage to yourself!"+ "