| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160 |
- using System;
- using System.Collections.Generic;
- using Avalonia.Controls;
- using Avalonia.Interactivity;
- using Avalonia.Layout;
- using Avalonia.Media;
- namespace ControlCatalog.Pages
- {
- public partial class ContentDemoPage : ContentPage
- {
- private static readonly (string Group, string Title, string Description, Func<UserControl> Factory)[] Demos =
- {
- // Overview
- ("Overview", "First Look", "Basic ContentPage with header, content, and background inside a NavigationPage.", () => new ContentPageFirstLookPage()),
- // Appearance
- ("Appearance", "Customization", "Adjust content alignment, background color, and padding to understand how ContentPage adapts its layout.", () => new ContentPageCustomizationPage()),
- // Features
- ("Features", "CommandBar", "Attach a CommandBar to the top or bottom of a ContentPage. Add and remove items at runtime.", () => new ContentPageCommandBarPage()),
- ("Features", "Safe Area", "Understand how AutomaticallyApplySafeAreaPadding absorbs platform insets.", () => new ContentPageSafeAreaPage()),
- ("Features", "Events", "Observe page lifecycle events: NavigatedTo, NavigatedFrom, and Navigating.", () => new ContentPageEventsPage()),
- // Performance
- ("Performance", "Performance Monitor", "Push ContentPages of varying weight (50 KB to 2 MB) and observe live instance count and managed heap. Pop pages and force GC to confirm memory is released.", () => new ContentPagePerformancePage()),
- };
- public ContentDemoPage()
- {
- InitializeComponent();
- Loaded += OnLoaded;
- }
- private async void OnLoaded(object? sender, RoutedEventArgs e)
- {
- await SampleNav.PushAsync(CreateHomePage(), null);
- }
- private ContentPage CreateHomePage()
- {
- var stack = new StackPanel
- {
- Margin = new Avalonia.Thickness(12),
- Spacing = 16
- };
- var groups = new Dictionary<string, WrapPanel>();
- var groupOrder = new List<string>();
- foreach (var (group, title, description, factory) in Demos)
- {
- if (!groups.ContainsKey(group))
- {
- groups[group] = new WrapPanel
- {
- Orientation = Orientation.Horizontal,
- HorizontalAlignment = HorizontalAlignment.Left
- };
- groupOrder.Add(group);
- }
- var demoFactory = factory;
- var demoTitle = title;
- var card = new Button
- {
- Width = 170,
- MinHeight = 80,
- Margin = new Avalonia.Thickness(0, 0, 8, 8),
- VerticalAlignment = VerticalAlignment.Top,
- HorizontalContentAlignment = HorizontalAlignment.Left,
- VerticalContentAlignment = VerticalAlignment.Top,
- Padding = new Avalonia.Thickness(12, 8),
- Content = new StackPanel
- {
- Spacing = 4,
- Children =
- {
- new TextBlock
- {
- Text = title,
- FontSize = 13,
- FontWeight = FontWeight.SemiBold,
- TextWrapping = TextWrapping.Wrap
- },
- new TextBlock
- {
- Text = description,
- FontSize = 11,
- Opacity = 0.6,
- TextWrapping = TextWrapping.Wrap
- }
- }
- }
- };
- card.Click += async (s, e) =>
- {
- var headerGrid = new Grid { ColumnDefinitions = new ColumnDefinitions("*, Auto") };
- headerGrid.Children.Add(new TextBlock
- {
- Text = demoTitle,
- VerticalAlignment = VerticalAlignment.Center
- });
- var closeBtn = new Button
- {
- Content = new PathIcon
- {
- Data = Geometry.Parse("M4.397 4.397a1 1 0 0 1 1.414 0L12 10.585l6.19-6.188a1 1 0 0 1 1.414 1.414L13.413 12l6.19 6.189a1 1 0 0 1-1.414 1.414L12 13.413l-6.189 6.19a1 1 0 0 1-1.414-1.414L10.585 12 4.397 5.811a1 1 0 0 1 0-1.414z")
- },
- Background = Brushes.Transparent,
- BorderThickness = new Avalonia.Thickness(0),
- Padding = new Avalonia.Thickness(8, 4),
- VerticalAlignment = VerticalAlignment.Center
- };
- Grid.SetColumn(closeBtn, 1);
- headerGrid.Children.Add(closeBtn);
- closeBtn.Click += async (_, _) => await SampleNav.PopAsync(null);
- var page = new ContentPage
- {
- Header = headerGrid,
- Content = demoFactory(),
- HorizontalContentAlignment = HorizontalAlignment.Stretch,
- VerticalContentAlignment = VerticalAlignment.Stretch
- };
- NavigationPage.SetHasBackButton(page, false);
- await SampleNav.PushAsync(page, null);
- };
- groups[group].Children.Add(card);
- }
- foreach (var groupName in groupOrder)
- {
- stack.Children.Add(new TextBlock
- {
- Text = groupName,
- FontSize = 13,
- FontWeight = FontWeight.SemiBold,
- Margin = new Avalonia.Thickness(0, 0, 0, 4),
- Opacity = 0.6
- });
- stack.Children.Add(groups[groupName]);
- }
- var homePage = new ContentPage
- {
- Content = new ScrollViewer { Content = stack },
- HorizontalContentAlignment = HorizontalAlignment.Stretch,
- VerticalContentAlignment = VerticalAlignment.Stretch
- };
- NavigationPage.SetHasNavigationBar(homePage, false);
- return homePage;
- }
- }
- }
|