aboutsummaryrefslogtreecommitdiff
path: root/V3/Effects/EffectsManager.cs
diff options
context:
space:
mode:
Diffstat (limited to 'V3/Effects/EffectsManager.cs')
-rw-r--r--V3/Effects/EffectsManager.cs54
1 files changed, 54 insertions, 0 deletions
diff --git a/V3/Effects/EffectsManager.cs b/V3/Effects/EffectsManager.cs
new file mode 100644
index 0000000..a175e34
--- /dev/null
+++ b/V3/Effects/EffectsManager.cs
@@ -0,0 +1,54 @@
+using System.Collections.Generic;
+using Microsoft.Xna.Framework;
+using Microsoft.Xna.Framework.Content;
+using Microsoft.Xna.Framework.Graphics;
+using V3.Data;
+
+namespace V3.Effects
+{
+ // ReSharper disable once ClassNeverInstantiated.Global
+ public sealed class EffectsManager : IEffectsManager
+ {
+ private readonly ContentManager mContentManager;
+ private readonly IOptionsManager mOptionsManager;
+ private readonly List<IEffect> mActiveEffects = new List<IEffect>();
+
+ public EffectsManager(ContentManager contentManager, IOptionsManager optionsManager)
+ {
+ mContentManager = contentManager;
+ mOptionsManager = optionsManager;
+ }
+
+ public void Update(GameTime gameTime)
+ {
+ var doneEffects = new List<IEffect>();
+ foreach (var effect in mActiveEffects)
+ {
+ effect.Update(gameTime);
+ if (!effect.IsPlaying)
+ {
+ doneEffects.Add(effect);
+ }
+ }
+ foreach (var doneEffect in doneEffects)
+ {
+ mActiveEffects.Remove(doneEffect);
+ }
+ }
+
+ public void Draw(SpriteBatch spriteBatch)
+ {
+ foreach (var effect in mActiveEffects)
+ {
+ effect.Draw(spriteBatch);
+ }
+ }
+
+ public void PlayOnce(IEffect effect, Point position, Point size)
+ {
+ effect.LoadContent(mContentManager);
+ mActiveEffects.Add(effect);
+ effect.PlayOnce(position, size, mOptionsManager);
+ }
+ }
+} \ No newline at end of file