From 17227e054a7e5e193179c1532aa5fcdf5d32cbff Mon Sep 17 00:00:00 2001 From: Robbie Antenesse Date: Fri, 29 Apr 2016 12:25:35 -0600 Subject: [PATCH] Make islands have limited money, limit amount of price changes each day. --- loadGameManager.js | 3 +- prefabs/islandPrefab.js | 86 ++++++++++++++++++++++++++++++----------- 2 files changed, 65 insertions(+), 24 deletions(-) diff --git a/loadGameManager.js b/loadGameManager.js index 22b54ca..bcc25d4 100644 --- a/loadGameManager.js +++ b/loadGameManager.js @@ -53,7 +53,7 @@ G.inventory = { }, CanBuy: function (itemIndex, price) { if (G.inventory.cargo[itemIndex] < G.stats.hold && G.inventory.money > price && - (G.inventory.cargo[itemIndex] > 0 || G.inventory.CheckCargo().length < G.stats.inventory)) + (G.inventory.cargo[itemIndex] > 0 || G.inventory.CheckCargo().length < G.stats.inventory)) { return true; } else { @@ -87,6 +87,7 @@ G.economy = { // Aww yea, supply and demand. 40, 20, 50, 80, 65, 20, 20, 30, 30, 60, 45, 70], + maxPriceChange: 10, cargoSold: [0, 0, 0, 0, // The more you sell, the lower the price gets 0, 0, 0, 0, 0, 0, 0, 0, diff --git a/prefabs/islandPrefab.js b/prefabs/islandPrefab.js index 83b6b21..a6b2bed 100644 --- a/prefabs/islandPrefab.js +++ b/prefabs/islandPrefab.js @@ -25,15 +25,23 @@ var pr_island = OS.P.Add("Island", { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], - + + money: 0, inventory: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], - storageSpace: [], + + storageSpace: [0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0], innPriceDifference: 0, innStays: 0, - priceDifferences: [], + priceDifferences: [0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0], itemsSold: [0, 0, 0, 0, // The more you sell, the lower the price gets 0, 0, 0, 0, 0, 0, 0, 0, @@ -41,7 +49,14 @@ var pr_island = OS.P.Add("Island", { itemsBought: [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] + 0, 0, 0, 0], + + storageFee: 10, + storageFeeMultiplier: 0.1, + storage: [0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0, + 0, 0, 0, 0] }); pr_island.DoFirst = function () { @@ -60,8 +75,7 @@ pr_island.SetUp = function () { if (this.storageSpace[i] > 20) { this.inventory[i] = Math.round(this.storageSpace[i] - Math.randomRange(0, 10)); - } - if (Math.randomRange(0, 100) < 25) { + } else if (Math.randomRange(0, 100) < 25) { this.inventory[i] = Math.round(Math.randomRange(0, this.storageSpace[i])); } } @@ -72,25 +86,44 @@ pr_island.SetUp = function () { if (this.CheckInventory().length < 4) { this.SetUp(); + } else { + for (var i = 0; i < 16; i++) { + // Generate the amount of money the shop has based on what it has. + this.money += (G.economy.cargoItemWorth[i] + this.priceDifferences[i]) * this.inventory[i]; + } + + // Minimum amount of money is 100. + if (this.money < 100) this.money = 100; } } pr_island.AdjustPrices = function () { for (var i = 0; i < 16; i++) { - this.priceDifferences[i] = 0; + // Save the previous price difference so the change doesn't get above a certain thereshold. + var previousPrice = newPriceDifference = this.priceDifferences[i]; + if (this.inventory[i] > (this.storageSpace[i] / 2)) { - this.priceDifferences[i] += -Math.round(this.inventory[i] * Math.randomRange(1, 3)); - } else if (this.inventory[i] < (this.storageSpace[i] / 4)) { - this.priceDifferences[i] += Math.round((this.storageSpace[i] - this.inventory[i]) * Math.randomRange(1, 3)); - } else { - this.priceDifferences[i] += Math.round(Math.randomRange(-2, 2)); + newPriceDifference -= Math.round(this.inventory[i] * Math.randomRange(1, 3)); + } + else if (this.inventory[i] < (this.storageSpace[i] / 4)) { + newPriceDifference += Math.round((this.storageSpace[i] - this.inventory[i]) * Math.randomRange(1, 3)); + } + else { + newPriceDifference += Math.round(Math.randomRange(-2, 2)); } - this.priceDifferences[i] = Math.round(this.priceDifferences[i] * ((this.itemsBought[i] + 1) / (this.itemsSold[i] + 1))); + newPriceDifference = Math.round(newPriceDifference * ((this.itemsBought[i] + 1) / (this.itemsSold[i] + 1))); - if (G.economy.cargoItemWorth[i] + this.priceDifferences[i] < 0) { - this.priceDifferences[i] = -G.economy.cargoItemWorth[i] + 1; + if (Math.abs(newPriceDifference) > Math.abs(previousPrice) + G.economy.maxPriceChange) { + // Prevent price from changing more than the limit. + newPriceDifference = previousPrice + ((previousPrice < 0) ? -G.economy.maxPriceChange : G.economy.maxPriceChange); } + + if (G.economy.cargoItemWorth[i] + newPriceDifference < 0) { + newPriceDifference = -G.economy.cargoItemWorth[i] + 1; + } + + this.priceDifferences[i] = newPriceDifference; } var priceDifferencesOrdered = this.priceDifferences.slice().sort(sortNumber); @@ -100,8 +133,11 @@ pr_island.AdjustPrices = function () { pr_island.SimulateTrade = function () { // This will be run on a timer that runs when not trading. for (var i = 0; i < 16; i++) { + var amount = 0; if (this.inventory[i] > 0) { - this.inventory[i] += Math.round(Math.randomRange(-this.storageSpace[i], this.storageSpace[i])); + amount = Math.round(Math.randomRange(-this.storageSpace[i], this.storageSpace[i])); + this.inventory[i] += amount; + if (this.inventory[i] < 0) { this.inventory[i] = 0; } @@ -110,11 +146,17 @@ pr_island.SimulateTrade = function () { } } else { if (Math.randomRange(0, 100) < 15) { - this.inventory[i] = Math.round(Math.randomRange(0, this.storageSpace[i])); + amount = Math.round(Math.randomRange(0, this.storageSpace[i])); + this.inventory[i] = amount; } } + // If the amount is positive, then subtract half the amount from the money (because they bought stuff) + // Otherwise, add the negative amount (because they sold that much) + this.money += (-amount * (G.economy.cargoItemWorth[i] + this.priceDifferences[i])) * ((amount > 0) ? 0.5 : 1); } + if (this.money <= 0) this.money = 100; // If they run out of money, give them some. + this.AdjustPrices(); } @@ -154,10 +196,9 @@ pr_island.TradeWith = function () { } pr_island.CanSellTo = function (itemIndex, price) { - if (this.inventory[itemIndex] < this.storageSpace[itemIndex]) { // If there's space in the inventory - if (this.itemsBoughtToday[itemIndex] < this.storageSpace[itemIndex] * 0.75) { // and if the island hasn't bought more than 75% of its storage space today + if (this.inventory[itemIndex] < this.storageSpace[itemIndex] && price < this.money) { + // If there's space in the inventory and there's enough money. return true; - } } return false; } @@ -165,6 +206,7 @@ pr_island.SellTo = function (itemIndex, price) { // Play Buy sound. this.inventory[itemIndex]++; this.itemsBought[itemIndex]++; + this.money -= price; G.inventory.cargo[itemIndex]--; G.inventory.money += price; @@ -173,9 +215,7 @@ pr_island.SellTo = function (itemIndex, price) { pr_island.CanBuyFrom = function (itemIndex, price) { if (this.inventory[itemIndex] > 0) { // If there's enough of the item - if (this.itemsSoldToday[itemIndex] < this.storageSpace[itemIndex] * 0.90) { // and if the island hasn't sold more than 90% of its storage space today return true; - } } return false; } @@ -183,7 +223,7 @@ pr_island.BuyFrom = function (itemIndex, price) { // Play Sell sound. this.inventory[itemIndex]--; this.itemsSold[itemIndex]++; - this.itemsSoldToday[itemIndex]++; + this.money += price; G.inventory.cargo[itemIndex]++; G.inventory.money -= price;