summaryrefslogtreecommitdiff
path: root/src/SMAPI/Framework
diff options
context:
space:
mode:
authorJesse Plamondon-Willard <Pathoschild@users.noreply.github.com>2022-05-28 15:07:19 -0400
committerJesse Plamondon-Willard <Pathoschild@users.noreply.github.com>2022-06-10 00:04:24 -0400
commit4f6965eef3c7690dcfc1e1946362a84f68f40767 (patch)
tree8d00d4c7bc88a5164caa74c6536b6e098fada90f /src/SMAPI/Framework
parent2134cef74fc7549387defc639789ebc0bcb5b5db (diff)
downloadSMAPI-4f6965eef3c7690dcfc1e1946362a84f68f40767.tar.gz
SMAPI-4f6965eef3c7690dcfc1e1946362a84f68f40767.tar.bz2
SMAPI-4f6965eef3c7690dcfc1e1946362a84f68f40767.zip
encapsulate loading the raw image data for mod patching
Diffstat (limited to 'src/SMAPI/Framework')
-rw-r--r--src/SMAPI/Framework/ContentManagers/ModContentManager.cs53
1 files changed, 36 insertions, 17 deletions
diff --git a/src/SMAPI/Framework/ContentManagers/ModContentManager.cs b/src/SMAPI/Framework/ContentManagers/ModContentManager.cs
index 44c9d8e4..fb031ccb 100644
--- a/src/SMAPI/Framework/ContentManagers/ModContentManager.cs
+++ b/src/SMAPI/Framework/ContentManagers/ModContentManager.cs
@@ -1,5 +1,6 @@
using System;
using System.Collections.Generic;
+using System.Diagnostics.CodeAnalysis;
using System.Globalization;
using System.IO;
using System.Linq;
@@ -201,27 +202,13 @@ namespace StardewModdingAPI.Framework.ContentManagers
// load
if (asRawData || this.UseRawImageLoading)
{
- // load raw data
- using FileStream stream = File.OpenRead(file.FullName);
- using SKBitmap bitmap = SKBitmap.Decode(stream);
- SKPMColor[] rawPixels = SKPMColor.PreMultiply(bitmap.Pixels);
-
- // convert to XNA pixel format
- Color[] pixels = new Color[rawPixels.Length];
- for (int i = pixels.Length - 1; i >= 0; i--)
- {
- SKPMColor pixel = rawPixels[i];
- pixels[i] = pixel.Alpha == 0
- ? Color.Transparent
- : new Color(r: pixel.Red, g: pixel.Green, b: pixel.Blue, alpha: pixel.Alpha);
- }
+ this.LoadRawImageData(file, out int width, out int height, out Color[] pixels, asRawData);
- // create texture
if (asRawData)
- return (T)(object)new RawTextureData(bitmap.Width, bitmap.Height, pixels);
+ return (T)(object)new RawTextureData(width, height, pixels);
else
{
- Texture2D texture = new(Game1.graphics.GraphicsDevice, bitmap.Width, bitmap.Height);
+ Texture2D texture = new(Game1.graphics.GraphicsDevice, width, height);
texture.SetData(pixels);
return (T)(object)texture;
}
@@ -235,6 +222,38 @@ namespace StardewModdingAPI.Framework.ContentManagers
}
}
+ /// <summary>Load the raw image data from a file on disk.</summary>
+ /// <param name="file">The file whose data to load.</param>
+ /// <param name="width">The pixel width for the loaded image data.</param>
+ /// <param name="height">The pixel height for the loaded image data.</param>
+ /// <param name="pixels">The premultiplied pixel data.</param>
+ /// <param name="forRawData">Whether the data is being loaded for an <see cref="IRawTextureData"/> (true) or <see cref="Texture2D"/> (false) instance.</param>
+ /// <remarks>This is separate to let framework mods intercept the data before it's loaded, if needed.</remarks>
+ [SuppressMessage("ReSharper", "UnusedParameter.Local", Justification = "The 'forRawData' parameter is only added for mods which may intercept this method.")]
+ [SuppressMessage("Style", "IDE0060:Remove unused parameter", Justification = "The 'forRawData' parameter is only added for mods which may intercept this method.")]
+ private void LoadRawImageData(FileInfo file, out int width, out int height, out Color[] pixels, bool forRawData)
+ {
+ // load raw data
+ SKPMColor[] rawPixels;
+ {
+ using FileStream stream = File.OpenRead(file.FullName);
+ using SKBitmap bitmap = SKBitmap.Decode(stream);
+ rawPixels = SKPMColor.PreMultiply(bitmap.Pixels);
+ width = bitmap.Width;
+ height = bitmap.Height;
+ }
+
+ // convert to XNA pixel format
+ pixels = new Color[rawPixels.Length];
+ for (int i = pixels.Length - 1; i >= 0; i--)
+ {
+ SKPMColor pixel = rawPixels[i];
+ pixels[i] = pixel.Alpha == 0
+ ? Color.Transparent
+ : new Color(r: pixel.Red, g: pixel.Green, b: pixel.Blue, alpha: pixel.Alpha);
+ }
+ }
+
/// <summary>Load an unpacked image file (<c>.tbin</c> or <c>.tmx</c>).</summary>
/// <typeparam name="T">The type of asset to load.</typeparam>
/// <param name="assetName">The asset name relative to the loader root directory.</param>