DrawerPageCustomFlyoutPage.xaml.cs 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. using System;
  2. using Avalonia.Controls;
  3. using Avalonia.Controls.Shapes;
  4. using Avalonia.Interactivity;
  5. using Avalonia.Media;
  6. using Avalonia.Threading;
  7. namespace ControlCatalog.Pages
  8. {
  9. public partial class DrawerPageCustomFlyoutPage : UserControl
  10. {
  11. private Ellipse? _bubble1;
  12. private Ellipse? _bubble2;
  13. private DispatcherTimer? _bubbleTimer;
  14. private double _bubblePhase;
  15. public DrawerPageCustomFlyoutPage()
  16. {
  17. InitializeComponent();
  18. _bubble1 = this.FindControl<Ellipse>("Bubble1");
  19. _bubble2 = this.FindControl<Ellipse>("Bubble2");
  20. DrawerPageControl.PropertyChanged += (_, args) =>
  21. {
  22. if (args.Property == DrawerPage.IsOpenProperty)
  23. OnDrawerOpenChanged((bool)args.NewValue!);
  24. };
  25. _ = DetailNav.PushAsync(BuildDetailPage("Home"), null);
  26. }
  27. private Control[] MenuItems =>
  28. new Control[] { MenuItem1, MenuItem2, MenuItem3, MenuItem4, MenuItem5, FooterRow };
  29. private void OnDrawerOpenChanged(bool isOpen)
  30. {
  31. if (isOpen)
  32. {
  33. StartBubbles();
  34. foreach (var item in MenuItems)
  35. {
  36. item.Opacity = 1.0;
  37. if (item.RenderTransform is TranslateTransform tt)
  38. tt.Y = 0;
  39. }
  40. }
  41. else
  42. {
  43. StopBubbles();
  44. foreach (var item in MenuItems)
  45. {
  46. var savedItemT = item.Transitions;
  47. item.Transitions = null;
  48. item.Opacity = 0.0;
  49. item.Transitions = savedItemT;
  50. if (item.RenderTransform is TranslateTransform tt)
  51. {
  52. var savedTT = tt.Transitions;
  53. tt.Transitions = null;
  54. tt.Y = 25;
  55. tt.Transitions = savedTT;
  56. }
  57. }
  58. }
  59. }
  60. private void StartBubbles()
  61. {
  62. if (_bubbleTimer != null) return;
  63. _bubblePhase = 0;
  64. _bubbleTimer = new DispatcherTimer(DispatcherPriority.Render)
  65. {
  66. Interval = TimeSpan.FromMilliseconds(16)
  67. };
  68. _bubbleTimer.Tick += OnBubbleTick;
  69. _bubbleTimer.Start();
  70. }
  71. private void StopBubbles()
  72. {
  73. if (_bubbleTimer == null) return;
  74. _bubbleTimer.Stop();
  75. _bubbleTimer.Tick -= OnBubbleTick;
  76. _bubbleTimer = null;
  77. if (_bubble1 != null) _bubble1.RenderTransform = null;
  78. if (_bubble2 != null) _bubble2.RenderTransform = null;
  79. }
  80. private void OnBubbleTick(object? sender, EventArgs e)
  81. {
  82. _bubblePhase += 0.012;
  83. if (_bubble1 != null)
  84. _bubble1.RenderTransform = new TranslateTransform(
  85. x: Math.Sin(_bubblePhase * 0.65) * 10,
  86. y: Math.Sin(_bubblePhase) * 14);
  87. if (_bubble2 != null)
  88. _bubble2.RenderTransform = new TranslateTransform(
  89. x: Math.Sin(_bubblePhase * 0.45 + 1.8) * 7,
  90. y: Math.Cos(_bubblePhase * 0.85 + 0.6) * 10);
  91. }
  92. private async void OnMenuItemClick(object? sender, RoutedEventArgs e)
  93. {
  94. if (sender is not Button button) return;
  95. var tag = button.Tag?.ToString() ?? "Home";
  96. DrawerPageControl.IsOpen = false;
  97. await DetailNav.ReplaceAsync(BuildDetailPage(tag), null);
  98. }
  99. private static ContentPage BuildDetailPage(string section)
  100. {
  101. var (iconPath, body) = section switch
  102. {
  103. "Home" =>
  104. ("M10,20V14H14V20H19V12H22L12,3L2,12H5V20H10Z",
  105. "Welcome back! Here is your dashboard with recent activity, quick actions, and personalized content."),
  106. "Explore" =>
  107. ("M12,11.5A2.5,2.5 0 0,1 9.5,9A2.5,2.5 0 0,1 12,6.5A2.5,2.5 0 0,1 14.5,9A2.5,2.5 0 0,1 12,11.5M12,2A7,7 0 0,0 5,9C5,14.25 12,22 12,22C12,22 19,14.25 19,9A7,7 0 0,0 12,2Z",
  108. "Discover new places, trending topics, and recommended content tailored to your interests."),
  109. "Messages" =>
  110. ("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",
  111. "Your conversations and notifications. Stay connected with the people who matter."),
  112. "Profile" =>
  113. ("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",
  114. "View and edit your profile, manage privacy settings, and control your account preferences."),
  115. "Settings" =>
  116. ("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",
  117. "Configure application preferences, notifications, and privacy options."),
  118. _ => ("M12,2A10,10 0 0,1 22,12A10,10 0 0,1 12,22A10,10 0 0,1 2,12A10,10 0 0,1 12,2Z", "")
  119. };
  120. var page = NavigationDemoHelper.MakeSectionPage(section, iconPath, section, body, 0);
  121. NavigationPage.SetHasNavigationBar(page, false);
  122. return page;
  123. }
  124. }
  125. }