2016-03-04 22:05:36 +08:00
|
|
|
|
using System;
|
|
|
|
|
|
|
|
|
|
namespace StardewModdingAPI.Events
|
|
|
|
|
{
|
2016-03-27 16:30:17 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
///
|
|
|
|
|
/// </summary>
|
2016-03-04 22:05:36 +08:00
|
|
|
|
public static class GraphicsEvents
|
|
|
|
|
{
|
2016-03-27 16:30:17 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs when the form (game) is resized.
|
|
|
|
|
/// </summary>
|
2016-03-04 22:05:36 +08:00
|
|
|
|
public static event EventHandler Resize = delegate { };
|
2016-03-27 16:30:17 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs before anything is drawn.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static event EventHandler OnPreRenderEvent = delegate { };
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs before the GUI is drawn.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static event EventHandler OnPreRenderGuiEvent = delegate { };
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs after the GUI is drawn.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static event EventHandler OnPostRenderGuiEvent = delegate { };
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs before the HUD is drawn.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static event EventHandler OnPreRenderHudEvent = delegate { };
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs after the HUD is drawn.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static event EventHandler OnPostRenderHudEvent = delegate { };
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Occurs after everything is drawn.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static event EventHandler OnPostRenderEvent = delegate { };
|
2016-03-04 22:05:36 +08:00
|
|
|
|
|
2016-03-27 13:32:15 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
/// Draws when SGame.Debug is true. F3 toggles this.
|
|
|
|
|
/// Game1.spriteBatch.Begin() is pre-called.
|
|
|
|
|
/// Do not make end or begin calls to the spritebatch.
|
|
|
|
|
/// If you are only trying to add debug information, use SGame.DebugMessageQueue in your Update loop.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public static event EventHandler DrawDebug = delegate { };
|
|
|
|
|
|
2016-03-27 16:30:17 +08:00
|
|
|
|
internal static void InvokeDrawDebug(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
DrawDebug.Invoke(sender, e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal static void InvokeOnPreRenderEvent(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
OnPreRenderEvent.Invoke(sender, e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal static void InvokeOnPreRenderGuiEvent(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
OnPreRenderGuiEvent.Invoke(sender, e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal static void InvokeOnPostRenderGuiEvent(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
OnPostRenderGuiEvent.Invoke(sender, e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal static void InvokeOnPreRenderHudEvent(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
OnPreRenderHudEvent.Invoke(sender, e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal static void InvokeOnPostRenderHudEvent(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
OnPostRenderHudEvent.Invoke(sender, e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
internal static void InvokeOnPostRenderEvent(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
OnPostRenderEvent.Invoke(sender, e);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#region To Remove
|
|
|
|
|
|
|
|
|
|
[Obsolete("Use the other Pre/Post render events instead.")]
|
|
|
|
|
public static event EventHandler DrawTick = delegate { };
|
|
|
|
|
|
|
|
|
|
[Obsolete("Use the other Pre/Post render events instead. All of them will automatically be drawn into the render target if needed.")]
|
|
|
|
|
public static event EventHandler DrawInRenderTargetTick = delegate { };
|
|
|
|
|
|
|
|
|
|
[Obsolete("Should not be used.")]
|
2016-03-04 22:05:36 +08:00
|
|
|
|
public static void InvokeDrawTick()
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
DrawTick.Invoke(null, EventArgs.Empty);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
2016-03-27 13:09:09 +08:00
|
|
|
|
Log.AsyncR("An exception occured in a Mod's DrawTick: " + ex);
|
2016-03-04 22:05:36 +08:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2016-03-27 16:30:17 +08:00
|
|
|
|
[Obsolete("Should not be used.")]
|
2016-03-27 09:50:47 +08:00
|
|
|
|
public static void InvokeDrawInRenderTargetTick()
|
|
|
|
|
{
|
|
|
|
|
DrawInRenderTargetTick.Invoke(null, EventArgs.Empty);
|
|
|
|
|
}
|
|
|
|
|
|
2016-03-27 16:30:17 +08:00
|
|
|
|
[Obsolete("Should not be used.")]
|
2016-03-04 22:05:36 +08:00
|
|
|
|
public static void InvokeResize(object sender, EventArgs e)
|
|
|
|
|
{
|
|
|
|
|
Resize.Invoke(sender, e);
|
|
|
|
|
}
|
2016-03-27 13:32:15 +08:00
|
|
|
|
|
2016-03-27 16:30:17 +08:00
|
|
|
|
#endregion
|
2016-03-04 22:05:36 +08:00
|
|
|
|
}
|
2016-03-27 13:09:09 +08:00
|
|
|
|
}
|