DrawerPagePerformancePage.xaml 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <UserControl xmlns="https://github.com/avaloniaui"
  2. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  3. x:Class="ControlCatalog.Pages.DrawerPagePerformancePage">
  4. <Grid ColumnDefinitions="*,300">
  5. <DockPanel Grid.Column="0" Margin="16">
  6. <DockPanel DockPanel.Dock="Bottom" Margin="0,12,0,0" Height="140">
  7. <DockPanel DockPanel.Dock="Top" Margin="0,0,0,4">
  8. <TextBlock Text="Operation Log" FontSize="13" FontWeight="SemiBold"
  9. VerticalAlignment="Center" />
  10. <Button x:Name="ClearLogButton" Content="Clear" FontSize="11"
  11. Padding="8,2" HorizontalAlignment="Right" Click="OnClearLog" />
  12. </DockPanel>
  13. <Border BorderBrush="{DynamicResource SystemControlForegroundBaseMediumLowBrush}"
  14. BorderThickness="1" CornerRadius="4" ClipToBounds="True">
  15. <ScrollViewer x:Name="LogScrollViewer">
  16. <StackPanel x:Name="LogPanel" Spacing="0" />
  17. </ScrollViewer>
  18. </Border>
  19. </DockPanel>
  20. <Border BorderBrush="{DynamicResource SystemControlForegroundBaseMediumLowBrush}"
  21. BorderThickness="1" CornerRadius="8" ClipToBounds="True">
  22. <DrawerPage x:Name="DrawerPageControl">
  23. <DrawerPage.DrawerHeader>
  24. <Border Background="{DynamicResource SystemControlHighlightAccentBrush}" Padding="16">
  25. <StackPanel Spacing="4">
  26. <TextBlock Text="Menu" FontSize="20" FontWeight="Bold" Foreground="White" />
  27. <TextBlock Text="Select a page to swap detail" FontSize="12" Foreground="White" Opacity="0.7" />
  28. </StackPanel>
  29. </Border>
  30. </DrawerPage.DrawerHeader>
  31. <DrawerPage.Drawer>
  32. <StackPanel Margin="8" Spacing="4">
  33. <Button HorizontalAlignment="Stretch" Background="Transparent"
  34. Click="OnMenuItemClick" Tag="Home">
  35. <StackPanel Orientation="Horizontal" Spacing="8">
  36. <PathIcon Width="16" Height="16" Data="M10,20V14H14V20H19V12H22L12,3L2,12H5V20H10Z" />
  37. <TextBlock Text="Home" VerticalAlignment="Center" />
  38. </StackPanel>
  39. </Button>
  40. <Button HorizontalAlignment="Stretch" Background="Transparent"
  41. Click="OnMenuItemClick" Tag="Profile">
  42. <StackPanel Orientation="Horizontal" Spacing="8">
  43. <PathIcon Width="16" Height="16" Data="M12,4A4,4 0 0,1 16,8A4,4 0 0,1 12,12A4,4 0 0,1 8,8A4,4 0 0,1 12,4M12,14C16.42,14 20,15.79 20,18V20H4V18C4,15.79 7.58,14 12,14Z" />
  44. <TextBlock Text="Profile" VerticalAlignment="Center" />
  45. </StackPanel>
  46. </Button>
  47. <Button HorizontalAlignment="Stretch" Background="Transparent"
  48. Click="OnMenuItemClick" Tag="Messages">
  49. <StackPanel Orientation="Horizontal" Spacing="8">
  50. <PathIcon Width="16" Height="16" Data="M20,8L12,13L4,8V6L12,11L20,6M20,4H4C2.89,4 2,4.89 2,6V18A2,2 0 0,0 4,20H20A2,2 0 0,0 22,18V6C22,4.89 21.1,4 20,4Z" />
  51. <TextBlock Text="Messages" VerticalAlignment="Center" />
  52. </StackPanel>
  53. </Button>
  54. <Button HorizontalAlignment="Stretch" Background="Transparent"
  55. Click="OnMenuItemClick" Tag="Settings">
  56. <StackPanel Orientation="Horizontal" Spacing="8">
  57. <PathIcon Width="16" Height="16" Data="M12,15.5A3.5,3.5 0 0,1 8.5,12A3.5,3.5 0 0,1 12,8.5A3.5,3.5 0 0,1 15.5,12A3.5,3.5 0 0,1 12,15.5M19.43,12.97C19.47,12.65 19.5,12.33 19.5,12C19.5,11.67 19.47,11.34 19.43,11L21.54,9.37C21.73,9.22 21.78,8.95 21.66,8.73L19.66,5.27C19.54,5.05 19.27,4.96 19.05,5.05L16.56,6.05C16.04,5.66 15.5,5.32 14.87,5.07L14.5,2.42C14.46,2.18 14.25,2 14,2H10C9.75,2 9.54,2.18 9.5,2.42L9.13,5.07C8.5,5.32 7.96,5.66 7.44,6.05L4.95,5.05C4.73,4.96 4.46,5.05 4.34,5.27L2.34,8.73C2.21,8.95 2.27,9.22 2.46,9.37L4.57,11C4.53,11.34 4.5,11.67 4.5,12C4.5,12.33 4.53,12.65 4.57,12.97L2.46,14.63C2.27,14.78 2.21,15.05 2.34,15.27L4.34,18.73C4.46,18.95 4.73,19.04 4.95,18.95L7.44,17.94C7.96,18.34 8.5,18.68 9.13,18.93L9.5,21.58C9.54,21.82 9.75,22 10,22H14C14.25,22 14.46,21.82 14.5,21.58L14.87,18.93C15.5,18.68 16.04,18.34 16.56,17.94L19.05,18.95C19.27,19.04 19.54,18.95 19.66,18.73L21.66,15.27C21.78,15.05 21.73,14.78 21.54,14.63L19.43,12.97Z" />
  58. <TextBlock Text="Settings" VerticalAlignment="Center" />
  59. </StackPanel>
  60. </Button>
  61. </StackPanel>
  62. </DrawerPage.Drawer>
  63. <DrawerPage.Content>
  64. <ContentPage x:Name="DetailPage" Header="Home">
  65. <StackPanel Margin="16" Spacing="8"
  66. HorizontalAlignment="Center" VerticalAlignment="Center">
  67. <TextBlock x:Name="DetailTitleText" Text="Home" FontSize="28" FontWeight="Bold"
  68. HorizontalAlignment="Center" />
  69. <TextBlock x:Name="DetailDescriptionText"
  70. Text="Select a menu item from the drawer to swap the detail page."
  71. FontSize="14" Opacity="0.6" TextWrapping="Wrap" MaxWidth="400"
  72. HorizontalAlignment="Center" />
  73. </StackPanel>
  74. </ContentPage>
  75. </DrawerPage.Content>
  76. <DrawerPage.DrawerFooter>
  77. <Border Padding="16">
  78. <StackPanel Spacing="2">
  79. <TextBlock Text="Avalonia" FontSize="12" FontWeight="SemiBold" Opacity="0.6" />
  80. <TextBlock Text="v1.0.0" FontSize="11" Opacity="0.4" />
  81. </StackPanel>
  82. </Border>
  83. </DrawerPage.DrawerFooter>
  84. </DrawerPage>
  85. </Border>
  86. </DockPanel>
  87. <Border Grid.Column="1"
  88. BorderBrush="{DynamicResource SystemControlForegroundBaseMediumLowBrush}"
  89. BorderThickness="1,0,0,0"
  90. Padding="16">
  91. <ScrollViewer>
  92. <StackPanel Spacing="12">
  93. <TextBlock Text="Metrics" FontSize="16" FontWeight="SemiBold"
  94. Foreground="{DynamicResource SystemControlHighlightAccentBrush}" />
  95. <TextBlock x:Name="CurrentDetailText" Text="Current Detail: Home" FontSize="13" />
  96. <TextBlock x:Name="SwapCountText" Text="Detail Swaps: 0" FontSize="13" />
  97. <TextBlock x:Name="LiveInstancesText" Text="Live Page Instances: 0" FontSize="13" />
  98. <TextBlock x:Name="TotalCreatedText" Text="Total Pages Created: 0" FontSize="13" />
  99. <DockPanel>
  100. <TextBlock x:Name="ManagedMemoryText" Text="Managed Heap: 0.0 MB" FontSize="13" />
  101. <TextBlock x:Name="MemoryDeltaText" Text="" FontSize="13" FontWeight="SemiBold"
  102. Margin="6,0,0,0" />
  103. </DockPanel>
  104. <TextBlock x:Name="LastOpTimeText" Text="Last Op: —" FontSize="13" />
  105. <Separator Margin="0,4" />
  106. <TextBlock Text="Actions" FontSize="16" FontWeight="SemiBold"
  107. Foreground="{DynamicResource SystemControlHighlightAccentBrush}" />
  108. <Button Content="Swap Detail (New Page)"
  109. HorizontalAlignment="Stretch" Click="OnSwapDetail" />
  110. <Button Content="Swap 5 Times"
  111. HorizontalAlignment="Stretch" Click="OnSwap5" />
  112. <Button Content="Toggle Drawer"
  113. HorizontalAlignment="Stretch" Click="OnToggleDrawer" />
  114. <Separator Margin="0,4" />
  115. <Button Content="Force GC + Refresh"
  116. HorizontalAlignment="Stretch" Click="OnForceGC"
  117. Background="{DynamicResource SystemControlHighlightAccentBrush}"
  118. Foreground="White" />
  119. <CheckBox x:Name="AutoRefreshCheck" Content="Auto-refresh (2s)"
  120. FontSize="13" IsCheckedChanged="OnAutoRefreshChanged" />
  121. <Separator Margin="0,4" />
  122. <TextBlock Text="Detail History" FontSize="16" FontWeight="SemiBold"
  123. Foreground="{DynamicResource SystemControlHighlightAccentBrush}" />
  124. <StackPanel x:Name="HistoryPanel" Spacing="4" />
  125. </StackPanel>
  126. </ScrollViewer>
  127. </Border>
  128. </Grid>
  129. </UserControl>