From 6cb9b2bc2631679f3c5b3f8d2375c79506b5ecee Mon Sep 17 00:00:00 2001 From: lay295 Date: Thu, 20 Aug 2020 22:14:06 -0400 Subject: [PATCH] Fix invalid memory access (idk how this fixes it) --- TwitchDownloaderCore/ChatRenderer.cs | 26 +++++++++++++++++--------- TwitchDownloaderWPF/App.xaml.cs | 5 +---- 2 files changed, 18 insertions(+), 13 deletions(-) diff --git a/TwitchDownloaderCore/ChatRenderer.cs b/TwitchDownloaderCore/ChatRenderer.cs index 38fed8fa..ed625b60 100644 --- a/TwitchDownloaderCore/ChatRenderer.cs +++ b/TwitchDownloaderCore/ChatRenderer.cs @@ -9,6 +9,7 @@ using System.Globalization; using System.IO; using System.Linq; +using System.Runtime.CompilerServices; using System.Text; using System.Text.RegularExpressions; using System.Threading; @@ -395,15 +396,7 @@ private void RenderVideo(ChatRenderOptions renderOptions, Queue f ffmpegStream.Write(bytes); if (renderOptions.GenerateMask) { - SKBitmap maskBitmap = new SKBitmap(renderOptions.ChatWidth, renderOptions.ChatHeight); - using (SKCanvas maskCanvas = new SKCanvas(maskBitmap)) - { - maskCanvas.Clear(SKColors.White); - maskCanvas.DrawBitmap(bufferBitmap, 0, 0, new SKPaint() { BlendMode = SKBlendMode.DstIn }); - } - var pixMask = maskBitmap.PeekPixels(); - var dataMask = SKData.Create(pixMask.GetPixels(), pixMask.Info.BytesSize); - var bytesMask = dataMask.ToArray(); + byte[] bytesMask = GetMaskBytes(bufferBitmap, renderOptions); maskStream.Write(bytesMask); } @@ -433,6 +426,21 @@ private void RenderVideo(ChatRenderOptions renderOptions, Queue f progress.Report(new ProgressReport() { reportType = ReportType.Log, data = $"FINISHED. RENDER TIME: {(int)stopwatch.Elapsed.TotalSeconds}s SPEED: {(duration / stopwatch.Elapsed.TotalSeconds).ToString("0.##")}x" }); process.WaitForExit(); } + + private byte[] GetMaskBytes(SKBitmap bufferBitmap, ChatRenderOptions renderOptions) + { + SKBitmap maskBitmap = new SKBitmap(renderOptions.ChatWidth, renderOptions.ChatHeight); + using (SKCanvas maskCanvas = new SKCanvas(maskBitmap)) + { + maskCanvas.Clear(SKColors.White); + maskCanvas.DrawBitmap(bufferBitmap, 0, 0, new SKPaint() { BlendMode = SKBlendMode.DstIn }); + } + var pixMask = maskBitmap.PeekPixels(); + var dataMask = SKData.Create(pixMask.GetPixels(), pixMask.Info.BytesSize); + var bytesMask = dataMask.ToArray(); + return bytesMask; + } + public static SKBitmap DrawTimestamp(SKBitmap sectionImage, List imageList, SKPaint messageFont, ChatRenderOptions renderOptions, Comment comment, Size canvasSize, ref Point drawPos, ref int default_x) { SKCanvas sectionImageCanvas = new SKCanvas(sectionImage); diff --git a/TwitchDownloaderWPF/App.xaml.cs b/TwitchDownloaderWPF/App.xaml.cs index 1ad42f4b..756ec4cb 100644 --- a/TwitchDownloaderWPF/App.xaml.cs +++ b/TwitchDownloaderWPF/App.xaml.cs @@ -15,9 +15,6 @@ namespace TwitchDownloaderWPF /// public partial class App : Application { - void App_DispatcherUnhandledException(object sender, DispatcherUnhandledExceptionEventArgs e) - { - File.AppendAllText("errors.txt", e.Exception.ToString()); - } + } }