From abfd774638d509a0d5fe5a61fe69b890fa3e0fc6 Mon Sep 17 00:00:00 2001 From: Michael Date: Sun, 29 Jan 2017 11:59:18 -0500 Subject: [PATCH] Scripting changes and background music! --- ShiftOS.WinForms/AudioManager.cs | 17 ++++++ ShiftOS.WinForms/Program.cs | 1 + ShiftOS.WinForms/ShiftOS.WinForms.csproj | 6 ++ ShiftOS.WinForms/ShiftOSAudioProvider.cs | 47 +++++++++++++++ ShiftOS.WinForms/packages.config | 1 + ShiftOS_TheReturn/AudioManager.cs | 76 ++++++++++++++++++++++++ ShiftOS_TheReturn/Scripting.cs | 31 ++++++++++ ShiftOS_TheReturn/ShiftOS.Engine.csproj | 5 ++ ShiftOS_TheReturn/packages.config | 1 + 9 files changed, 185 insertions(+) create mode 100644 ShiftOS.WinForms/AudioManager.cs create mode 100644 ShiftOS.WinForms/ShiftOSAudioProvider.cs create mode 100644 ShiftOS_TheReturn/AudioManager.cs diff --git a/ShiftOS.WinForms/AudioManager.cs b/ShiftOS.WinForms/AudioManager.cs new file mode 100644 index 0000000..530a700 --- /dev/null +++ b/ShiftOS.WinForms/AudioManager.cs @@ -0,0 +1,17 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; + +namespace ShiftOS.WinForms +{ + public static class AudioManager + { + + public static void Test() + { + + } + } +} diff --git a/ShiftOS.WinForms/Program.cs b/ShiftOS.WinForms/Program.cs index ea6445c..30a29e2 100644 --- a/ShiftOS.WinForms/Program.cs +++ b/ShiftOS.WinForms/Program.cs @@ -47,6 +47,7 @@ namespace ShiftOS.WinForms Application.EnableVisualStyles(); Application.SetCompatibleTextRenderingDefault(false); //if ANYONE puts code before those two winforms config lines they will be declared a drunky. - Michael + ShiftOS.Engine.AudioManager.Init(new ShiftOSAudioProvider()); Localization.RegisterProvider(new WFLanguageProvider()); Shiftorium.RegisterProvider(new WinformsShiftoriumProvider()); AppearanceManager.OnExit += () => diff --git a/ShiftOS.WinForms/ShiftOS.WinForms.csproj b/ShiftOS.WinForms/ShiftOS.WinForms.csproj index 739719b..3cc3b4f 100644 --- a/ShiftOS.WinForms/ShiftOS.WinForms.csproj +++ b/ShiftOS.WinForms/ShiftOS.WinForms.csproj @@ -47,6 +47,10 @@ ..\packages\Newtonsoft.Json.9.0.1\lib\net45\Newtonsoft.Json.dll + + ..\packages\Vlc.DotNet.Core.Interops.2.1.130\lib\net45\x86\Vlc.DotNet.Core.Interops.dll + True + @@ -169,6 +173,7 @@ Terminal.cs + UserControl @@ -198,6 +203,7 @@ Oobe.cs + diff --git a/ShiftOS.WinForms/ShiftOSAudioProvider.cs b/ShiftOS.WinForms/ShiftOSAudioProvider.cs new file mode 100644 index 0000000..f217325 --- /dev/null +++ b/ShiftOS.WinForms/ShiftOSAudioProvider.cs @@ -0,0 +1,47 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using Newtonsoft.Json; +using ShiftOS.Engine; + +namespace ShiftOS.WinForms +{ + class ShiftOSAudioProvider : IAudioProvider + { + public int Count + { + get + { + var wc = new System.Net.WebClient(); + return JsonConvert.DeserializeObject>(wc.DownloadString("http://getshiftos.ml/api.php?q=soundtrack")).Count; + } + } + + private float _vol = 1.0f; + + public float Volume + { + get + { + return _vol; + } + + set + { + _vol = value; + } + } + + public byte[] GetTrack(int index) + { + var wc = new System.Net.WebClient(); + var st = JsonConvert.DeserializeObject>(wc.DownloadString("http://getshiftos.ml/api.php?q=soundtrack")); + + return wc.DownloadData(st[index]); + } + } + + +} diff --git a/ShiftOS.WinForms/packages.config b/ShiftOS.WinForms/packages.config index 9d64bf3..51393a5 100644 --- a/ShiftOS.WinForms/packages.config +++ b/ShiftOS.WinForms/packages.config @@ -1,4 +1,5 @@  + \ No newline at end of file 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