mirror of
https://github.com/gui-cs/Terminal.Gui.git
synced 2025-12-27 00:07:58 +01:00
* Initial plan * Remove LineView and replace all usages with Line - Deleted LineViewExample.cs scenario - Deleted LineViewTests.cs test file - Replaced LineView with Line in all examples (CollectionNavigatorTester, FileDialogExamples, LineExample, Wizard) - Replaced LineView with Line in all tests (ViewTests, TileViewTests) - Changed TileViewLineView to inherit from Line instead of LineView - Removed LineView.cs file - Removed LineView category from TileViewNesting scenario Co-authored-by: tig <585482+tig@users.noreply.github.com> * Remove LineView references from documentation - Updated Line.cs XML documentation to remove comparison with LineView - Removed LineView section from views.md documentation Co-authored-by: tig <585482+tig@users.noreply.github.com> * Fixes Wizard (#4269) * fixed Wizard * Made Line use GetAttributeForRole --------- Co-authored-by: copilot-swe-agent[bot] <198982749+Copilot@users.noreply.github.com> Co-authored-by: tig <585482+tig@users.noreply.github.com> Co-authored-by: Tig <tig@users.noreply.github.com>
220 lines
5.7 KiB
C#
220 lines
5.7 KiB
C#
namespace UICatalog.Scenarios;
|
|
|
|
[ScenarioMetadata ("Line", "Demonstrates the Line view with LineCanvas integration.")]
|
|
[ScenarioCategory ("Controls")]
|
|
[ScenarioCategory ("Drawing")]
|
|
[ScenarioCategory ("Adornments")]
|
|
public class LineExample : Scenario
|
|
{
|
|
public override void Main ()
|
|
{
|
|
Application.Init ();
|
|
|
|
var app = new Window
|
|
{
|
|
Title = GetQuitKeyAndName ()
|
|
};
|
|
|
|
// Section 1: Basic Lines
|
|
var basicLabel = new Label
|
|
{
|
|
X = 0,
|
|
Y = 0,
|
|
Text = "Basic Lines:"
|
|
};
|
|
app.Add (basicLabel);
|
|
|
|
// Horizontal line
|
|
var hLine = new Line
|
|
{
|
|
X = 0,
|
|
Y = 1,
|
|
Width = 30
|
|
};
|
|
app.Add (hLine);
|
|
|
|
// Vertical line
|
|
var vLine = new Line
|
|
{
|
|
X = 32,
|
|
Y = 0,
|
|
Height = 10,
|
|
Orientation = Orientation.Vertical
|
|
};
|
|
app.Add (vLine);
|
|
|
|
// Section 2: Different Line Styles
|
|
var stylesLabel = new Label
|
|
{
|
|
X = 0,
|
|
Y = 3,
|
|
Text = "Line Styles:"
|
|
};
|
|
app.Add (stylesLabel);
|
|
|
|
(LineStyle, string) [] styles = new []
|
|
{
|
|
(LineStyle.Single, "Single"),
|
|
(LineStyle.Double, "Double"),
|
|
(LineStyle.Heavy, "Heavy"),
|
|
(LineStyle.Rounded, "Rounded"),
|
|
(LineStyle.Dashed, "Dashed"),
|
|
(LineStyle.Dotted, "Dotted")
|
|
};
|
|
|
|
var yPos = 4;
|
|
|
|
foreach ((LineStyle style, string name) in styles)
|
|
{
|
|
app.Add (new Label { X = 0, Y = yPos, Width = 15, Text = name + ":" });
|
|
app.Add (new Line { X = 16, Y = yPos, Width = 14, Style = style });
|
|
yPos++;
|
|
}
|
|
|
|
// Section 3: Line Intersections
|
|
var intersectionLabel = new Label
|
|
{
|
|
X = 35,
|
|
Y = 3,
|
|
Text = "Line Intersections:"
|
|
};
|
|
app.Add (intersectionLabel);
|
|
|
|
// Create a grid of intersecting lines
|
|
var gridX = 35;
|
|
var gridY = 5;
|
|
|
|
// Horizontal lines in the grid
|
|
for (var i = 0; i < 5; i++)
|
|
{
|
|
app.Add (
|
|
new Line
|
|
{
|
|
X = gridX,
|
|
Y = gridY + i * 2,
|
|
Width = 21,
|
|
Style = LineStyle.Single
|
|
});
|
|
}
|
|
|
|
// Vertical lines in the grid
|
|
for (var i = 0; i < 5; i++)
|
|
{
|
|
app.Add (
|
|
new Line
|
|
{
|
|
X = gridX + i * 5,
|
|
Y = gridY,
|
|
Height = 9,
|
|
Orientation = Orientation.Vertical,
|
|
Style = LineStyle.Single
|
|
});
|
|
}
|
|
|
|
// Section 4: Mixed Styles (shows how LineCanvas handles different line styles)
|
|
var mixedLabel = new Label
|
|
{
|
|
X = 60,
|
|
Y = 3,
|
|
Text = "Mixed Style Intersections:"
|
|
};
|
|
app.Add (mixedLabel);
|
|
|
|
// Double horizontal
|
|
app.Add (
|
|
new Line
|
|
{
|
|
X = 60,
|
|
Y = 5,
|
|
Width = 20,
|
|
Style = LineStyle.Double
|
|
});
|
|
|
|
// Single vertical through double horizontal
|
|
app.Add (
|
|
new Line
|
|
{
|
|
X = 70,
|
|
Y = 4,
|
|
Height = 3,
|
|
Orientation = Orientation.Vertical,
|
|
Style = LineStyle.Single
|
|
});
|
|
|
|
// Heavy horizontal
|
|
app.Add (
|
|
new Line
|
|
{
|
|
X = 60,
|
|
Y = 8,
|
|
Width = 20,
|
|
Style = LineStyle.Heavy
|
|
});
|
|
|
|
// Single vertical through heavy horizontal
|
|
app.Add (
|
|
new Line
|
|
{
|
|
X = 70,
|
|
Y = 7,
|
|
Height = 3,
|
|
Orientation = Orientation.Vertical,
|
|
Style = LineStyle.Single
|
|
});
|
|
|
|
// Section 5: Box Example (showing borders and lines working together)
|
|
var boxLabel = new Label
|
|
{
|
|
X = 0,
|
|
Y = 12,
|
|
Text = "Lines with Borders:"
|
|
};
|
|
app.Add (boxLabel);
|
|
|
|
var framedView = new FrameView
|
|
{
|
|
Title = "Frame",
|
|
X = 0,
|
|
Y = 13,
|
|
Width = 30,
|
|
Height = 8,
|
|
BorderStyle = LineStyle.Single
|
|
};
|
|
|
|
// Add a cross inside the frame
|
|
framedView.Add (
|
|
new Line
|
|
{
|
|
X = 0,
|
|
Y = 3,
|
|
Width = Dim.Fill (),
|
|
Style = LineStyle.Single
|
|
});
|
|
|
|
framedView.Add (
|
|
new Line
|
|
{
|
|
X = 14,
|
|
Y = 0,
|
|
Height = Dim.Fill (),
|
|
Orientation = Orientation.Vertical,
|
|
Style = LineStyle.Single
|
|
});
|
|
|
|
app.Add (framedView);
|
|
|
|
// Add help text
|
|
var helpLabel = new Label
|
|
{
|
|
X = Pos.Center (),
|
|
Y = Pos.AnchorEnd (1),
|
|
Text = "Line integrates with LineCanvas for automatic intersection handling"
|
|
};
|
|
app.Add (helpLabel);
|
|
|
|
Application.Run (app);
|
|
app.Dispose ();
|
|
Application.Shutdown ();
|
|
}
|
|
}
|