2016-04-05 01:10:40 +02:00
|
|
|
var Game = {};
|
|
|
|
G = Game;
|
|
|
|
|
2016-04-06 01:33:38 +02:00
|
|
|
G.player = {}; // Just a reference until G.player is created at rm_Ocean's load time.
|
|
|
|
G.oceanParticle = {}; // One ocean particle will exist at any time and move around the boat.
|
|
|
|
G.map = []; // List of island objects, generated/loaded and saved at game start, loaded on room start.
|
2016-04-08 02:17:45 +02:00
|
|
|
G.currentScreen = ""; // For pause screen, stats screen, inventory screen
|
|
|
|
G.inventory = {
|
2016-04-06 22:41:40 +02:00
|
|
|
money: 100,
|
2016-04-08 22:39:12 +02:00
|
|
|
supplies: 20, // How much stuff you have to maintain your crew's illness with.
|
2016-04-08 02:17:45 +02:00
|
|
|
cargo: []
|
|
|
|
};
|
|
|
|
G.stats = {
|
2016-04-07 20:26:58 +02:00
|
|
|
inventory: 3, // Maximum number of different things the inventory can hold.
|
|
|
|
hold: 20, // Maximum number of each individual kind of thing in the inventory.
|
2016-04-08 02:17:45 +02:00
|
|
|
speed: 1, // How many pixels you move.
|
|
|
|
hull: 3, // Your HP, pretty much. How many times you can crash without exploding.
|
|
|
|
maxHull: 3, // How much your hull can refill to.
|
|
|
|
popularity: 1, // Haggle success rate in percentage.
|
|
|
|
haggling: 10, // How much you can increase the asking price by.
|
|
|
|
crew: 2, // How many crew members you have. Influences how fast your energy recovers.
|
|
|
|
energy: 25, // Drains rate determined by current speed. When drained, currentSpeed reduces until you have enough energy to continue.
|
|
|
|
maxEnergy: 50, // How much to refill your energy to. Can increase with upgrades.
|
2016-04-08 22:39:12 +02:00
|
|
|
illness: 1 // Your crew's overall health. When this is low, your ship slows down.
|
2016-04-06 22:41:40 +02:00
|
|
|
}
|
2016-04-08 02:17:45 +02:00
|
|
|
|
2016-04-07 20:26:58 +02:00
|
|
|
G.itemSheet = new Image();
|
|
|
|
G.itemSheet.src = "images/items_sheet.png";
|
2016-04-05 01:10:40 +02:00
|
|
|
|
2016-04-08 02:17:45 +02:00
|
|
|
G.economy = { // Aww yea, supply and demand.
|
|
|
|
// Items are determined by their index, and their position on the sheet determines their index.
|
|
|
|
// So the second item on the top row is index 1, and to get its value, you get `G.economy.cargoItemWorth[1]`
|
|
|
|
cargoItemWorth: [10, 20, 30, 30, //Can be adjusted based on sales.
|
|
|
|
40, 20, 50, 80,
|
|
|
|
65, 20, 20, 30,
|
|
|
|
30, 60, 45, 70],
|
|
|
|
cargoSold: [0, 0, 0, 0, // The more you sell, the lower the price gets
|
|
|
|
0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0],
|
|
|
|
cargoBought: [0, 0, 0, 0, // The more you buy, the higher the price gets
|
|
|
|
0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0,
|
|
|
|
0, 0, 0, 0],
|
|
|
|
CheckEconomy: function () {
|
|
|
|
for (var i = 0; i < this.cargoSold; i++) {
|
|
|
|
var soldBoughtDifference = this.cargoBought[i] - this.cargoSold[i];
|
|
|
|
|
|
|
|
if (Math.abs(soldBoughtDifference) > (this.cargoItemWorth[i] * 0.75)) { // If the difference is greater than 75% of the worth,
|
|
|
|
this.cargoItemWorth[i] += Math.round(soldBoughtDifference * 0.5); // Adjust the worth by half of the difference.
|
|
|
|
|
|
|
|
if (this.cargoItemWorth[i] < 1) {
|
|
|
|
this.cargoItemWorth[i] = 1; // Make worth never drop below 1.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-04-05 01:10:40 +02:00
|
|
|
function loadGameManager () {}
|