diff --git a/CrosshairMod/Crosshair.cs b/CrosshairMod/Crosshair.cs index d8727c9..aa42e23 100644 --- a/CrosshairMod/Crosshair.cs +++ b/CrosshairMod/Crosshair.cs @@ -8,34 +8,31 @@ using UnityEngine; namespace CrosshairMod { - /* The class responsible for drawing/creating/administrating the crosshair. - * - * This is where settings are applied to the crosshair. - */ + /// + /// Contains Crosshair information and draws/creates it + /// static class Crosshair { - // Crosshair Texture / Style + /// + /// Graphics information for the crosshair + /// private static Texture2D m_texture = new Texture2D(0, 0); private static GUIStyle m_style; - // If crosshair is visible or hidden private static bool m_enabled = true; private static bool m_validState = true; - // Toggles visibilty of the crosshair public static void Toggle() { m_enabled = !m_enabled; Settings.SetSetting("crosshairVisible", 1, true); } - // Returns wether the crosshair is enabled public static bool Enabled() { return m_enabled; } - // Change Color public static void SetColor(int r, int g, int b, int a) { Settings.SetSetting("crosshairColorRed", r); @@ -46,7 +43,6 @@ namespace CrosshairMod Create(); } - // Change Size public static void ChangeSize(int difference) { int currentLength = Settings.GetValue("crosshairLength"); @@ -56,7 +52,6 @@ namespace CrosshairMod Create(); } - // Change Thickness public static void ChangeThickness(int difference) { int currentThickness = Settings.GetValue("crosshairThickness"); @@ -66,7 +61,9 @@ namespace CrosshairMod Create(); } - // This must be called, or else no crosshair will be rendered + /// + /// Creates a new crosshair texture with the current settings + /// public static void Create() { // Creates a crosshair texture @@ -125,7 +122,6 @@ namespace CrosshairMod m_style.normal.background = m_texture; } - // Render the Crosshair public static void Render() { // If the crosshair is faulty, then don't execute this code diff --git a/CrosshairMod/Interface.cs b/CrosshairMod/Interface.cs index 82a207f..1acb1c8 100644 --- a/CrosshairMod/Interface.cs +++ b/CrosshairMod/Interface.cs @@ -8,45 +8,65 @@ using UnityEngine; namespace CrosshairMod { - - /* A class that handles the Crosshair GUI. - * - * Contains all Buttons, Sliders etc. that are able to modify the crosshair. - */ - - // TODO: Create GUILayout.Window to make a less crappy version of the settings window + /// + /// Handles and contains every Object needed for the interface + /// static class Interface { - // Saves wether the interface is visible or not private static bool m_visible = false; - // Stores all Buttons used in the interface. + /// + /// A list of all Objects (That includes buttons, sliders etc) inside the GUI Window + /// This makes it easy to add more components if it is needed. + /// private static List m_inputs = new List(); + // TODO: Replace with dictionary, the whole concept of having IDs inside the objects is stupid and unnecessary - // Values of the RGBA Sliders + /// + /// RGBA Slider values + /// private static int rSliderValue, gSliderValue, bSliderValue, aSliderValue; - // Position ind dimension of the GUI background private static Vector2 m_position; private static Vector2 m_dimension; - // Creates a new button object and adds it to the List + /// + /// Creates a new Button and adds it to the content list + /// + /// X-Position + /// Y-position + /// Width + /// Height + /// Text to be displayed on the button + /// Key of the Button + /// Action to be executed when the button is pressed private static void AddButton(float x, float y, float width, float height, string label, string ID, params EventHandler[] onClickEvent) { - GUIButton buttonObj = new GUIButton(x, y, width, height, label, ID, onClickEvent); + Input.Button buttonObj = new Input.Button(x, y, width, height, label, ID, onClickEvent); m_inputs.Add(buttonObj); } - // Creates a new slider object and adds it to the List - // Returns the index of the button + /// + /// Creates a new Slider and adds ot to the content list + /// + /// X-Position + /// Y-Position/param> + /// Width + /// Height + /// Minimum value of the slider + /// Maximum value of the slider + /// Starting value of the slider + /// Key of the slider private static void AddSlider(float x, float y, float width, float height, float min, float max, float init, string ID) { - GUISlider sliderObj = new GUISlider(x, y, width, height, min, max, init, ID); + Input.Slider sliderObj = new Input.Slider(x, y, width, height, min, max, init, ID); m_inputs.Add(sliderObj); } - // Initializes all Buttons, gives them their function etc + /// + /// Creates all needed input objects and initializes window + /// public static void Init() { // Set dimension to 0.25 of the screen width/height @@ -58,7 +78,7 @@ namespace CrosshairMod // Create Crosshair Visibilty Button AddButton(20, 20, 200, 30, (Crosshair.Enabled() ? "Hide Crosshair" : "Show Crosshair"), "Toggle", (object sender, EventArgs e) => { Crosshair.Toggle(); }, - (object sender, EventArgs e) => { GUIButton btn = (GUIButton)sender; btn.label = (Crosshair.Enabled() ? "Hide Crosshair" : "Show Crosshair"); }); + (object sender, EventArgs e) => { Input.Button btn = (Input.Button)sender; btn.Label = (Crosshair.Enabled() ? "Hide Crosshair" : "Show Crosshair"); }); // Create Crosshair Size +/- Buttons AddButton(20, 60, 30, 30, @@ -84,20 +104,21 @@ namespace CrosshairMod AddSlider(m_dimension.x / 2 + 60, 150, 200, 30, 0, 255, aSliderValue, "alpha"); } - // Displays / Hides the menu public static void Toggle() { m_visible = !m_visible; } - // Renders the window public static void Render() { + // TODO: Think about making this a GUILayout.ModalWindow if (m_visible) GUI.Window(420, new Rect(m_position, m_dimension), RenderFunc, "Crosshair Settings"); } - // Renders the Panel, but also handles Updating the buttons + /// + /// Where actual rendering happens. Draws all objects and updated them + /// private static void RenderFunc(int windowID) { // Make Window draggable @@ -114,7 +135,7 @@ namespace CrosshairMod GUI.Label(new Rect(m_dimension.x / 2 + 20, 150, 200, 30), "A: " + aSliderValue); // Set crosshair Colour after getting slider values - IEnumerable it = m_inputs.OfType(); + IEnumerable it = m_inputs.OfType(); rSliderValue = (int)it.First(slider => slider.ID == "red").Value; gSliderValue = (int)it.First(slider => slider.ID == "green").Value; bSliderValue = (int)it.First(slider => slider.ID == "blue").Value; @@ -123,12 +144,14 @@ namespace CrosshairMod Crosshair.SetColor(rSliderValue, gSliderValue, bSliderValue, aSliderValue); // Update Buttons - HandleButtons(); + HandleInputObjects(); } - // Calls the Update function on all Buttons to check if they were pressed, and execute their Action - private static void HandleButtons() + /// + /// Calls the Update function of each input object + /// + private static void HandleInputObjects() { foreach(InputObject obj in m_inputs) { diff --git a/CrosshairMod/Interface/Button.cs b/CrosshairMod/Interface/Button.cs index 895da89..6e4f259 100644 --- a/CrosshairMod/Interface/Button.cs +++ b/CrosshairMod/Interface/Button.cs @@ -6,51 +6,62 @@ using System.Text; using UnityEngine; -namespace CrosshairMod +namespace CrosshairMod.Input { - /* - * A button wrapper class that is used right now as I don't have access to - * the games buttons. Since UnityEngine.GUI only has a function to draw Buttons, - * I made this class for easy handling. - * - */ - class GUIButton : InputObject + /// + /// Button wrapper for Unitys GUI.Button() function. I made this in order + /// to store buttons and render them in Lists + /// + class Button : InputObject { - // da_google thinks this Button Wrapper is stupid, so let's see what ths Button Wrapper thinks about him - private const bool IS_DA_GOOGLE_STUPID = true; - // Interesting. - - // OnClick event + /// + /// Event Handler that contains the actions to execute when the Button was clicked + /// public event EventHandler OnClick; - // Label of the Button - public string label { get; set; } = ""; + public string Label = ""; - // Initialize Button - public GUIButton(float x, float y, float width, float height, string label, string ID, params EventHandler[] OnClickEvent) + /// + /// Create new Button + /// + /// X-Position + /// Y-Position + /// Width + /// Height + /// Text inside the button + /// Button ID + /// Action to execute when button is pressed + public Button(float x, float y, float width, float height, string label, string ID, params EventHandler[] OnClickEvent) : base(x, y, width, height, ID) { - Logging.Debug.Log("Button Constructor"); + Logging.Debug.Log("Button Constructor: " + label); // Assign position, dimension and label - this.label = label; + this.Label = label; // Push OnClickEvents foreach(EventHandler e in OnClickEvent) OnClick += e; } - public GUIButton(string ID) + /// + /// Sad, pathetic default constructor + /// + /// + public Button(string ID) : base(0, 0, 0, 0, ID) { // Empty } - // Updates and Draws the Button. + /// + /// Draws button and returns button state / executes button action + /// + /// 1f if the button is pressed, 0f else public override float Update() { // Get if the Button was pressed and invoke OnClick event accordingly - bool buttonPressed = GUI.Button(new Rect(position, dimensions), label); + bool buttonPressed = GUI.Button(new Rect(position, dimensions), Label); if (buttonPressed) OnClick?.Invoke(this, EventArgs.Empty); diff --git a/CrosshairMod/Interface/InputObject.cs b/CrosshairMod/Interface/InputObject.cs index 7e14d2a..11743bf 100644 --- a/CrosshairMod/Interface/InputObject.cs +++ b/CrosshairMod/Interface/InputObject.cs @@ -8,21 +8,25 @@ using UnityEngine; namespace CrosshairMod { - /* - * Base of all Input Objects. - * - * Any Input Object that wants to be displayed in the Interface must - * inherit from this class. - */ + /// + /// Base class for all InputObjects. Defines basic attributes that + /// every input object needs + /// abstract class InputObject { - // position and dimension of the object public Vector2 position, dimensions; - - // ID of the Object + + // TODO: Remove once dictionary was implemented public readonly string ID; - // constructor to set position and size + /// + /// Create new InputObject + /// + /// X-Position + /// Y-Position + /// Width + /// Height + /// ID public InputObject(float x, float y, float width, float height, string ID) { this.position = new Vector2(x, y); @@ -30,7 +34,11 @@ namespace CrosshairMod this.ID = ID; } - // the update method (that works as renderer) must be overriden by each object + /// + /// The Update method every Input Object needs. + /// This is needed to store all kinds of input objects in one List for example + /// + /// Value of the Object public abstract float Update(); } } diff --git a/CrosshairMod/Interface/Slider.cs b/CrosshairMod/Interface/Slider.cs index 47dbf80..df6a28d 100644 --- a/CrosshairMod/Interface/Slider.cs +++ b/CrosshairMod/Interface/Slider.cs @@ -6,18 +6,33 @@ using System.Text; using UnityEngine; -namespace CrosshairMod +namespace CrosshairMod.Input { - class GUISlider : InputObject + class Slider : InputObject { - // Min/Max values for the slider - public float Min { get; set; } = 0; - public float Max { get; set; } = 0; + /// + /// Min/Max Slider values + /// + public float Min = 0; + public float Max = 0; - // Current slider value - public float Value { get; set; } = 0; + /// + /// Current slider value + /// + public float Value = 0; - public GUISlider(float x, float y, float width, float height, float min, float max, float init, string ID) + /// + /// Creates a new Slider + /// + /// X-Position + /// Y-Position + /// Width + /// Height + /// Minimum Slider value + /// Maximum Slider value + /// Initial Slider value + /// ID + public Slider(float x, float y, float width, float height, float min, float max, float init, string ID) : base(x, y, width, height, ID) { Min = min; @@ -25,12 +40,20 @@ namespace CrosshairMod Value = init; } - public GUISlider(string ID) + /// + /// Sad, pathetic default constructor + /// + /// + public Slider(string ID) :base (0, 0, 0, 0, ID) { } + /// + /// Draws and Updates the slider + /// + /// Value of the Slider public override float Update() { Value = GUI.HorizontalSlider(new Rect(position, dimensions), Value, Min, Max); diff --git a/CrosshairMod/Logging.cs b/CrosshairMod/Logging.cs index db9fd39..3f1c199 100644 --- a/CrosshairMod/Logging.cs +++ b/CrosshairMod/Logging.cs @@ -8,17 +8,17 @@ using UnityEngine; namespace CrosshairMod { - // CrosshairMod's Logging class - // Simply writes messages to the Unity Debug output - // However, I prefer this over Debug.Log() since it doesn't include a stacktrace (Except for Errors) + /// + /// Handles Logging in the Crosshair mod + /// public static class Logging { - // The Prefix that gets put in front of every Log public const string PREFIX = "[CROSSHAIRMOD]"; - // A kind of sub-class that is used to Log messages that will only appear - // when the User installs a Debug build of the Mod. Release versions will - // not log Debug messages this way. + /// + /// Logging's subclass for Debug Logging. + /// This only logs messages in the debug build of the mod. + /// public static class Debug { public static void Log(string message) @@ -44,19 +44,17 @@ namespace CrosshairMod } - // Logs information public static void Log(string message) { Console.WriteLine(PREFIX + "Info: " + message); } - // Logs warnings public static void LogWarning(string message) { Console.WriteLine(PREFIX + "Warning: " + message); } - // Logs errors + public static void LogError(string message) { UnityEngine.Debug.Log(PREFIX + "Error: " + message); diff --git a/CrosshairMod/Main.cs b/CrosshairMod/Main.cs index a73c6b3..910981d 100644 --- a/CrosshairMod/Main.cs +++ b/CrosshairMod/Main.cs @@ -1,12 +1,11 @@ /* - * Source code of a mode that adds a crosshair into + * Source code of a mod that adds a crosshair into * the game Blackwake. * * @author Lauchmelder - * @version v0.3 + * @version v0.3.1 */ - using System; using System.Collections.Generic; using System.Linq; @@ -16,24 +15,22 @@ using UnityEngine; namespace CrosshairMod { - - /* - * This is the Main class that is responsible for - * handling initializing and updating the components - * of the crosshair mod. - */ + /// + /// Class that gets loaded by the ModLoader. Calls every component of the Mod + /// public class CrosshairMod : MonoBehaviour { - // Define Hotkeys for Menu and Crosshair Toggle + /// + /// Default Hotkey Definitions + /// private char MENU_OPEN_KEY = 'H'; private char CH_TOGGLE_KEY = 'J'; - // This will be executed first void Start() { // Update the settings - Settings.LoadSettings(".\\Blackwake_Data\\Managed\\Mods\\chSettings.sett"); + Settings.LoadSettings(".\\Blackwake_Data\\Managed\\Mods\\Assets\\chSettings.sett"); // Create Crosshair Crosshair.Create(); // Create Panel @@ -44,7 +41,6 @@ namespace CrosshairMod CH_TOGGLE_KEY = (char)Settings.GetValue("hotkeyGUIToggle", true, CH_TOGGLE_KEY); } - // This gets called on every GUI Update (Can be multiple tiems per Frame) void OnGUI() { // Check for Key presses @@ -66,11 +62,10 @@ namespace CrosshairMod Crosshair.Render(); } - // Will be called when the application is closed void OnApplicationQuit() { // Save settings - Settings.SaveSettings(".\\Blackwake_Data\\Managed\\Mods\\chSettings.sett"); + Settings.SaveSettings(".\\Blackwake_Data\\Managed\\Mods\\Assets\\chSettings.sett"); Logging.Debug.Log("Saved Settings"); } } diff --git a/CrosshairMod/Settings.cs b/CrosshairMod/Settings.cs index 795ad70..a48bedc 100644 --- a/CrosshairMod/Settings.cs +++ b/CrosshairMod/Settings.cs @@ -6,16 +6,17 @@ using System.Text; namespace CrosshairMod { - /* - * The class that is responsible for loading and storing all the - * necessary settings. There is much room for improvement. - */ + /// + /// Loads, contains and handles settings + /// static class Settings { - // Initialize Settings dictionary private static Dictionary m_settings = new Dictionary(); - // Load settings from file + /// + /// Load settings from file + /// + /// public static void LoadSettings(string filepath) { Logging.Debug.Log("Accessing Settings at " + filepath); @@ -75,7 +76,10 @@ namespace CrosshairMod Logging.Log("Settings loaded."); } - // Converts the dictionary to a sett file + /// + /// Converts dictionary to a string to be stored in the settings file + /// + /// Save location public static void SaveSettings(string filepath) { string filecontent = ""; @@ -87,7 +91,11 @@ namespace CrosshairMod System.IO.File.WriteAllText(filepath, filecontent); } - // Adds a setting to the settings + /// + /// Create new setting and add it to the dictionary + /// + /// Setting name + /// Setting value public static void AddSetting(string key, int value) { if (m_settings.ContainsKey(key)) @@ -96,7 +104,12 @@ namespace CrosshairMod m_settings.Add(key, value); } - // Changes a settings value, and adds it if specified + /// + /// Change a settings value + /// + /// Setting name + /// New setting value + /// If the setting doesn't exist, create it public static void SetSetting(string key, int newVal, bool addIfDoesntExist = false) { // If the setting doesn't exist, either add and set it, or print a Debug.Warning @@ -117,9 +130,13 @@ namespace CrosshairMod m_settings[key] = newVal; } - // Tries to return the value belonging to a certain key - // If the specified key doesn't exist, it returns 0 and logs an error - // One can also specify that the setting should be created with some initial value + /// + /// Returns the value of a setting + /// + /// Setting name + /// Add the setting if it doesn't exist + /// Initial value of the setting in case it doesn't exist + /// public static int GetValue(string key, bool addIfDoesntExist = false, int initialValue = 0) { int value = 0;