From fc8a05358a92cc3c77c5f1e30d536807ef0614fd Mon Sep 17 00:00:00 2001 From: Victoria Plitt Date: Mon, 8 Apr 2019 13:49:55 +0300 Subject: were added scripting projects --- .../Tango.Scripting.Editors/Rendering/TextLayer.cs | 70 ++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Rendering/TextLayer.cs (limited to 'Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Rendering/TextLayer.cs') diff --git a/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Rendering/TextLayer.cs b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Rendering/TextLayer.cs new file mode 100644 index 000000000..3f4b8299b --- /dev/null +++ b/Software/Visual_Studio/Scripting/Tango.Scripting.Editors/Rendering/TextLayer.cs @@ -0,0 +1,70 @@ +// Copyright (c) AlphaSierraPapa for the SharpDevelop Team (for details please see \doc\copyright.txt) +// This code is distributed under the GNU LGPL (for details please see \doc\license.txt) + +using System; +using System.Collections.Generic; +using System.Windows; +using System.Windows.Input; +using System.Windows.Media; + +namespace Tango.Scripting.Editors.Rendering +{ + /// + /// The control that contains the text. + /// + /// This control is used to allow other UIElements to be placed inside the TextView but + /// behind the text. + /// The text rendering process (VisualLine creation) is controlled by the TextView, this + /// class simply displays the created Visual Lines. + /// + /// + /// This class does not contain any input handling and is invisible to hit testing. Input + /// is handled by the TextView. + /// This allows UIElements that are displayed behind the text, but still can react to mouse input. + /// + sealed class TextLayer : Layer + { + /// + /// the index of the text layer in the layers collection + /// + internal int index; + + public TextLayer(TextView textView) : base(textView, KnownLayer.Text) + { + } + + List visuals = new List(); + + internal void SetVisualLines(ICollection visualLines) + { + foreach (VisualLineDrawingVisual v in visuals) { + if (v.VisualLine.IsDisposed) + RemoveVisualChild(v); + } + visuals.Clear(); + foreach (VisualLine newLine in visualLines) { + VisualLineDrawingVisual v = newLine.Render(); + if (!v.IsAdded) { + AddVisualChild(v); + v.IsAdded = true; + } + visuals.Add(v); + } + InvalidateArrange(); + } + + protected override int VisualChildrenCount { + get { return visuals.Count; } + } + + protected override Visual GetVisualChild(int index) + { + return visuals[index]; + } + + protected override void ArrangeCore(Rect finalRect) + { + textView.ArrangeTextLayer(visuals); + } + } +} -- cgit v1.3.1