mirror of https://github.com/espruino/BangleApps
Update app.js
parent
4b011befa1
commit
7119eda345
|
@ -1,11 +1,26 @@
|
||||||
//Create constants
|
//Create constants------------------------------------------------------------------
|
||||||
const GREEN_SLIME = 1; //Normal slime, is always neutral.
|
|
||||||
const PINK_SLIME = 2; //Can get angry
|
|
||||||
const GRAY_SLIME = 3; //Can be neutral, angry or erratic
|
|
||||||
const YELLOW_SLIME = 4; //Is always erratic
|
|
||||||
const PURPLE_SLIME = 5; //Is always angry
|
|
||||||
|
|
||||||
//Initialize variables
|
//Slimes
|
||||||
|
const GREEN_SLIME = 1; //Normal slime, is always neutral. | 0% Item chance
|
||||||
|
const PINK_SLIME = 2; //Can get angry. | 10% Item chance
|
||||||
|
const GRAY_SLIME = 3; //Can be neutral, angry or erratic. | 20% Item chance
|
||||||
|
const YELLOW_SLIME = 4; //Is always erratic. | 50% Item chance
|
||||||
|
const PURPLE_SLIME = 5; //Is always angry. | 100% Item chance
|
||||||
|
|
||||||
|
//Items
|
||||||
|
const ITEM_ATK_UP = 1; //Raises damage dealt by +1 for next battle
|
||||||
|
const ITEM_DEF_UP = 2; //Reduces all damage by +1 for next battle
|
||||||
|
const ITEM_HP_UP = 3; //Increases HP by 3
|
||||||
|
const ITEM_BLOCK_UP = 4; //Raises defence when defending by from 3 to 5 for next battle
|
||||||
|
const ITEM_CRIT_UP = 5; //Gives attack a 20% chance to instantly KO slime for next battle
|
||||||
|
|
||||||
|
//Base stats
|
||||||
|
const BASE_ATK = 1;
|
||||||
|
const BASE_DEF = 0;
|
||||||
|
const BASE_BLOCK = 3;
|
||||||
|
const BASE_CRIT = 0;
|
||||||
|
|
||||||
|
//Initialize variables------------------------------------------------------------------
|
||||||
var playerHP = 20;
|
var playerHP = 20;
|
||||||
var slimeHP = 3;
|
var slimeHP = 3;
|
||||||
var slimeType = GREEN_SLIME;
|
var slimeType = GREEN_SLIME;
|
||||||
|
@ -16,6 +31,19 @@ var slimeState = 0;
|
||||||
var showBattleResult = false;
|
var showBattleResult = false;
|
||||||
var dmgDealt = 0;
|
var dmgDealt = 0;
|
||||||
var playerDefence = 0;
|
var playerDefence = 0;
|
||||||
|
var playerItem = 0;
|
||||||
|
var critChance = 0;
|
||||||
|
|
||||||
|
//Stats (Modifiers)
|
||||||
|
var statAtk = 1;
|
||||||
|
var statDef = 0;
|
||||||
|
var statBlock = 3;
|
||||||
|
var statCrit = 0;
|
||||||
|
|
||||||
|
//Item vars
|
||||||
|
var itemName = "";
|
||||||
|
var itemDesc = "";
|
||||||
|
var itemChance = 0;
|
||||||
|
|
||||||
var refreshInterval;
|
var refreshInterval;
|
||||||
var waitTime = 0;
|
var waitTime = 0;
|
||||||
|
@ -25,8 +53,8 @@ var score = 0;
|
||||||
|
|
||||||
var themeNote = 0;
|
var themeNote = 0;
|
||||||
|
|
||||||
//Load files
|
//Load files------------------------------------------------------------------
|
||||||
var file = require("Storage").open("highscore.txt","r");
|
var file = require("Storage").open("highscore.txt", "r");
|
||||||
highscore = file.readLine();
|
highscore = file.readLine();
|
||||||
if (highscore == undefined) highscore = 0;
|
if (highscore == undefined) highscore = 0;
|
||||||
|
|
||||||
|
@ -36,110 +64,139 @@ var graySlime = require("Storage").read("slimegray.img");
|
||||||
var yellowSlime = require("Storage").read("slimeyellow.img");
|
var yellowSlime = require("Storage").read("slimeyellow.img");
|
||||||
var purpleSlime = require("Storage").read("slimepurple.img");
|
var purpleSlime = require("Storage").read("slimepurple.img");
|
||||||
|
|
||||||
//UI Stuff
|
//UI Stuff------------------------------------------------------------------
|
||||||
function drawOpeningUI() {
|
function drawOpeningUI() {
|
||||||
g.clear();
|
g.clear();
|
||||||
g.setFont("Vector",screenWidth/15);
|
g.setFont("Vector", screenWidth / 15);
|
||||||
g.setFontAlign(0,0); // center font
|
g.setFontAlign(0, 0); // center font
|
||||||
g.drawString("SLIME HUNT",screenWidth/2,screenHeight*0.1);
|
g.drawString("SLIME HUNT", screenWidth / 2, screenHeight * 0.1);
|
||||||
g.drawString("-SCORE TO BEAT-",screenWidth/2,screenHeight*0.3);
|
g.drawString("-SCORE TO BEAT-", screenWidth / 2, screenHeight * 0.3);
|
||||||
g.drawString("<><><> "+highscore+" <><><>",screenWidth/2,screenHeight*0.45);
|
g.drawString("<><><> " + highscore + " <><><>", screenWidth / 2, screenHeight * 0.45);
|
||||||
g.setFont("Vector",screenWidth/20);
|
g.setFont("Vector", screenWidth / 20);
|
||||||
g.drawString("A Slime approches...",screenWidth/2,screenHeight*0.6);
|
g.drawString("A Slime approches...", screenWidth / 2, screenHeight * 0.6);
|
||||||
wait(8,waitForBattle);
|
wait(8, waitForBattle);
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawSlime() {
|
function drawSlime() {
|
||||||
switch(slimeType) {
|
switch (slimeType) {
|
||||||
case GREEN_SLIME:
|
case GREEN_SLIME:
|
||||||
g.drawImage(greenSlime,screenWidth/2,screenHeight/2,{scale:4,rotate:0});
|
g.drawImage(greenSlime, screenWidth / 2, screenHeight / 2, {
|
||||||
|
scale: 4,
|
||||||
|
rotate: 0
|
||||||
|
});
|
||||||
break;
|
break;
|
||||||
case PINK_SLIME:
|
case PINK_SLIME:
|
||||||
g.drawImage(pinkSlime,screenWidth/2,screenHeight/2,{scale:4,rotate:0});
|
g.drawImage(pinkSlime, screenWidth / 2, screenHeight / 2, {
|
||||||
|
scale: 4,
|
||||||
|
rotate: 0
|
||||||
|
});
|
||||||
break;
|
break;
|
||||||
case GRAY_SLIME:
|
case GRAY_SLIME:
|
||||||
g.drawImage(graySlime,screenWidth/2,screenHeight/2,{scale:4,rotate:0});
|
g.drawImage(graySlime, screenWidth / 2, screenHeight / 2, {
|
||||||
|
scale: 4,
|
||||||
|
rotate: 0
|
||||||
|
});
|
||||||
break;
|
break;
|
||||||
case YELLOW_SLIME:
|
case YELLOW_SLIME:
|
||||||
g.drawImage(yellowSlime,screenWidth/2,screenHeight/2,{scale:4,rotate:0});
|
g.drawImage(yellowSlime, screenWidth / 2, screenHeight / 2, {
|
||||||
|
scale: 4,
|
||||||
|
rotate: 0
|
||||||
|
});
|
||||||
break;
|
break;
|
||||||
case PURPLE_SLIME:
|
case PURPLE_SLIME:
|
||||||
g.drawImage(purpleSlime,screenWidth/2,screenHeight/2,{scale:4,rotate:0});
|
g.drawImage(purpleSlime, screenWidth / 2, screenHeight / 2, {
|
||||||
|
scale: 4,
|
||||||
|
rotate: 0
|
||||||
|
});
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function drawBattleUI() {
|
function drawBattleUI() {
|
||||||
g.clear();
|
g.clear();
|
||||||
g.setFont("Vector",screenWidth/8);
|
g.setFont("Vector", screenWidth / 8);
|
||||||
g.setFontAlign(0,0); // center font
|
g.setFontAlign(0, 0); // center font
|
||||||
g.drawString("SLIME HP: " + slimeHP,screenWidth/2,screenHeight*0.1);
|
g.drawString("SLIME HP: " + slimeHP, screenWidth / 2, screenHeight * 0.1);
|
||||||
g.setFont("Vector",screenWidth/20);
|
g.setFont("Vector", screenWidth / 20);
|
||||||
if (!showBattleResult) {
|
if (!showBattleResult) {
|
||||||
switch(slimeState) {
|
switch (slimeState) {
|
||||||
case 0:
|
case 0:
|
||||||
g.drawString("The slime seems neutral...",screenWidth/2,screenHeight*0.25);
|
g.drawString("The slime seems neutral...", screenWidth / 2, screenHeight * 0.25);
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
g.drawString("The slime seems angry...",screenWidth/2,screenHeight*0.25);
|
g.drawString("The slime seems angry...", screenWidth / 2, screenHeight * 0.25);
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
g.drawString("The slime seems eratic...",screenWidth/2,screenHeight*0.25);
|
g.drawString("The slime seems eratic...", screenWidth / 2, screenHeight * 0.25);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
var brString = (turn == 0 ? "The Slime loses " : "You lose ");
|
var brString = (turn == 0 ? "The Slime loses " : "You lose ");
|
||||||
g.drawString(brString + dmgDealt + "HP!",screenWidth/2,screenHeight*0.25);
|
g.drawString(brString + dmgDealt + "HP!", screenWidth / 2, screenHeight * 0.25);
|
||||||
}
|
}
|
||||||
drawSlime();
|
drawSlime();
|
||||||
g.drawLine(0,screenHeight*0.72,screenWidth,screenHeight*0.72);
|
g.drawLine(0, screenHeight * 0.72, screenWidth, screenHeight * 0.72);
|
||||||
if (turn == 0) {
|
if (turn == 0) {
|
||||||
g.setFont("Vector",screenWidth/15);
|
g.setFont("Vector", screenWidth / 15);
|
||||||
g.drawString("Your HP is " + playerHP + ".",screenWidth/2,screenHeight*0.8);
|
g.drawString("Your HP is " + playerHP + ".", screenWidth / 2, screenHeight * 0.8);
|
||||||
g.setFont("Vector",screenWidth/20);
|
g.setFont("Vector", screenWidth / 20);
|
||||||
g.drawString("(B1) FIGHT\t|\t(B2) DEFEND\t|\t(B3) RUN",screenWidth/2,screenHeight*0.9);
|
g.drawString("(B1) FIGHT\t|\t(B2) DEFEND\t|\t(B3) RUN", screenWidth / 2, screenHeight * 0.9);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Win / lose functions------------------------------------------------------------------
|
||||||
function win() {
|
function win() {
|
||||||
wait(5,winTheme);
|
wait(5, winTheme);
|
||||||
calcScore(slimeType);
|
calcScore(slimeType);
|
||||||
showBattleResult = false;
|
showBattleResult = false;
|
||||||
g.clear();
|
g.clear();
|
||||||
g.setFont("Vector",screenWidth/8);
|
g.setFont("Vector", screenWidth / 8);
|
||||||
g.setFontAlign(0,0); // center font
|
g.setFontAlign(0, 0); // center font
|
||||||
g.drawString("YOU WON!",screenWidth/2,screenHeight/2);
|
g.drawString("YOU WON!", screenWidth / 2, screenHeight * 0.1);
|
||||||
g.setFont("Vector",screenWidth/20);
|
g.drawLine(0, screenHeight * 0.2, screenWidth, screenHeight * 0.2);
|
||||||
g.drawString("Your score is << " + score + " >>",screenWidth/2,screenHeight*0.75);
|
g.setFont("Vector", screenWidth / 12);
|
||||||
g.drawString("Press (B3) to find another slime!",screenWidth/2,screenHeight*0.9);
|
g.drawString((playerItem == 0 ? "No Item." : "GOT ITEM!"), screenWidth / 2, screenHeight * 0.27);
|
||||||
|
g.setFont("Vector", screenWidth / 15);
|
||||||
|
g.drawString((playerItem == 0 ? "" : "<><> " + itemName + " <><>"), screenWidth / 2, screenHeight * 0.40);
|
||||||
|
g.setFont("Vector", screenWidth / 20);
|
||||||
|
g.drawString((playerItem == 0 ? "" : itemDesc), screenWidth / 2, screenHeight * 0.52);
|
||||||
|
g.drawLine(0, screenHeight * 0.6, screenWidth, screenHeight * 0.6);
|
||||||
|
g.drawString("Your score is << " + score + " >>", screenWidth / 2, screenHeight * 0.75);
|
||||||
|
g.drawString("Press (B3) to find another slime!", screenWidth / 2, screenHeight * 0.9);
|
||||||
turn = 0;
|
turn = 0;
|
||||||
setWatch(run,BTN3);
|
setWatch(run, BTN3);
|
||||||
}
|
}
|
||||||
|
|
||||||
function lose() {
|
function lose() {
|
||||||
wait(5,loseTheme);
|
wait(5, loseTheme);
|
||||||
playerHP = 20;
|
playerHP = 20;
|
||||||
showBattleResult = false;
|
showBattleResult = false;
|
||||||
g.clear();
|
g.clear();
|
||||||
g.setFont("Vector",screenWidth/8);
|
g.setFont("Vector", screenWidth / 8);
|
||||||
g.setFontAlign(0,0); // center font
|
g.setFontAlign(0, 0); // center font
|
||||||
g.drawString("You lose...",screenWidth/2,screenHeight/2);
|
g.drawString("You lose...", screenWidth / 2, screenHeight * 0.1);
|
||||||
g.setFont("Vector",screenWidth/20);
|
g.drawLine(0, screenHeight * 0.2, screenWidth, screenHeight * 0.2);
|
||||||
g.drawString("Your score is << " + score + " >>",screenWidth/2,screenHeight*0.75);
|
g.setFont("Vector", screenWidth / 12);
|
||||||
g.drawString("Press (B3) to try again...",screenWidth/2,screenHeight*0.9);
|
g.drawString((score > highscore ? "-NEW HIGHSCORE-" : "-SCORE TO BEAT-"), screenWidth / 2, screenHeight * 0.27);
|
||||||
|
g.setFont("Vector", screenWidth / 15);
|
||||||
|
g.drawString((score > highscore ? "<><> " + score + " <><>" : "<><> " + highscore + " <><>"), screenWidth / 2, screenHeight * 0.43);
|
||||||
|
g.drawLine(0, screenHeight * 0.6, screenWidth, screenHeight * 0.6);
|
||||||
|
g.setFont("Vector", screenWidth / 20);
|
||||||
|
g.drawString("Your score is << " + score + " >>", screenWidth / 2, screenHeight * 0.75);
|
||||||
|
g.drawString("Press (B3) to try again...", screenWidth / 2, screenHeight * 0.9);
|
||||||
score = 0;
|
score = 0;
|
||||||
turn = 0;
|
turn = 0;
|
||||||
setWatch(run,BTN3);
|
setWatch(run, BTN3);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Battle Stuff
|
//Battle Stuff------------------------------------------------------------------
|
||||||
function nextTurn() {
|
function nextTurn() {
|
||||||
turn = (turn == 0 ? 1 : 0);
|
turn = (turn == 0 ? 1 : 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
function slimeFight() {
|
function slimeFight() {
|
||||||
Bangle.beep(100, 500);
|
Bangle.beep(100, 500);
|
||||||
switch(slimeState) {
|
switch (slimeState) {
|
||||||
case 0:
|
case 0:
|
||||||
dmgDealt = Math.floor(Math.random() * 2);
|
dmgDealt = Math.floor(Math.random() * 2);
|
||||||
break;
|
break;
|
||||||
|
@ -150,7 +207,7 @@ function slimeFight() {
|
||||||
dmgDealt = Math.floor(Math.random() * 6);
|
dmgDealt = Math.floor(Math.random() * 6);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
dmgDealt = Math.max(0,dmgDealt - playerDefence);
|
dmgDealt = Math.max(0, dmgDealt - playerDefence);
|
||||||
playerHP -= dmgDealt;
|
playerHP -= dmgDealt;
|
||||||
slimeAI();
|
slimeAI();
|
||||||
}
|
}
|
||||||
|
@ -158,22 +215,33 @@ function slimeFight() {
|
||||||
function fight() {
|
function fight() {
|
||||||
if (turn == 0 && waitTime <= 0) {
|
if (turn == 0 && waitTime <= 0) {
|
||||||
Bangle.beep(100, 1000);
|
Bangle.beep(100, 1000);
|
||||||
dmgDealt = 1;
|
dmgDealt = statAtk;
|
||||||
playerDefence = 0;
|
playerDefence = statDef;
|
||||||
|
if (statCrit == 0) {
|
||||||
slimeHP -= dmgDealt;
|
slimeHP -= dmgDealt;
|
||||||
|
}else{
|
||||||
|
critChance = Math.floor(Math.random() * 100);
|
||||||
|
if (critChance >= 100-critStat) {
|
||||||
|
slimeHP = 0;
|
||||||
|
dmgDealt = 99;
|
||||||
|
}else{
|
||||||
|
slimeHP -= dmgDealt;
|
||||||
|
}
|
||||||
|
critChance = 0;
|
||||||
|
}
|
||||||
showBattleResult = true;
|
showBattleResult = true;
|
||||||
drawBattleUI();
|
drawBattleUI();
|
||||||
wait(5,waitForTurn);
|
wait(5, waitForTurn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function defend() {
|
function defend() {
|
||||||
if (turn == 0 && waitTime <= 0) {
|
if (turn == 0 && waitTime <= 0) {
|
||||||
dmgDealt = 0;
|
dmgDealt = 0;
|
||||||
playerDefence = 3;
|
playerDefence = statBlock + statDef;
|
||||||
showBattleResult = true;
|
showBattleResult = true;
|
||||||
drawBattleUI();
|
drawBattleUI();
|
||||||
wait(5,waitForTurn);
|
wait(5, waitForTurn);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -181,7 +249,7 @@ function run() {
|
||||||
if (turn == 0 && waitTime <= 0) {
|
if (turn == 0 && waitTime <= 0) {
|
||||||
showBattleResult = false;
|
showBattleResult = false;
|
||||||
Bangle.beep(200, 4000);
|
Bangle.beep(200, 4000);
|
||||||
wait(3,waitForBattle);
|
wait(3, waitForBattle);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -189,7 +257,8 @@ function run() {
|
||||||
function newBattle() {
|
function newBattle() {
|
||||||
showBattleResult = false;
|
showBattleResult = false;
|
||||||
slimeType = Math.floor(Math.random() * 5) + 1;
|
slimeType = Math.floor(Math.random() * 5) + 1;
|
||||||
switch(slimeType) {
|
useItem(); //Use item at start of new battle
|
||||||
|
switch (slimeType) {
|
||||||
case GREEN_SLIME:
|
case GREEN_SLIME:
|
||||||
slimeHP = 3;
|
slimeHP = 3;
|
||||||
break;
|
break;
|
||||||
|
@ -213,13 +282,13 @@ function newBattle() {
|
||||||
}
|
}
|
||||||
|
|
||||||
function battle() {
|
function battle() {
|
||||||
setWatch(fight,BTN1);
|
setWatch(fight, BTN1);
|
||||||
setWatch(defend,BTN2);
|
setWatch(defend, BTN2);
|
||||||
setWatch(run,BTN3);
|
setWatch(run, BTN3);
|
||||||
}
|
}
|
||||||
|
|
||||||
function slimeAI() {
|
function slimeAI() {
|
||||||
switch(slimeType) {
|
switch (slimeType) {
|
||||||
case GREEN_SLIME:
|
case GREEN_SLIME:
|
||||||
slimeState = 0;
|
slimeState = 0;
|
||||||
break;
|
break;
|
||||||
|
@ -237,10 +306,60 @@ function slimeAI() {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
//Items------------------------------------------------------------------
|
||||||
|
function getItem() {
|
||||||
|
playerItem = Math.floor(Math.random() * 5) + 1;
|
||||||
|
switch (playerItem) {
|
||||||
|
case ITEM_ATK_UP:
|
||||||
|
itemName = "Attack Up";
|
||||||
|
itemDesc = "+1 damage next battle.";
|
||||||
|
break;
|
||||||
|
case ITEM_DEF_UP:
|
||||||
|
itemName = "Defence Up";
|
||||||
|
itemDesc = "+1 defence next battle.";
|
||||||
|
break;
|
||||||
|
case ITEM_HP_UP:
|
||||||
|
itemName = "HP Up";
|
||||||
|
itemDesc = "+3 HP.";
|
||||||
|
break;
|
||||||
|
case ITEM_BLOCK_UP:
|
||||||
|
itemName = "Block Up";
|
||||||
|
itemDesc = "+2 block on DEFEND next battle.";
|
||||||
|
break;
|
||||||
|
case ITEM_CRIT_UP:
|
||||||
|
itemName = "Critical Up";
|
||||||
|
itemDesc = "20% chance to crit next battle.";
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function useItem() {
|
||||||
|
statAtk = BASE_ATK;
|
||||||
|
statDef = BASE_DEF;
|
||||||
|
statBlock = BASE_BLOCK;
|
||||||
|
statCrit = BASE_CRIT;
|
||||||
|
switch (playerItem) {
|
||||||
|
case ITEM_ATK_UP:
|
||||||
|
statAtk = 2;
|
||||||
|
break;
|
||||||
|
case ITEM_DEF_UP:
|
||||||
|
statDef = 1;
|
||||||
|
break;
|
||||||
|
case ITEM_HP_UP:
|
||||||
|
playerHP += 3;
|
||||||
|
break;
|
||||||
|
case ITEM_BLOCK_UP:
|
||||||
|
statBlock = 5;
|
||||||
|
break;
|
||||||
|
case ITEM_CRIT_UP:
|
||||||
|
statCrit = 20;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
playerItem = 0;
|
||||||
|
}
|
||||||
|
|
||||||
//Timed transitions
|
//Timed transitions------------------------------------------------------------------
|
||||||
function wait(duration,waitFunc) {
|
function wait(duration, waitFunc) {
|
||||||
waitTime = duration;
|
waitTime = duration;
|
||||||
if (!refreshInterval)
|
if (!refreshInterval)
|
||||||
refreshInterval = setInterval(waitFunc, 500);
|
refreshInterval = setInterval(waitFunc, 500);
|
||||||
|
@ -255,13 +374,13 @@ function waitForTurn() {
|
||||||
if (playerHP > 0 && slimeHP > 0) {
|
if (playerHP > 0 && slimeHP > 0) {
|
||||||
if (turn == 1) {
|
if (turn == 1) {
|
||||||
slimeFight();
|
slimeFight();
|
||||||
wait(5,waitForTurn);
|
wait(5, waitForTurn);
|
||||||
}else{
|
} else {
|
||||||
showBattleResult = false;
|
showBattleResult = false;
|
||||||
battle();
|
battle();
|
||||||
}
|
}
|
||||||
drawBattleUI();
|
drawBattleUI();
|
||||||
}else{
|
} else {
|
||||||
if (playerHP <= 0) {
|
if (playerHP <= 0) {
|
||||||
lose();
|
lose();
|
||||||
}
|
}
|
||||||
|
@ -287,54 +406,71 @@ function waitForBattle() {
|
||||||
|
|
||||||
function winTheme() {
|
function winTheme() {
|
||||||
waitTime--;
|
waitTime--;
|
||||||
Bangle.beep(200, 100*themeNote);
|
Bangle.beep(200, 100 * themeNote);
|
||||||
themeNote++;
|
themeNote++;
|
||||||
if (waitTime <= 0) {
|
if (waitTime <= 0) {
|
||||||
themeNote = 0;
|
themeNote = 0;
|
||||||
clearInterval(refreshInterval);
|
clearInterval(refreshInterval);
|
||||||
refreshInterval = undefined;
|
refreshInterval = undefined;
|
||||||
|
setWatch(run, BTN3);
|
||||||
}
|
}
|
||||||
Bangle.setLCDPower(1);
|
Bangle.setLCDPower(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
function loseTheme() {
|
function loseTheme() {
|
||||||
waitTime--;
|
waitTime--;
|
||||||
Bangle.beep(200, 600-(100*themeNote));
|
Bangle.beep(200, 600 - (100 * themeNote));
|
||||||
themeNote++;
|
themeNote++;
|
||||||
if (waitTime <= 0) {
|
if (waitTime <= 0) {
|
||||||
themeNote = 0;
|
themeNote = 0;
|
||||||
clearInterval(refreshInterval);
|
clearInterval(refreshInterval);
|
||||||
refreshInterval = undefined;
|
refreshInterval = undefined;
|
||||||
|
setWatch(run, BTN3);
|
||||||
}
|
}
|
||||||
Bangle.setLCDPower(1);
|
Bangle.setLCDPower(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Calculations
|
//Calculations------------------------------------------------------------------
|
||||||
function calcScore(slimeType) {
|
function calcScore(slimeType) {
|
||||||
switch(slimeType) {
|
switch (slimeType) {
|
||||||
case GREEN_SLIME:
|
case GREEN_SLIME:
|
||||||
score += 1;
|
score += 1;
|
||||||
|
//No items
|
||||||
break;
|
break;
|
||||||
case PINK_SLIME:
|
case PINK_SLIME:
|
||||||
score += 2;
|
score += 2;
|
||||||
|
itemChance = Math.floor(Math.random() * 100);
|
||||||
|
if (itemChance >= 100 - 10) { //100 - ITEM CHANCE %
|
||||||
|
getItem();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case GRAY_SLIME:
|
case GRAY_SLIME:
|
||||||
score += 2;
|
score += 3;
|
||||||
|
itemChance = Math.floor(Math.random() * 100);
|
||||||
|
if (itemChance >= 100 - 25) { //100 - ITEM CHANCE %
|
||||||
|
getItem();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case YELLOW_SLIME:
|
case YELLOW_SLIME:
|
||||||
score += 5;
|
score += 5;
|
||||||
|
itemChance = Math.floor(Math.random() * 100);
|
||||||
|
if (itemChance >= 100 - 50) { //100 - ITEM CHANCE %
|
||||||
|
getItem();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
case PURPLE_SLIME:
|
case PURPLE_SLIME:
|
||||||
score += 10;
|
score += 10;
|
||||||
|
getItem();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (score > highscore) {
|
if (score > highscore) {
|
||||||
file.erase();
|
file.erase();
|
||||||
file = require("Storage").open("highscore.txt","w");
|
file = require("Storage").open("highscore.txt", "w");
|
||||||
file.write(score);
|
file.write(score);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//------------------------------------GAME STARTS HERE -----------------------------------------------
|
//------------------------------------GAME STARTS HERE -----------------------------------------------
|
||||||
|
|
||||||
//Load opening UI
|
//Load opening UI
|
||||||
|
|
Loading…
Reference in New Issue