416 lines
18 KiB
C#
416 lines
18 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Timers;
|
|
using System.Threading.Tasks;
|
|
using Newtonsoft.Json;
|
|
using Newtonsoft.Json.Linq;
|
|
using StardewModdingAPI;
|
|
using Microsoft.Xna.Framework;
|
|
using System.Windows;
|
|
namespace BuildEndurance
|
|
{
|
|
|
|
public class BuildEndurance : Mod
|
|
{
|
|
public static double BuildEndurance_data_xp_nextlvl=20;
|
|
public static double BuildEndurance_data_xp_current=0;
|
|
|
|
public static int BuildEndurance_data_current_lvl=0;
|
|
|
|
public static int BuildEndurance_data_stam_bonus_acumulated=0;
|
|
|
|
public static int BuildEndurance_data_ini_stam_bonus=0;
|
|
|
|
public static bool BuildEndurance_data_clear_mod_effects = false;
|
|
|
|
public static int BuildEndurance_data_old_stamina = 0;
|
|
|
|
public static bool tool_cleaner = false;
|
|
|
|
public static bool fed = false;
|
|
|
|
public Config ModConfig { get; set; }
|
|
|
|
public static bool upon_loading = false;
|
|
|
|
//Credit goes to Zoryn for pieces of this config generation that I kinda repurposed.
|
|
public override void Entry(params object[] objects)
|
|
{
|
|
Log.Info("HEYO WORLD");
|
|
|
|
StardewModdingAPI.Events.GameEvents.UpdateTick += EatingCallBack; //sloppy again but it'll do.
|
|
|
|
StardewModdingAPI.Events.GameEvents.OneSecondTick += Tool_Cleanup;
|
|
StardewModdingAPI.Events.GameEvents.UpdateTick += ToolCallBack;
|
|
StardewModdingAPI.Events.PlayerEvents.LoadedGame += LoadingCallBack;
|
|
StardewModdingAPI.Events.TimeEvents.DayOfMonthChanged += SleepCallback;
|
|
|
|
var configLocation = Path.Combine(PathOnDisk, "BuildEnduranceConfig.json");
|
|
if (!File.Exists(configLocation))
|
|
{
|
|
Console.WriteLine("Initial configuration file setup.");
|
|
ModConfig = new Config();
|
|
|
|
ModConfig.BuildEndurance_current_lvl = 0;
|
|
ModConfig.BuildEndurance_max_lvl = 100;
|
|
|
|
ModConfig.BuildEndurance_stam_increase_upon_lvl_up = 1;
|
|
|
|
ModConfig.BuildEndurance_xp_current = 0;
|
|
ModConfig.BuildEndurance_xp_nextlvl = 20;
|
|
ModConfig.BuildEndurance_xp_curve = 1.15;
|
|
|
|
ModConfig.BuildEndurance_xp_eating = 2;
|
|
ModConfig.BuildEndurance_xp_sleeping = 10;
|
|
ModConfig.BuildEndurance_xp_tooluse = 1;
|
|
|
|
ModConfig.BuildEndurance_ini_stam_boost = 0;
|
|
|
|
ModConfig.BuildEndurance_stam_accumulated = 0;
|
|
|
|
File.WriteAllBytes(configLocation, Encoding.UTF8.GetBytes(JsonConvert.SerializeObject(ModConfig)));
|
|
}
|
|
else
|
|
{
|
|
ModConfig = JsonConvert.DeserializeObject<Config>(Encoding.UTF8.GetString(File.ReadAllBytes(configLocation)));
|
|
Console.WriteLine("Found BuildEndurance config file.");
|
|
}
|
|
|
|
// DataLoader();
|
|
// MyWritter(); //hopefully loading these after the game is loaded will prevent wierd issues.
|
|
|
|
Console.WriteLine("BuildEndurance Initialization Completed");
|
|
}
|
|
|
|
|
|
|
|
public void ToolCallBack(object sender, EventArgs e) //ultra quick response for checking if a tool is used.
|
|
{
|
|
if (tool_cleaner == true) return;
|
|
|
|
|
|
if (StardewModdingAPI.Entities.SPlayer.CurrentFarmer.usingTool == true)
|
|
{
|
|
//Console.WriteLine("Tool is being used");
|
|
BuildEndurance_data_xp_current += ModConfig.BuildEndurance_xp_tooluse;
|
|
tool_cleaner = true;
|
|
}
|
|
else return;
|
|
}
|
|
|
|
public void Tool_Cleanup(object sender, EventArgs e) //nerfs how quickly xp is actually gained. I hope.
|
|
{
|
|
|
|
if (tool_cleaner == true) tool_cleaner = false;
|
|
else return;
|
|
}
|
|
|
|
public void EatingCallBack(object sender, EventArgs e)
|
|
{
|
|
|
|
|
|
if (StardewValley.Game1.isEating == true)
|
|
{
|
|
// Console.WriteLine("NOM NOM NOM");
|
|
fed = true;
|
|
|
|
//this code will run when the player eats an object. I.E. increases their eating skills.
|
|
}
|
|
//I'm going to assume they ate the food.
|
|
if ((StardewValley.Game1.isEating == false) && fed == true)
|
|
{
|
|
// Console.WriteLine("NOM NOM NOM");
|
|
BuildEndurance_data_xp_current += ModConfig.BuildEndurance_xp_eating;
|
|
fed = false;
|
|
}
|
|
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
|
|
public void LoadingCallBack(object sender, EventArgs e)
|
|
{
|
|
|
|
// Log.Info("GamessssssssLoaded");
|
|
// Console.WriteLine("entering loading callback");
|
|
if (StardewModdingAPI.Inheritance.SGame.hasLoadedGame == true)
|
|
{
|
|
Log.Info("CharacterLoaded");
|
|
// Console.WriteLine("Penetrated loading callback");
|
|
//Log.Info(StardewValley.Game1.player.name);
|
|
DataLoader();
|
|
MyWritter();
|
|
upon_loading = true;
|
|
Log.Info("writers passed");
|
|
//runs when the player is loaded.
|
|
|
|
|
|
var player = StardewValley.Game1.player;
|
|
|
|
if (BuildEndurance_data_old_stamina == 0)
|
|
{
|
|
BuildEndurance_data_old_stamina = player.MaxStamina; //grab the initial stamina value
|
|
}
|
|
|
|
player.MaxStamina = BuildEndurance_data_ini_stam_bonus + BuildEndurance_data_stam_bonus_acumulated + BuildEndurance_data_old_stamina; //incase the ini stam bonus is loaded in.
|
|
|
|
if (BuildEndurance_data_clear_mod_effects == true)
|
|
{
|
|
player.MaxStamina = BuildEndurance_data_old_stamina;
|
|
Console.WriteLine("BuildEndurance Reset!");
|
|
}
|
|
|
|
DataLoader();
|
|
MyWritter();
|
|
}
|
|
|
|
}
|
|
|
|
public void SleepCallback(object sender, EventArgs e)
|
|
{
|
|
Log.Info("SLEEP CALLBACK");
|
|
|
|
Log.Info("CLEAR DATA PASSED");
|
|
//This will run when the character goes to sleep. It will increase their sleeping skill.
|
|
//Console.WriteLine("Is this being hit?");
|
|
|
|
if (upon_loading == true)
|
|
{
|
|
Clear_DataLoader();
|
|
//because this doesn't work propperly at first anyways.
|
|
|
|
//return;
|
|
|
|
|
|
|
|
var player = StardewValley.Game1.player;
|
|
|
|
BuildEndurance_data_xp_current += ModConfig.BuildEndurance_xp_sleeping;
|
|
|
|
if (BuildEndurance_data_old_stamina == 0)
|
|
{
|
|
BuildEndurance_data_old_stamina = player.MaxStamina; //grab the initial stamina value
|
|
}
|
|
|
|
if (BuildEndurance_data_clear_mod_effects == true)
|
|
{
|
|
player.MaxStamina = BuildEndurance_data_old_stamina;
|
|
BuildEndurance_data_xp_nextlvl = ModConfig.BuildEndurance_xp_nextlvl;
|
|
BuildEndurance_data_xp_current = ModConfig.BuildEndurance_xp_current;
|
|
BuildEndurance_data_stam_bonus_acumulated = 0;
|
|
BuildEndurance_data_old_stamina = player.MaxStamina;
|
|
BuildEndurance_data_ini_stam_bonus = 0;
|
|
BuildEndurance_data_current_lvl = 0;
|
|
Console.WriteLine("BuildEndurance Reset!");
|
|
}
|
|
|
|
|
|
if (BuildEndurance_data_clear_mod_effects == false)
|
|
{
|
|
if (BuildEndurance_data_current_lvl < ModConfig.BuildEndurance_max_lvl)
|
|
{
|
|
while (BuildEndurance_data_xp_current >= BuildEndurance_data_xp_nextlvl)
|
|
{
|
|
BuildEndurance_data_current_lvl += 1;
|
|
BuildEndurance_data_xp_current = BuildEndurance_data_xp_current - BuildEndurance_data_xp_nextlvl;
|
|
BuildEndurance_data_xp_nextlvl = (ModConfig.BuildEndurance_xp_curve * BuildEndurance_data_xp_nextlvl);
|
|
player.MaxStamina += ModConfig.BuildEndurance_stam_increase_upon_lvl_up;
|
|
BuildEndurance_data_stam_bonus_acumulated += ModConfig.BuildEndurance_stam_increase_upon_lvl_up;
|
|
Log.Info("IF YOU SEE THIS TOO MUCH THIS IS AN INFINITE LOOP. CRAP");
|
|
}
|
|
|
|
/*
|
|
if (player.MaxStamina != BuildEndurance_data_old_stamina + BuildEndurance_data_stam_bonus_acumulated + BuildEndurance_data_ini_stam_bonus)
|
|
{
|
|
player.MaxStamina = BuildEndurance_data_old_stamina + BuildEndurance_data_stam_bonus_acumulated + BuildEndurance_data_ini_stam_bonus;
|
|
}
|
|
*/
|
|
|
|
|
|
}
|
|
}
|
|
BuildEndurance_data_clear_mod_effects = false;
|
|
|
|
MyWritter();
|
|
}
|
|
else Log.Info("Lazy programming");
|
|
}
|
|
|
|
|
|
//Mod config data.
|
|
public class Config
|
|
{
|
|
public double BuildEndurance_xp_nextlvl { get; set; }
|
|
public double BuildEndurance_xp_current { get; set; }
|
|
public double BuildEndurance_xp_curve { get; set; }
|
|
|
|
public int BuildEndurance_current_lvl { get; set; }
|
|
public int BuildEndurance_max_lvl { get; set; }
|
|
|
|
public int BuildEndurance_stam_increase_upon_lvl_up { get; set; }
|
|
|
|
public int BuildEndurance_xp_tooluse { get; set; }
|
|
public int BuildEndurance_xp_eating { get; set; }
|
|
public int BuildEndurance_xp_sleeping { get; set; }
|
|
|
|
public int BuildEndurance_ini_stam_boost { get; set; }
|
|
|
|
public int BuildEndurance_stam_accumulated { get; set; }
|
|
|
|
}
|
|
|
|
|
|
void Clear_DataLoader()
|
|
{
|
|
DataLoader();
|
|
MyWritter();
|
|
//loads the data to the variables upon loading the game.
|
|
string myname = StardewValley.Game1.player.name;
|
|
string mylocation = Path.Combine(PathOnDisk, "BuildEndurance_data_");
|
|
string mylocation2 = mylocation+myname;
|
|
string mylocation3 = mylocation2+".txt";
|
|
if (!File.Exists(mylocation3)) //if not data.json exists, initialize the data variables to the ModConfig data. I.E. starting out.
|
|
{
|
|
Console.WriteLine("Clear Data Loaded could not find the correct file.");
|
|
|
|
|
|
BuildEndurance_data_clear_mod_effects = false;
|
|
BuildEndurance_data_old_stamina = 0;
|
|
BuildEndurance_data_ini_stam_bonus = 0;
|
|
//return;
|
|
}
|
|
|
|
else
|
|
{
|
|
//loads the BuildEndurance_data upon loading the mod
|
|
string[] readtext = File.ReadAllLines(mylocation3);
|
|
BuildEndurance_data_ini_stam_bonus = Convert.ToInt32(readtext[9]);
|
|
BuildEndurance_data_clear_mod_effects = Convert.ToBoolean(readtext[14]);
|
|
BuildEndurance_data_old_stamina = Convert.ToInt32(readtext[16]);
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
void DataLoader()
|
|
{
|
|
//loads the data to the variables upon loading the game.
|
|
string myname = StardewValley.Game1.player.name;
|
|
string mylocation = Path.Combine(PathOnDisk, "BuildEndurance_data_");
|
|
string mylocation2 = mylocation + myname;
|
|
string mylocation3 = mylocation2 + ".txt";
|
|
if (!File.Exists(mylocation3)) //if not data.json exists, initialize the data variables to the ModConfig data. I.E. starting out.
|
|
{
|
|
Console.WriteLine("DataLoading");
|
|
BuildEndurance_data_xp_nextlvl = ModConfig.BuildEndurance_xp_nextlvl;
|
|
BuildEndurance_data_xp_current = ModConfig.BuildEndurance_xp_current;
|
|
BuildEndurance_data_current_lvl = ModConfig.BuildEndurance_current_lvl;
|
|
BuildEndurance_data_ini_stam_bonus = ModConfig.BuildEndurance_ini_stam_boost;
|
|
BuildEndurance_data_stam_bonus_acumulated = ModConfig.BuildEndurance_stam_accumulated;
|
|
BuildEndurance_data_clear_mod_effects = false;
|
|
BuildEndurance_data_old_stamina = 0;
|
|
|
|
}
|
|
|
|
else
|
|
{
|
|
// Console.WriteLine("HEY THERE IM LOADING DATA");
|
|
|
|
//loads the BuildEndurance_data upon loading the mod
|
|
string[] readtext = File.ReadAllLines(mylocation3);
|
|
BuildEndurance_data_current_lvl = Convert.ToInt32(readtext[3]);
|
|
BuildEndurance_data_xp_nextlvl = Convert.ToDouble(readtext[7]); //these array locations refer to the lines in BuildEndurance_data.json
|
|
BuildEndurance_data_xp_current = Convert.ToDouble(readtext[5]);
|
|
BuildEndurance_data_ini_stam_bonus = Convert.ToInt32(readtext[9]);
|
|
BuildEndurance_data_stam_bonus_acumulated = Convert.ToInt32(readtext[11]);
|
|
BuildEndurance_data_clear_mod_effects = Convert.ToBoolean(readtext[14]);
|
|
BuildEndurance_data_old_stamina = Convert.ToInt32(readtext[16]);
|
|
|
|
}
|
|
}
|
|
|
|
void MyWritter()
|
|
{
|
|
//saves the BuildEndurance_data at the end of a new day;
|
|
string myname = StardewValley.Game1.player.name;
|
|
string mylocation = Path.Combine(PathOnDisk, "BuildEndurance_data_");
|
|
string mylocation2 = mylocation + myname;
|
|
string mylocation3 = mylocation2 + ".txt";
|
|
string[] mystring3= new string[20];
|
|
if (!File.Exists(mylocation3))
|
|
{
|
|
Console.WriteLine("The data file for BuildEndurance was not found, guess I'll create it when you sleep.");
|
|
|
|
//write out the info to a text file at the end of a day. This will run if it doesnt exist.
|
|
|
|
mystring3[0] = "Player: Build Endurance Data. Modification can cause errors. Edit at your own risk.";
|
|
mystring3[1] = "====================================================================================";
|
|
|
|
mystring3[2] = "Player Current Level:";
|
|
mystring3[3] = BuildEndurance_data_current_lvl.ToString();
|
|
|
|
mystring3[4] = "Player Current XP:";
|
|
mystring3[5] = BuildEndurance_data_xp_current.ToString();
|
|
|
|
mystring3[6] = "Xp to next Level:";
|
|
mystring3[7] = BuildEndurance_data_xp_nextlvl.ToString();
|
|
|
|
mystring3[8] = "Initial Stam Bonus:";
|
|
mystring3[9] = BuildEndurance_data_ini_stam_bonus.ToString();
|
|
|
|
mystring3[10] = "Additional Stam Bonus:";
|
|
mystring3[11] = BuildEndurance_data_stam_bonus_acumulated.ToString();
|
|
|
|
mystring3[12] = "=======================================================================================";
|
|
mystring3[13] = "RESET ALL MOD EFFECTS? This will effective start you back at square 1. Also good if you want to remove this mod.";
|
|
mystring3[14] = BuildEndurance_data_clear_mod_effects.ToString();
|
|
mystring3[15] = "OLD STAMINA AMOUNT: This is the initial value of the Player's Stamina before this mod took over.";
|
|
mystring3[16] = BuildEndurance_data_old_stamina.ToString();
|
|
|
|
File.WriteAllLines(mylocation3, mystring3);
|
|
}
|
|
|
|
else
|
|
{
|
|
// Console.WriteLine("HEY IM SAVING DATA");
|
|
|
|
//write out the info to a text file at the end of a day.
|
|
mystring3[0] = "Player: Build Endurance Data. Modification can cause errors. Edit at your own risk.";
|
|
mystring3[1] = "====================================================================================";
|
|
|
|
mystring3[2] = "Player Current Level:";
|
|
mystring3[3] = BuildEndurance_data_current_lvl.ToString();
|
|
|
|
mystring3[4] = "Player Current XP:";
|
|
mystring3[5] = BuildEndurance_data_xp_current.ToString();
|
|
|
|
mystring3[6] = "Xp to next Level:";
|
|
mystring3[7] = BuildEndurance_data_xp_nextlvl.ToString();
|
|
|
|
mystring3[8] = "Initial Stam Bonus:";
|
|
mystring3[9] = BuildEndurance_data_ini_stam_bonus.ToString();
|
|
|
|
mystring3[10] = "Additional Stam Bonus:";
|
|
mystring3[11] = BuildEndurance_data_stam_bonus_acumulated.ToString();
|
|
|
|
mystring3[12] = "=======================================================================================";
|
|
mystring3[13] = "RESET ALL MOD EFFECTS? This will effective start you back at square 1. Also good if you want to remove this mod.";
|
|
mystring3[14] = BuildEndurance_data_clear_mod_effects.ToString();
|
|
mystring3[15] = "OLD STAMINA AMOUNT: This is the initial value of the Player's Stamina before this mod took over.";
|
|
mystring3[16] = BuildEndurance_data_old_stamina.ToString();
|
|
|
|
|
|
File.WriteAllLines(mylocation3, mystring3);
|
|
}
|
|
}
|
|
|
|
} //end my function
|
|
} |