diff --git a/ConsoleMediaPlayer.Common/MediaPlayer.cs b/ConsoleMediaPlayer.Common/MediaPlayer.cs index c185f30..b7c37a1 100644 --- a/ConsoleMediaPlayer.Common/MediaPlayer.cs +++ b/ConsoleMediaPlayer.Common/MediaPlayer.cs @@ -14,13 +14,13 @@ public MediaPlayer(string filePath) if (!File.Exists(filePath)) throw new Exception($"El archivo {filePath} no existe"); FilePath = filePath; + ConsoleHelper.SetCurrentFont(FontSize); } public abstract void Play(); public void ResizeConsoleScreen() { - ConsoleHelper.SetCurrentFont(FontSize); int width = Resolution.Width + MARGIN.Width; int height = Resolution.Height + MARGIN.Height; Console.SetWindowSize(width, height); diff --git a/ConsoleMediaPlayer.VideoApp/Program.cs b/ConsoleMediaPlayer.VideoApp/Program.cs index 9fe2938..3efffc4 100644 --- a/ConsoleMediaPlayer.VideoApp/Program.cs +++ b/ConsoleMediaPlayer.VideoApp/Program.cs @@ -4,6 +4,9 @@ public class Program { public static void Main(string[] args) { + Console.WriteLine(Console.LargestWindowHeight); + Console.WriteLine(Console.LargestWindowWidth); + Console.WriteLine("Introduce ruta de un vídeo:"); string filePath = Console.ReadLine().Replace("\"", ""); diff --git a/ConsoleMediaPlayer.VideoApp/VideoPlayer.cs b/ConsoleMediaPlayer.VideoApp/VideoPlayer.cs index 1eae3f5..55ea3b6 100644 --- a/ConsoleMediaPlayer.VideoApp/VideoPlayer.cs +++ b/ConsoleMediaPlayer.VideoApp/VideoPlayer.cs @@ -16,7 +16,7 @@ public class VideoPlayer : MediaPlayer { private const int DEFAULT_HEIGHT = 250; private const int FPS_LIMIT = 24; - private static string ASCII_PIXEL_TABLE = @"█▓@8#x+o=:-. "; + private const string ASCII_PIXEL_TABLE = @"█▓@8#x+o=:-. "; private ISoundOut _soundOut; @@ -48,7 +48,7 @@ private void ExtractMetadata(int height) private int CalculateBytesPerFrame(int width, int height) { int lineSizeWithoutPadding = width * 3; - int lineSizeWithPadding = (int)Math.Ceiling(lineSizeWithoutPadding / 4f) * 4; + int lineSizeWithPadding = (int)Math.Ceiling(lineSizeWithoutPadding / 4.0) * 4; return 54 + lineSizeWithPadding * height; } @@ -82,9 +82,6 @@ public override async void Play() { Thread.Sleep(TimeSpan.FromTicks(waitTicks)); } - else - { - } } SpinWait.SpinUntil(() => _soundOut.PlaybackState != PlaybackState.Playing); @@ -108,33 +105,31 @@ await FFMpegArguments public async void ExtractFramesAsync() { - using (var stream = new MemoryTributary()) + using Stream stream = new MemoryTributary(); + + await FFMpegArguments + .FromFileInput(FilePath) + .OutputToPipe(new StreamPipeSink(stream), options => options + .ForceFormat("rawvideo") + .WithFramerate(FPS) + .WithVideoCodec("bmp") + .WithCustomArgument("-ss 00:00") + .Resize(Resolution.Width, Resolution.Height) + ).ProcessAsynchronously(); + + stream.Position = 0; + byte[] buffer = new byte[BytesPerFrame]; + Frames.Clear(); + + while (stream.Position < stream.Length) { - await FFMpegArguments - .FromFileInput(FilePath) - .OutputToPipe(new StreamPipeSink(stream), options => options - .ForceFormat("rawvideo") - .WithFramerate(FPS) - .WithVideoCodec("bmp") - .WithCustomArgument("-ss 00:00") - .Resize(Resolution.Width, Resolution.Height) - ).ProcessAsynchronously(); - - stream.Position = 0; - byte[] buffer = new byte[BytesPerFrame]; - Frames.Clear(); - - while (stream.Position < stream.Length) - { - int bytesReaded = stream.Read(buffer, 0, BytesPerFrame); + int bytesReaded = stream.Read(buffer, 0, BytesPerFrame); - using (MemoryStream auxStream = new MemoryStream(buffer, 0, bytesReaded)) - { - auxStream.Position = 0; - Bitmap frame = (Bitmap)Image.FromStream(auxStream); - Frames.Add(RenderFrame(frame)); - } - } + using MemoryStream auxStream = new MemoryStream(buffer, 0, bytesReaded); + + auxStream.Position = 0; + Bitmap frame = (Bitmap)Image.FromStream(auxStream); + Frames.Add(RenderFrame(frame)); } }