*only increase chance of goal items if you haven't already met the goal.

*make increase chance work for "special" things!!! (eg. white cat)
*stop increasing goal progress once we hit the required amount
*seperate goal names and goal associated things
This commit is contained in:
Rob Pearce 2016-08-30 19:46:40 +10:00
parent 62f7b20a88
commit b5dedbe0ad
2 changed files with 84 additions and 27 deletions

View File

@ -96,6 +96,10 @@ var GOALVERB = {
'whitecat': 'Attack',
};
var GOALNAME = {
'whitecat': 'white cat',
};
var prizetypes = [
"tissues", "shears", "magiccarpet",
];
@ -1390,7 +1394,15 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
//console.log("progress()");
for (i = 0 ; i < this.levels[curlevel].goals.length; i++ ) {
//console.log("this goal type is " + this.levels[curlevel].goals[i].type);
// already met the goal?
if (this.levels[curlevel].goals[i].progress >= this.levels[curlevel].goals[i].count) {
continue;
}
// goal matches what we just progressed in?
if (this.levels[curlevel].goals[i].type == type) {
// increase progress.
this.levels[curlevel].goals[i].progress += amt;
if (this.levels[curlevel].goals[i].progress >= this.levels[curlevel].goals[i].count) {
@ -1403,8 +1415,6 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
}
}
},
calcstars : function (lev, points) {
var i;
@ -1881,6 +1891,7 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
var x,y;
var margin = 10;
var indent = 50;
var progindent = 25;
var boxindent = 20;
//ctx = this.context;
@ -1931,15 +1942,23 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
goalcol = "#aaee00";
}
// goal name
// goal description
var ess = "s";
if (this.levels[curlevel].goals[n].count == 1) {
ess = "";
}
var goalname;
if (GOALNAME[this.levels[curlevel].goals[n].type] == undefined) {
goalname = this.levels[curlevel].goals[n].type;
} else {
goalname = GOALNAME[this.levels[curlevel].goals[n].type];
}
var goaltext = GOALVERB[this.levels[curlevel].goals[n].type] + " " +
this.levels[curlevel].goals[n].count + " " +
this.levels[curlevel].goals[n].type + ess;
goalname + ess;
var progtext = "[" + this.levels[curlevel].goals[n].progress + " / " +
this.levels[curlevel].goals[n].count + "]";
@ -1950,7 +1969,8 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
ctx.textAlign = "right";
ctx.textBaseline = "top";
shadowtext(ctx, progtext, GOALTEXTSIZE,goalcol, SCREENW-indent, y);
shadowtext(ctx, progtext, GOALTEXTSIZE,goalcol, SCREENW-progindent, y);
// completed?
if (goalmet) {
@ -4080,6 +4100,8 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
ctx.stroke();
// right: bags
var SMALLBAGAMT = 0.2;
if (game.levels[curlevel].bags != undefined) {
for (i = 0; i < game.levels[curlevel].bags.length; i++) {
var bagh,thisbag;
@ -4087,8 +4109,8 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
x = BOARDX + (GRIDW * GRIDSIZE);
y = BOARDY + (thisbag.y * GRIDSIZE);
if (thisbag.cats < thisbag.capacity) {
bagh = THINGSIZE*0.1; // base height
bagh += (thisbag.cats / thisbag.capacity) * (THINGSIZE*0.9); // increase based on fullness
bagh = THINGSIZE*SMALLBAGAMT; // base height
bagh += (thisbag.cats / thisbag.capacity) * (THINGSIZE*(1-SMALLBAGAMT)); // increase based on fullness
ctx.drawImage(image['bag'], x, y + GRIDSIZE/2 - bagh/2, THINGSIZE, bagh);
} else if (thisbag.prize != "") { // not collected yet
var size = SCREENW - (GRIDW*GRIDSIZE + BOARDX) ;
@ -4173,6 +4195,15 @@ console.log("lev " + lev + " newwid " + newwid + " ratio " + ratio);
console.log("chear() - ending game");
game.setstate("gameover");
game.cheat = 1;
} else if (ch == 'i') {
var what;
what = getthingxy(lastmx, lastmy);
if (what != undefined) {
console.log("info for " + what.name);
console.log(what);
}
} else if (ch == 'c') {
playerdata.clearall();
} else if (ch == 'f') {
@ -4821,7 +4852,7 @@ function getrandomtype() {
}
// construct a list of permitted special things
var poss = [ "sunlight", "toad", "whitecat" ] ;
var poss = [ "door", "sunlight", "toad", "whitecat" ] ;
for (i in poss ) {
if (!game.isbanned(curlevel, poss[i])) {
if (speciallist == undefined) {
@ -4839,7 +4870,7 @@ function getrandomtype() {
// default thinglist
// must be sorted from low to high!
if (!game.isbanned(curlevel, 'door')) thinglist.push({ type: 'door', pct: 10 } );
//if (!game.isbanned(curlevel, 'door')) thinglist.push({ type: 'door', pct: 10 } );
if (speciallist != undefined) {
if (dodb) console.log("specials are possible");
thinglist.push({ type: 'special', pct: 5 } );
@ -4850,6 +4881,7 @@ function getrandomtype() {
if (!game.isbanned(curlevel, 'cat')) thinglist.push({ type: 'cat', pct: 45 } );
}
// increase the chance of something appearing if
// a. it's a goal
// b. we don't have any
@ -4857,16 +4889,41 @@ function getrandomtype() {
var n;
for (i = 0; i < thinglist.length; i++) {
for (n = 0 ; n < game.levels[curlevel].goals.length; n++ ) {
if (game.levels[curlevel].goals[n].type == thinglist[i].type) {
var matchesgoal = false;
var thingtype = thinglist[i].type
var goaltype = game.levels[curlevel].goals[n].type;
var lookforthing;
if (game.levels[curlevel].goals[n].progress < game.levels[curlevel].goals[n].count) {
if (goaltype == thingtype) {
matchesgoal = true;
lookforthing = thingtype;
} else if ((thingtype == "special") &&
speciallist.indexOf(goaltype) != -1) {
// change it.
lookforthing = goaltype;
matchesgoal = true;
}
}
if (matchesgoal) {
var count;
console.log("****** " + thinglist[i].type + " matches goal.");
console.log("****** " + thingtype + " matches goal.");
// check if any exist
count = countalivethingsoftype(thinglist[i].type);
count = countalivethingsoftype(lookforthing);
if (count <= 1) {
console.log("****** no things of type " + thinglist[i].type);
console.log("****** no things of type " + lookforthing);
// extra chance!
thinglist[i].pct *= 3;
console.log("double chance of " + thinglist[i].type);
thinglist[i].pct *= 4;
console.log("extra chance of " + thingtype + "(" + lookforthing + ")");
// if the thing in question is 'special',
// cheat on the random check later to make sure we
// only get the right kind of special thing.
if (thingtype == "special") {
speciallist.splice(0, speciallist.length);
speciallist.push(goaltype);
}
}
}
}
@ -5054,7 +5111,7 @@ function thing(gridx, gridy, type, text, col) {
this.canfall = function() {
// doors can't fall after their initial drop
if (this.type == "door") {
if ((this.gridy >= 0) && (this.new == false)) {
if ((this.gridy >= 0) && (this.isnew == false)) {
return false;
}
}

22
todo
View File

@ -9,24 +9,24 @@ https://www.smashingmagazine.com/2012/10/design-your-own-mobile-game/
https://www.smashingmagazine.com/2012/10/design-your-own-mobile-game/
--- check here for ios
-------------------
*special: toad - slap to make it drop down and clear objects below.
*special: white cat : destroys stuff around it
*increase changes of a goal things appearing if none exist.
*only increase chance of goal items if you haven't already met the goal.
*make increase chance work for "special" things!!! (eg. white cat)
*stop increasing goal progress once we hit the required amount
*seperate goal names and goal associated things
make increasechance work for "special" things!!!
OBSTACLES on later levels
fixed position.
separate goal names and goal associated things
other colour cat
more goals:
form x parades of length y
other colour cats
--------------
more goals:
form x parades of length y
more prizes: ???
mouse - place to clear all cats in grid/column
whitecat - place to clear 3 x 3 grid around it