summaryrefslogtreecommitdiff
path: root/src/StardewModdingAPI/Context.cs
diff options
context:
space:
mode:
Diffstat (limited to 'src/StardewModdingAPI/Context.cs')
-rw-r--r--src/StardewModdingAPI/Context.cs12
1 files changed, 8 insertions, 4 deletions
diff --git a/src/StardewModdingAPI/Context.cs b/src/StardewModdingAPI/Context.cs
index 6bc5ae56..6c5ae40e 100644
--- a/src/StardewModdingAPI/Context.cs
+++ b/src/StardewModdingAPI/Context.cs
@@ -1,4 +1,5 @@
-using StardewValley;
+using StardewModdingAPI.Events;
+using StardewValley;
using StardewValley.Menus;
namespace StardewModdingAPI
@@ -15,6 +16,12 @@ namespace StardewModdingAPI
/// <summary>Whether the player has loaded a save and the world has finished initialising.</summary>
public static bool IsWorldReady { get; internal set; }
+ /// <summary>Whether the player is free to move around (e.g. save is loaded, no menu is displayed, no cutscene is in progress, etc).</summary>
+ public static bool IsPlayerFree => Context.IsWorldReady && Game1.activeClickableMenu == null && Game1.player.CanMove && !Game1.dialogueUp && !Game1.eventUp;
+
+ /// <summary>Whether the game is currently running the draw loop. This isn't relevant to most mods, since you should use <see cref="GraphicsEvents.OnPostRenderEvent"/> to draw to the screen.</summary>
+ public static bool IsInDrawLoop { get; internal set; }
+
/****
** Internal
****/
@@ -23,8 +30,5 @@ namespace StardewModdingAPI
/// <summary>Whether the game is currently writing to the save file.</summary>
internal static bool IsSaving => Game1.activeClickableMenu is SaveGameMenu || Game1.activeClickableMenu is ShippingMenu; // saving is performed by SaveGameMenu, but it's wrapped by ShippingMenu on days when the player shipping something
-
- /// <summary>Whether the game is currently running the draw loop.</summary>
- internal static bool IsInDrawLoop { get; set; }
}
}