Made the letter/mailbox menu accessible
This commit is contained in:
		| @@ -58,5 +58,23 @@ namespace stardew_access.Game | ||||
|             int y = (int)player.getTileLocation().Y; | ||||
|             return y; | ||||
|         } | ||||
|  | ||||
|         internal static int getToolHItPositionX() | ||||
|         { | ||||
|             if (player == null) | ||||
|                 initPlayer(); | ||||
|  | ||||
|             int x = (int)player.GetGrabTile().X; | ||||
|             return x; | ||||
|         } | ||||
|  | ||||
|         internal static int getToolHItPositionY() | ||||
|         { | ||||
|             if (player == null) | ||||
|                 initPlayer(); | ||||
|  | ||||
|             int y = (int)player.GetGrabTile().Y; | ||||
|             return y; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -7,6 +7,7 @@ using StardewValley.Menus; | ||||
| using Microsoft.Xna.Framework.Graphics; | ||||
| using stardew_access.Patches; | ||||
| using AutoHotkey.Interop; | ||||
| using Microsoft.Xna.Framework; | ||||
|  | ||||
| namespace stardew_access | ||||
| { | ||||
| @@ -85,9 +86,30 @@ namespace stardew_access | ||||
|                 postfix: new HarmonyMethod(typeof(MenuPatch), nameof(MenuPatch.NewGameMenuPatch)) | ||||
|             ); | ||||
|  | ||||
|             harmony.Patch( | ||||
|                 original: AccessTools.Method(typeof(LetterViewerMenu), nameof(LetterViewerMenu.draw), new Type[] { typeof(SpriteBatch) }), | ||||
|                 postfix: new HarmonyMethod(typeof(MenuPatch), nameof(MenuPatch.LetterViewerMenuPatch)) | ||||
|             ); | ||||
|  | ||||
|             #endregion | ||||
|  | ||||
|             helper.Events.Input.ButtonPressed += this.OnButtonPressed; | ||||
|             helper.Events.GameLoop.UpdateTicked += this.onUpdateTicked; | ||||
|         } | ||||
|  | ||||
|         private void onUpdateTicked(object sender, UpdateTickedEventArgs e) | ||||
|         { | ||||
|             if (!Context.IsPlayerFree) | ||||
|                 return; | ||||
|  | ||||
|              | ||||
|         } | ||||
|  | ||||
|         private void On1SecUpdateTicked(object sender, OneSecondUpdateTickedEventArgs e) | ||||
|         { | ||||
|  | ||||
|              | ||||
|              | ||||
|         } | ||||
|  | ||||
|         private void OnButtonPressed(object sender, ButtonPressedEventArgs e) | ||||
| @@ -104,7 +126,7 @@ namespace stardew_access | ||||
|                 // Narrate Position | ||||
|                 if (Equals(e.Button, SButton.K)) | ||||
|                 { | ||||
|                     string toSpeak = $"X: {CurrentPlayer.getPositionX()} , Y: {CurrentPlayer.getPositionX()}"; | ||||
|                     string toSpeak = $"X: {CurrentPlayer.getPositionX()} , Y: {CurrentPlayer.getPositionY()}"; | ||||
|                     ScreenReader.say(toSpeak, true); | ||||
|                 } | ||||
|  | ||||
|   | ||||
| @@ -9,6 +9,67 @@ namespace stardew_access.Patches | ||||
|     { | ||||
|         private static int saveGameIndex = -1; | ||||
|         private static bool isRunning = false; | ||||
|         private static string currentLetterText = " "; | ||||
|  | ||||
|         internal static void LetterViewerMenuPatch(LetterViewerMenu __instance) | ||||
|         { | ||||
|             try | ||||
|             { | ||||
|                 if (!__instance.IsActive()) | ||||
|                     return; | ||||
|  | ||||
|                 #region Texts in the letter | ||||
|                 string title = __instance.mailTitle; | ||||
|                 string message = __instance.mailMessage[__instance.page]; | ||||
|  | ||||
|                 string toSpeak = $"{title} \t\n\t {message}."; | ||||
|  | ||||
|                 if (__instance.ShouldShowInteractable()) | ||||
|                 { | ||||
|                     if (__instance.moneyIncluded > 0) | ||||
|                     { | ||||
|                         string moneyText = Game1.content.LoadString("Strings\\UI:LetterViewer_MoneyIncluded", __instance.moneyIncluded); | ||||
|                         toSpeak += $"\t\n\t ,Included money: {moneyText}"; | ||||
|                     } | ||||
|                     else if (__instance.learnedRecipe != null && __instance.learnedRecipe.Length > 0) | ||||
|                     { | ||||
|                         string recipeText = Game1.content.LoadString("Strings\\UI:LetterViewer_LearnedRecipe", __instance.cookingOrCrafting); | ||||
|                         toSpeak += $"\t\n\t ,Learned Recipe: {recipeText}"; | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 if (__instance.ShouldShowInteractable() && __instance.questID != -1) | ||||
|                 { | ||||
|                     toSpeak += "\t\n\t ,Close this menu to accept or press left click button"; | ||||
|                 } | ||||
|  | ||||
|                 if (currentLetterText != toSpeak) | ||||
|                 { | ||||
|                     currentLetterText = toSpeak; | ||||
|                     ScreenReader.say(toSpeak, false); | ||||
|                 } | ||||
|                 #endregion | ||||
|  | ||||
|                 #region Narrate items given in the mail | ||||
|                 if (__instance.ShouldShowInteractable()) | ||||
|                 { | ||||
|                     foreach (ClickableComponent c in __instance.itemsToGrab) | ||||
|                     { | ||||
|                         string name = c.name; | ||||
|                         string label = c.label; | ||||
|  | ||||
|                         if (c.containsPoint(Game1.getMousePosition().X, Game1.getMousePosition().Y)) | ||||
|                             ScreenReader.sayWithChecker($"Grab: {name} \t\n {label}", false); | ||||
|                     } | ||||
|                 }  | ||||
|                 #endregion | ||||
|             } | ||||
|             catch (Exception e) | ||||
|             { | ||||
|  | ||||
|                 MainClass.monitor.Log($"Unable to narrate Text:\n{e.Message}\n{e.StackTrace}", LogLevel.Error); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         internal static void TitleMenuPatch(TitleMenu __instance) | ||||
|         { | ||||
|   | ||||
| @@ -21,7 +21,7 @@ namespace stardew_access | ||||
|             } | ||||
|             catch (Exception ex) | ||||
|             { | ||||
|                 MainClass.monitor.Log($"Error initializing NVDA:\n{ex.StackTrace}", LogLevel.Error); | ||||
|                 MainClass.monitor.Log($"Error initializing NVDA:\n{ex.StackTrace}", LogLevel.Info); | ||||
|             } | ||||
|  | ||||
|             // Initialize JAWS | ||||
| @@ -31,7 +31,7 @@ namespace stardew_access | ||||
|             } | ||||
|             catch (Exception ex) | ||||
|             { | ||||
|                 MainClass.monitor.Log($"Error initializing JAWS:\n{ex.StackTrace}", LogLevel.Error); | ||||
|                 MainClass.monitor.Log($"Error initializing JAWS:\n{ex.StackTrace}", LogLevel.Info); | ||||
|             } | ||||
|  | ||||
|             // Initialize SAPI | ||||
| @@ -41,7 +41,7 @@ namespace stardew_access | ||||
|             } | ||||
|             catch (Exception ex) | ||||
|             { | ||||
|                 MainClass.monitor.Log($"Error initializing SAPI:\n{ex.StackTrace}", LogLevel.Error); | ||||
|                 MainClass.monitor.Log($"Error initializing SAPI:\n{ex.StackTrace}", LogLevel.Info); | ||||
|             } | ||||
|  | ||||
|             if (nvdaOutput != null && nvdaOutput.IsAvailable()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user