From 033d27d2da7614e8f897280add43abd791e102ef Mon Sep 17 00:00:00 2001 From: Evgeny Gorbovoy Date: Fri, 5 Jan 2024 17:20:12 +0100 Subject: [PATCH] This commit introduces support for tab and newline characters in the DrawingContextImpl class. The update will handle these characters during draw operations, translating tab characters into a sequence of spaces and newline characters into a 'no-op' (no operation) at this stage. --- .../Drawing/DrawingContextImpl.cs | 41 ++++++++++++++++--- 1 file changed, 36 insertions(+), 5 deletions(-) diff --git a/src/Consolonia.Core/Drawing/DrawingContextImpl.cs b/src/Consolonia.Core/Drawing/DrawingContextImpl.cs index f5fde7e0..0ca2fb49 100644 --- a/src/Consolonia.Core/Drawing/DrawingContextImpl.cs +++ b/src/Consolonia.Core/Drawing/DrawingContextImpl.cs @@ -1,6 +1,7 @@ using System; using System.Collections.Generic; using System.Linq; +using System.Text; using Avalonia; using Avalonia.Media; using Avalonia.Platform; @@ -381,11 +382,12 @@ void DrawPixelAndMoveHead(int count) if (!Transform.IsTranslateOnly()) ConsoloniaPlatform.RaiseNotSupported(15); Point whereToDraw = origin.Transform(Transform); + int currentXPosition = 0; //todo: support surrogates for (int i = 0; i < str.Length; i++) { - Point characterPoint = whereToDraw.Transform(Matrix.CreateTranslation(i, 0)); + Point characterPoint = whereToDraw.Transform(Matrix.CreateTranslation(currentXPosition++, 0)); CurrentClip.ExecuteWithClipping(characterPoint, () => { ConsoleColor foregroundColor = consoleColorBrush.Color; @@ -411,11 +413,40 @@ void DrawPixelAndMoveHead(int count) } } - // ReSharper disable once AccessToModifiedClosure //todo: pass as a parameter - var consolePixel = new Pixel(str[i], foregroundColor); + char character = str[i]; - _pixelBuffer.Set((PixelBufferCoordinate)characterPoint, - (oldPixel, cp) => oldPixel.Blend(cp), consolePixel); + switch (character) + { + case '\t': + { + var consolePixel = new Pixel(' ', foregroundColor); + for (int j = 0; j < 8; j++) + { + _pixelBuffer.Set((PixelBufferCoordinate)characterPoint.WithX(characterPoint.X + j), + (oldPixel, cp) => oldPixel.Blend(cp), consolePixel); + currentXPosition++; + } + + currentXPosition--; + } + break; + case '\n': + { + /*var consolePixel = new Pixel(' ', foregroundColor); + + _pixelBuffer.Set((PixelBufferCoordinate)characterPoint, + (oldPixel, cp) => oldPixel.Blend(cp), consolePixel);*/ + } + break; + default: + { + var consolePixel = new Pixel(character, foregroundColor); + + _pixelBuffer.Set((PixelBufferCoordinate)characterPoint, + (oldPixel, cp) => oldPixel.Blend(cp), consolePixel); + } + break; + } }); } }