diff options
Diffstat (limited to 'Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization')
6 files changed, 176 insertions, 0 deletions
diff --git a/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/InterpolatorJsonConverter.cs b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/InterpolatorJsonConverter.cs new file mode 100644 index 0000000..21bd7fc --- /dev/null +++ b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/InterpolatorJsonConverter.cs @@ -0,0 +1,25 @@ +using System.Collections.Generic; +using System.Linq; +using System.Reflection; +using MonoGame.Extended.Particles.Modifiers.Interpolators; +using MonoGame.Extended.Serialization; + +namespace MonoGame.Extended.Particles.Serialization +{ + public class InterpolatorJsonConverter : BaseTypeJsonConverter<Interpolator> + { + public InterpolatorJsonConverter() + : base(GetSupportedTypes(), "Interpolator") + { + } + + private static IEnumerable<TypeInfo> GetSupportedTypes() + { + return typeof(Interpolator) + .GetTypeInfo() + .Assembly + .DefinedTypes + .Where(type => typeof(Interpolator).GetTypeInfo().IsAssignableFrom(type) && !type.IsAbstract); + } + } +}
\ No newline at end of file diff --git a/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ModifierExecutionStrategyJsonConverter.cs b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ModifierExecutionStrategyJsonConverter.cs new file mode 100644 index 0000000..8fc894b --- /dev/null +++ b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ModifierExecutionStrategyJsonConverter.cs @@ -0,0 +1,34 @@ +using System; +using System.Reflection; +using System.Text.Json; +using System.Text.Json.Serialization; + +namespace MonoGame.Extended.Particles.Serialization; + +/// <summary> +/// Converts a <see cref="ParticleModifierExecutionStrategy"/> value to or from JSON. +/// </summary> +public class ModifierExecutionStrategyJsonConverter : JsonConverter<ParticleModifierExecutionStrategy> +{ + /// <inheritdoc /> + public override bool CanConvert(Type typeToConvert) => + typeToConvert == typeof(ParticleModifierExecutionStrategy) || + typeToConvert.GetTypeInfo().BaseType == typeof(ParticleModifierExecutionStrategy); + + /// <inheritdoc /> + public override ParticleModifierExecutionStrategy Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) + { + var value = JsonSerializer.Deserialize<string>(ref reader, options); + return ParticleModifierExecutionStrategy.Parse(value); + } + + /// <inheritdoc /> + /// <exception cref="ArgumentNullException"> + /// Throw if <paramref name="writer"/> is <see langword="null"/>. + /// </exception> + public override void Write(Utf8JsonWriter writer, ParticleModifierExecutionStrategy value, JsonSerializerOptions options) + { + ArgumentNullException.ThrowIfNull(writer); + writer.WriteStringValue(value.ToString()); + } +} diff --git a/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ModifierJsonConverter.cs b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ModifierJsonConverter.cs new file mode 100644 index 0000000..5985e40 --- /dev/null +++ b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ModifierJsonConverter.cs @@ -0,0 +1,25 @@ +using System.Collections.Generic; +using System.Linq; +using System.Reflection; +using MonoGame.Extended.Particles.Modifiers; +using MonoGame.Extended.Serialization; + +namespace MonoGame.Extended.Particles.Serialization +{ + public class ModifierJsonConverter : BaseTypeJsonConverter<Modifier> + { + public ModifierJsonConverter() + : base(GetSupportedTypes(), "Modifier") + { + } + + private static IEnumerable<TypeInfo> GetSupportedTypes() + { + return typeof(Modifier) + .GetTypeInfo() + .Assembly + .DefinedTypes + .Where(type => typeof(Modifier).GetTypeInfo().IsAssignableFrom(type) && !type.IsAbstract); + } + } +}
\ No newline at end of file diff --git a/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ParticleJsonSerializerOptionsProvider.cs b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ParticleJsonSerializerOptionsProvider.cs new file mode 100644 index 0000000..489b3ee --- /dev/null +++ b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ParticleJsonSerializerOptionsProvider.cs @@ -0,0 +1,34 @@ +using System.Text.Json; +using System.Text.Json.Serialization; +using MonoGame.Extended.Serialization; + +namespace MonoGame.Extended.Particles.Serialization; + +public static class ParticleJsonSerializerOptionsProvider +{ + public static JsonSerializerOptions GetOptions(ITextureRegionService textureRegionService) + { + var options = new JsonSerializerOptions + { + WriteIndented = true, + DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull, + PropertyNamingPolicy = JsonNamingPolicy.CamelCase + }; + + options.Converters.Add(new Vector2JsonConverter()); + options.Converters.Add(new Size2JsonConverter()); + options.Converters.Add(new ColorJsonConverter()); + options.Converters.Add(new TextureRegion2DJsonConverter(textureRegionService)); + options.Converters.Add(new ProfileJsonConverter()); + options.Converters.Add(new ModifierJsonConverter()); + options.Converters.Add(new InterpolatorJsonConverter()); + options.Converters.Add(new TimeSpanJsonConverter()); + options.Converters.Add(new RangeJsonConverter<int>()); + options.Converters.Add(new RangeJsonConverter<float>()); + options.Converters.Add(new RangeJsonConverter<HslColor>()); + options.Converters.Add(new HslColorJsonConverter()); + options.Converters.Add(new ModifierExecutionStrategyJsonConverter()); + + return options; + } +} diff --git a/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ProfileJsonConverter.cs b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ProfileJsonConverter.cs new file mode 100644 index 0000000..8d98079 --- /dev/null +++ b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/ProfileJsonConverter.cs @@ -0,0 +1,25 @@ +using System.Collections.Generic; +using System.Linq; +using System.Reflection; +using MonoGame.Extended.Particles.Profiles; +using MonoGame.Extended.Serialization; + +namespace MonoGame.Extended.Particles.Serialization +{ + public class ProfileJsonConverter : BaseTypeJsonConverter<Profile> + { + public ProfileJsonConverter() + : base(GetSupportedTypes(), nameof(Profile)) + { + } + + private static IEnumerable<TypeInfo> GetSupportedTypes() + { + return typeof(Profile) + .GetTypeInfo() + .Assembly + .DefinedTypes + .Where(type => type.IsSubclassOf(typeof(Profile)) && !type.IsAbstract); + } + } +}
\ No newline at end of file diff --git a/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/TimeSpanJsonConverter.cs b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/TimeSpanJsonConverter.cs new file mode 100644 index 0000000..0155b08 --- /dev/null +++ b/Plugins/MonoGame.Extended/source/MonoGame.Extended.Particles/Serialization/TimeSpanJsonConverter.cs @@ -0,0 +1,33 @@ +using System; +using System.Text.Json; +using System.Text.Json.Serialization; + +namespace MonoGame.Extended.Particles.Serialization; + +public class TimeSpanJsonConverter : JsonConverter<TimeSpan> +{ + /// <inheritdoc /> + public override bool CanConvert(Type typeToConvert) => typeToConvert == typeof(TimeSpan); + + /// <inheritdoc /> + public override TimeSpan Read(ref Utf8JsonReader reader, Type typeToConvert, JsonSerializerOptions options) + { + if (reader.TokenType == JsonTokenType.Number) + { + double seconds = reader.GetDouble(); + return TimeSpan.FromSeconds(seconds); + } + + return TimeSpan.Zero; + } + + /// <inheritdoc /> + /// <exception cref="ArgumentNullException"> + /// Throw if <paramref name="writer"/> is <see langword="null"/>. + /// </exception> + public override void Write(Utf8JsonWriter writer, TimeSpan value, JsonSerializerOptions options) + { + ArgumentNullException.ThrowIfNull(writer); + writer.WriteNumberValue(value.TotalSeconds); + } +} |