From abfd774638d509a0d5fe5a61fe69b890fa3e0fc6 Mon Sep 17 00:00:00 2001 From: Michael Date: Sun, 29 Jan 2017 11:59:18 -0500 Subject: Scripting changes and background music! --- ShiftOS_TheReturn/AudioManager.cs | 76 +++++++++++++++++++++++++++++++++ ShiftOS_TheReturn/Scripting.cs | 31 ++++++++++++++ ShiftOS_TheReturn/ShiftOS.Engine.csproj | 5 +++ ShiftOS_TheReturn/packages.config | 1 + 4 files changed, 113 insertions(+) create mode 100644 ShiftOS_TheReturn/AudioManager.cs (limited to 'ShiftOS_TheReturn') diff --git a/ShiftOS_TheReturn/AudioManager.cs b/ShiftOS_TheReturn/AudioManager.cs new file mode 100644 index 0000000..d133f07 --- /dev/null +++ b/ShiftOS_TheReturn/AudioManager.cs @@ -0,0 +1,76 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading; +using System.Threading.Tasks; +using NAudio; +using NAudio.Wave; + +namespace ShiftOS.Engine +{ + public static class AudioManager + { + private static WaveOut _out = null; + private static AudioFileReader _reader = null; + private static IAudioProvider _provider = null; + private static bool _running = true; + + public static void Init(IAudioProvider _p) + { + _provider = _p; + AppearanceManager.OnExit += () => + { + _running = false; + _out?.Stop(); + _reader?.Dispose(); + _out?.Dispose(); + System.IO.File.Delete("temp.mp3"); + }; + var t = new Thread(() => + { + Random rnd = new Random(); + while(_running == true) + { + int track = rnd.Next(0, _provider.Count); + byte[] mp3 = _provider.GetTrack(track); + System.IO.File.WriteAllBytes("temp.mp3", mp3); + _reader = new AudioFileReader("temp.mp3"); + _out = new WaveOut(); + _out.Init(_reader); + _out.Volume = _provider.Volume; + + _out.Play(); + while(_out.PlaybackState == PlaybackState.Playing) + { + Thread.Sleep(5000); //even when the player isn't playing, this will give a good delay between songs. + } + } + }); + t.IsBackground = true; + t.Start(); + } + + + } + + public interface IAudioProvider + { + /// + /// Gets a byte[] array corresponding to an MP3 track given an index. + /// + /// A track index to use when finding the right track. + /// The MP3 byte[] array. + byte[] GetTrack(int index); + + /// + /// Gets the 1-based count of all available tracks. + /// + int Count { get; } + + /// + /// Gets or sets the track player's volume. + /// + float Volume { get; set; } + } +} diff --git a/ShiftOS_TheReturn/Scripting.cs b/ShiftOS_TheReturn/Scripting.cs index bea2568..4d5c1a7 100644 --- a/ShiftOS_TheReturn/Scripting.cs +++ b/ShiftOS_TheReturn/Scripting.cs @@ -148,6 +148,37 @@ namespace ShiftOS.Engine.Scripting } } + [Exposed("console")] + public class ConsoleFunctions + { + public void write(dynamic text) + { + Console.Write(text.ToString()); + } + + public void writeLine(dynamic text) + { + Console.WriteLine(text.ToString()); + } + } + + [Exposed("sos")] + public class SystemFunctions + { + public int getCodepoints() { return SaveSystem.CurrentSave.Codepoints; } + + + public bool runCommand(string cmd) + { + var args = TerminalBackend.GetArgs(ref cmd); + + return TerminalBackend.RunClient(cmd, args); + } + + + } + + public class ExposedAttribute : Attribute { /// diff --git a/ShiftOS_TheReturn/ShiftOS.Engine.csproj b/ShiftOS_TheReturn/ShiftOS.Engine.csproj index ce22f3c..1ae2855 100644 --- a/ShiftOS_TheReturn/ShiftOS.Engine.csproj +++ b/ShiftOS_TheReturn/ShiftOS.Engine.csproj @@ -61,6 +61,10 @@ ..\Libraries\Discoursistency.Util.dll + + ..\packages\NAudio.1.8.0\lib\net35\NAudio.dll + True + ..\Libraries\NetSockets.dll @@ -115,6 +119,7 @@ + diff --git a/ShiftOS_TheReturn/packages.config b/ShiftOS_TheReturn/packages.config index ace2c07..2827246 100644 --- a/ShiftOS_TheReturn/packages.config +++ b/ShiftOS_TheReturn/packages.config @@ -3,5 +3,6 @@ + \ No newline at end of file -- cgit v1.2.3